summaryrefslogtreecommitdiff
authorskyhusker <skyhusker>2005-02-02 13:36:32 (UTC)
committer skyhusker <skyhusker>2005-02-02 13:36:32 (UTC)
commit737b0b5ce3e5db15bf11f696b070c9b475f92b61 (patch) (side-by-side diff)
treef37a834ddaffc9447c71a86c594a522fe97295b7
parentf1f48d6711b359499c7ab3b9102a25f21259df53 (diff)
downloadopie-737b0b5ce3e5db15bf11f696b070c9b475f92b61.zip
opie-737b0b5ce3e5db15bf11f696b070c9b475f92b61.tar.gz
opie-737b0b5ce3e5db15bf11f696b070c9b475f92b61.tar.bz2
Slightly modified debug messages
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--noncore/net/opieirc/ircmessage.cpp14
1 files changed, 7 insertions, 7 deletions
diff --git a/noncore/net/opieirc/ircmessage.cpp b/noncore/net/opieirc/ircmessage.cpp
index 1b7072e..da8db77 100644
--- a/noncore/net/opieirc/ircmessage.cpp
+++ b/noncore/net/opieirc/ircmessage.cpp
@@ -1,157 +1,157 @@
#include <opie2/odebug.h>
using namespace Opie::Core;
#include <qtextstream.h>
#include <qstring.h>
#include <qstringlist.h>
#include <qregexp.h>
#include "ircmessage.h"
/*
* Create a new IRCMessage by evaluating
* a received string
*/
IRCMessage::IRCMessage(QString line) {
/* Remove CRs from the message */
while((line.right(1) == "\n") || (line.right(1) == "\r"))
line = line.left(line.length() - 1);
QTextIStream stream(&line);
QString temp;
stream >> temp;
if (temp.startsWith(":")) {
/* extract the prefix */
m_prefix = temp.right(temp.length()-1);
stream >> temp;
m_command = temp.upper();
m_allParameters = line.right(line.length() - m_prefix.length() - m_command.length() - 3);
} else {
m_command = temp.upper();
m_allParameters = line.right(line.length() - m_command.length() - 1);
}
/* Create a list of all parameters */
while(!(stream.atEnd())) {
stream >> temp;
if (temp.startsWith(":")) {
/* last parameter */
m_trailing = line.right(line.length() - line.find(QChar(':'), 1) - 1);
m_parameters << m_trailing;
break;
} else {
m_parameters << temp;
}
}
m_commandNumber = m_command.toInt(&m_isNumerical);
/* Is this a CTCP command */
if ((m_command == "PRIVMSG" || m_command == "NOTICE") && m_trailing.length()>0 && m_trailing.left(1) == QChar(1)) {
m_ctcp = TRUE;
- if (m_command == "PRIVMSG") {
- m_ctcpRequest = TRUE;
- }
- else {
- m_ctcpRequest = FALSE;
- }
+
+ m_ctcpRequest = (m_command == "PRIVMSG");
/* Strip CTCP \001 characters */
m_allParameters = m_allParameters.replace(QRegExp(QChar(1)), "");
QTextIStream ctcpStream(&m_allParameters);
ctcpStream >> m_ctcpDestination;
ctcpStream >> temp;
m_ctcpCommand = temp.upper().right(temp.length()-1);
m_parameters.clear();
int length = m_allParameters.length() - m_ctcpCommand.length() - 1;
length -= m_ctcpDestination.length() + 1;
if (length <= 0) {
m_allParameters = "";
}
else {
m_allParameters = m_allParameters.right(length);
m_parameters << m_allParameters;
}
}
else {
m_ctcp = FALSE;
}
odebug << "Parsed: " << line << oendl;
odebug << "Prefix: " << m_prefix << oendl;
odebug << "Command: " << m_command << oendl;
odebug << "Allparameters: " << m_allParameters << oendl;
+
for (unsigned int i=0; i<m_parameters.count(); i++) {
odebug << "Parameter " << i << ":" << m_parameters[i] << oendl;
}
- odebug << "CTCP Command: " << m_ctcpCommand << oendl;
+
+ if(m_ctcp) {
+ odebug << "CTCP " << (m_ctcpRequest? "Request" : "Reply") << ": " << m_ctcpCommand << oendl;
odebug << "CTCP Destination: " << m_ctcpDestination << oendl;
odebug << "CTCP param count is: " << m_parameters.count() << oendl;
+ }
}
QString IRCMessage::param(int param) {
return m_parameters[param];
}
QStringList IRCMessage::params(const QString &paramstring) const {
QStringList params, retvalue;
params = QStringList::split(',', paramstring);
QStringList::Iterator end = params.end();
for (QStringList::Iterator it = params.begin(); it != end; ++it) {
int pos = (*it).find(':');
if(pos < 0) {
if((*it).toUInt() < m_parameters.count())
retvalue << m_parameters[(*it).toUInt()];
}
else {
unsigned int start, end;
start = (*it).left(pos).toUInt();
end = (*it).mid(pos+1).toUInt();
for (unsigned int i=start;i<=end && i < m_parameters.count() ;++i) {
retvalue << m_parameters[i];
}
}
}
return retvalue;
}
QString IRCMessage::prefix() {
return m_prefix;
}
QString IRCMessage::command() {
return m_command;
}
QString IRCMessage::ctcpCommand() {
return m_ctcpCommand;
}
QString IRCMessage::ctcpDestination() {
return m_ctcpDestination;
}
unsigned short IRCMessage::commandNumber() {
return m_commandNumber;
}
bool IRCMessage::isNumerical() {
return m_isNumerical;
}
bool IRCMessage::isCTCP() {
return m_ctcp;
}
bool IRCMessage::isCTCPRequest() {
return m_ctcpRequest;
}