summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/opieirc/ircmessage.cpp27
-rw-r--r--noncore/net/opieirc/ircmessage.h3
2 files changed, 24 insertions, 6 deletions
diff --git a/noncore/net/opieirc/ircmessage.cpp b/noncore/net/opieirc/ircmessage.cpp
index d19e9e6..1b7072e 100644
--- a/noncore/net/opieirc/ircmessage.cpp
+++ b/noncore/net/opieirc/ircmessage.cpp
@@ -43,42 +43,49 @@ IRCMessage::IRCMessage(QString line) {
43 m_parameters << m_trailing; 43 m_parameters << m_trailing;
44 break; 44 break;
45 } else { 45 } else {
46 m_parameters << temp; 46 m_parameters << temp;
47 } 47 }
48 } 48 }
49 49
50 50
51 m_commandNumber = m_command.toInt(&m_isNumerical); 51 m_commandNumber = m_command.toInt(&m_isNumerical);
52 /* Is this a CTCP command */ 52 /* Is this a CTCP command */
53 if ((m_command == "PRIVMSG" || m_command == "NOTICE") && m_trailing.length()>0 && m_trailing.left(1) == QChar(1)) { 53 if ((m_command == "PRIVMSG" || m_command == "NOTICE") && m_trailing.length()>0 && m_trailing.left(1) == QChar(1)) {
54 m_ctcp = TRUE; 54 m_ctcp = TRUE;
55 if (m_command == "PRIVMSG") {
56 m_ctcpRequest = TRUE;
57 }
58 else {
59 m_ctcpRequest = FALSE;
60 }
61
55 /* Strip CTCP \001 characters */ 62 /* Strip CTCP \001 characters */
56 m_allParameters = m_allParameters.replace(QRegExp(QChar(1)), ""); 63 m_allParameters = m_allParameters.replace(QRegExp(QChar(1)), "");
57 QTextIStream ctcpStream(&m_allParameters); 64 QTextIStream ctcpStream(&m_allParameters);
58 if (m_command == "PRIVMSG") 65 ctcpStream >> m_ctcpDestination;
59 ctcpStream >> m_ctcpDestination;
60 ctcpStream >> temp; 66 ctcpStream >> temp;
61 m_ctcpCommand = temp.upper().right(temp.length()-1); 67 m_ctcpCommand = temp.upper().right(temp.length()-1);
62 m_parameters.clear(); 68 m_parameters.clear();
63 int length = m_allParameters.length() - m_ctcpCommand.length() - 1; 69 int length = m_allParameters.length() - m_ctcpCommand.length() - 1;
64 if (m_command == "PRIVMSG") 70 length -= m_ctcpDestination.length() + 1;
65 length -= m_ctcpDestination.length() + 1;
66 if (length <= 0) { 71 if (length <= 0) {
67 m_allParameters = ""; 72 m_allParameters = "";
68 } else { 73 }
74 else {
69 m_allParameters = m_allParameters.right(length); 75 m_allParameters = m_allParameters.right(length);
70 m_parameters << m_allParameters; 76 m_parameters << m_allParameters;
71 } 77 }
72 } else { 78 }
79 else {
73 m_ctcp = FALSE; 80 m_ctcp = FALSE;
74 } 81 }
75 82
76 83
77 odebug << "Parsed: " << line << oendl; 84 odebug << "Parsed: " << line << oendl;
78 odebug << "Prefix: " << m_prefix << oendl; 85 odebug << "Prefix: " << m_prefix << oendl;
79 odebug << "Command: " << m_command << oendl; 86 odebug << "Command: " << m_command << oendl;
80 odebug << "Allparameters: " << m_allParameters << oendl; 87 odebug << "Allparameters: " << m_allParameters << oendl;
81 for (unsigned int i=0; i<m_parameters.count(); i++) { 88 for (unsigned int i=0; i<m_parameters.count(); i++) {
82 odebug << "Parameter " << i << ":" << m_parameters[i] << oendl; 89 odebug << "Parameter " << i << ":" << m_parameters[i] << oendl;
83 } 90 }
84 odebug << "CTCP Command: " << m_ctcpCommand << oendl; 91 odebug << "CTCP Command: " << m_ctcpCommand << oendl;
@@ -135,20 +142,28 @@ QString IRCMessage::ctcpDestination() {
135unsigned short IRCMessage::commandNumber() { 142unsigned short IRCMessage::commandNumber() {
136 return m_commandNumber; 143 return m_commandNumber;
137} 144}
138 145
139bool IRCMessage::isNumerical() { 146bool IRCMessage::isNumerical() {
140 return m_isNumerical; 147 return m_isNumerical;
141} 148}
142 149
143bool IRCMessage::isCTCP() { 150bool IRCMessage::isCTCP() {
144 return m_ctcp; 151 return m_ctcp;
145} 152}
146 153
154bool IRCMessage::isCTCPRequest() {
155 return m_ctcpRequest;
156}
157
158bool IRCMessage::isCTCPReply() {
159 return !m_ctcpRequest;
160}
161
147QString IRCMessage::trailing() { 162QString IRCMessage::trailing() {
148 return m_trailing; 163 return m_trailing;
149} 164}
150 165
151QString IRCMessage::allParameters() { 166QString IRCMessage::allParameters() {
152 return m_allParameters; 167 return m_allParameters;
153} 168}
154 169
diff --git a/noncore/net/opieirc/ircmessage.h b/noncore/net/opieirc/ircmessage.h
index 10ba450..40bb210 100644
--- a/noncore/net/opieirc/ircmessage.h
+++ b/noncore/net/opieirc/ircmessage.h
@@ -29,24 +29,26 @@ class QStringList;
29 29
30class IRCMessage { 30class IRCMessage {
31public: 31public:
32 /* Parse an IRC message and create the IRCMessage object */ 32 /* Parse an IRC message and create the IRCMessage object */
33 IRCMessage(QString line); 33 IRCMessage(QString line);
34 34
35 /* Return the IRC message prefix (usually sender etc) */ 35 /* Return the IRC message prefix (usually sender etc) */
36 QString prefix(); 36 QString prefix();
37 /* Check if this IRCMessage's command is literal or numerical */ 37 /* Check if this IRCMessage's command is literal or numerical */
38 bool isNumerical(); 38 bool isNumerical();
39 /* CHeck if this IRCMessage is a CTCP message */ 39 /* CHeck if this IRCMessage is a CTCP message */
40 bool isCTCP(); 40 bool isCTCP();
41 bool isCTCPRequest();
42 bool isCTCPReply();
41 /* Return the IRC command (literal commands) */ 43 /* Return the IRC command (literal commands) */
42 QString command(); 44 QString command();
43 /* Return the CTCP command */ 45 /* Return the CTCP command */
44 QString ctcpCommand(); 46 QString ctcpCommand();
45 /* Return the CTCP destination if applicable (channel/person) */ 47 /* Return the CTCP destination if applicable (channel/person) */
46 QString ctcpDestination(); 48 QString ctcpDestination();
47 /* Return the IRC command (numerical commands) */ 49 /* Return the IRC command (numerical commands) */
48 unsigned short commandNumber(); 50 unsigned short commandNumber();
49 /* Return the trailing parameter string */ 51 /* Return the trailing parameter string */
50 QString trailing(); 52 QString trailing();
51 /* Return the complete parameter string */ 53 /* Return the complete parameter string */
52 QString allParameters(); 54 QString allParameters();
@@ -56,15 +58,16 @@ public:
56 QStringList params(const QString &paramstring) const; 58 QStringList params(const QString &paramstring) const;
57protected: 59protected:
58 QString m_prefix; 60 QString m_prefix;
59 QString m_command; 61 QString m_command;
60 QString m_ctcpCommand; 62 QString m_ctcpCommand;
61 QString m_ctcpDestination; 63 QString m_ctcpDestination;
62 unsigned short m_commandNumber; 64 unsigned short m_commandNumber;
63 QString m_allParameters; 65 QString m_allParameters;
64 QString m_trailing; 66 QString m_trailing;
65 QStringList m_parameters; 67 QStringList m_parameters;
66 bool m_isNumerical; 68 bool m_isNumerical;
67 bool m_ctcp; 69 bool m_ctcp;
70 bool m_ctcpRequest;
68}; 71};
69 72
70#endif 73#endif