author | skyhusker <skyhusker> | 2005-05-31 21:08:33 (UTC) |
---|---|---|
committer | skyhusker <skyhusker> | 2005-05-31 21:08:33 (UTC) |
commit | b30f28de8d5fa29001bc73a0a0e56ef653f1269f (patch) (unidiff) | |
tree | bd6530f1ba36fb7bf96c1d8c2962446cab416da8 | |
parent | 89417179ed4d38875dc3edce0f4e184edf13f1f2 (diff) | |
download | opie-b30f28de8d5fa29001bc73a0a0e56ef653f1269f.zip opie-b30f28de8d5fa29001bc73a0a0e56ef653f1269f.tar.gz opie-b30f28de8d5fa29001bc73a0a0e56ef653f1269f.tar.bz2 |
Fix channel name validation. Thanks to hrw for reporting.
-rw-r--r-- | noncore/net/opieirc/ircservertab.cpp | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/noncore/net/opieirc/ircservertab.cpp b/noncore/net/opieirc/ircservertab.cpp index d3c0448..5eb1758 100644 --- a/noncore/net/opieirc/ircservertab.cpp +++ b/noncore/net/opieirc/ircservertab.cpp | |||
@@ -1,419 +1,420 @@ | |||
1 | #include <qtextstream.h> | 1 | #include <qtextstream.h> |
2 | #include <qwhatsthis.h> | 2 | #include <qwhatsthis.h> |
3 | 3 | ||
4 | #include "ircservertab.h" | 4 | #include "ircservertab.h" |
5 | #include "ircmessageparser.h" | 5 | #include "ircmessageparser.h" |
6 | #include "ircchannelperson.h" | 6 | #include "ircchannelperson.h" |
7 | 7 | ||
8 | 8 | ||
9 | bool IRCServerTab::containsPing( const QString& text, IRCServerTab* tab ) { | 9 | bool IRCServerTab::containsPing( const QString& text, IRCServerTab* tab ) { |
10 | return (text.contains(IRCMessageParser::tr("Received a CTCP PING from "))) || | 10 | return (text.contains(IRCMessageParser::tr("Received a CTCP PING from "))) || |
11 | (text.find("ping") != -1 && text.find( tab->server()->nick() != -1)); | 11 | (text.find("ping") != -1 && text.find( tab->server()->nick() != -1)); |
12 | } | 12 | } |
13 | 13 | ||
14 | 14 | ||
15 | IRCServerTab::IRCServerTab(IRCServer server, MainWindow *mainWindow, QWidget *parent, const char *name, WFlags f) : IRCTab(parent, name, f) { | 15 | IRCServerTab::IRCServerTab(IRCServer server, MainWindow *mainWindow, QWidget *parent, const char *name, WFlags f) : IRCTab(parent, name, f) { |
16 | m_server = server; | 16 | m_server = server; |
17 | m_session = new IRCSession(this, &m_server); | 17 | m_session = new IRCSession(this, &m_server); |
18 | m_mainWindow = mainWindow; | 18 | m_mainWindow = mainWindow; |
19 | m_close = FALSE; | 19 | m_close = FALSE; |
20 | m_lines = 0; | 20 | m_lines = 0; |
21 | m_description->setText(tr("Connecting to")+" <b>" + server.hostname() + ":" + QString::number(server.port()) + "</b>"); | 21 | m_description->setText(tr("Connecting to")+" <b>" + server.hostname() + ":" + QString::number(server.port()) + "</b>"); |
22 | m_textview = new QTextView(this); | 22 | m_textview = new QTextView(this); |
23 | m_textview->setHScrollBarMode(QScrollView::AlwaysOff); | 23 | m_textview->setHScrollBarMode(QScrollView::AlwaysOff); |
24 | m_textview->setVScrollBarMode(QScrollView::AlwaysOn); | 24 | m_textview->setVScrollBarMode(QScrollView::AlwaysOn); |
25 | m_textview->setTextFormat(RichText); | 25 | m_textview->setTextFormat(RichText); |
26 | QWhatsThis::add(m_textview, tr("Server messages")); | 26 | QWhatsThis::add(m_textview, tr("Server messages")); |
27 | m_layout->add(m_textview); | 27 | m_layout->add(m_textview); |
28 | m_field = new IRCHistoryLineEdit(this); | 28 | m_field = new IRCHistoryLineEdit(this); |
29 | connect(m_field, SIGNAL(nextTab()), this, SIGNAL(nextTab())); | 29 | connect(m_field, SIGNAL(nextTab()), this, SIGNAL(nextTab())); |
30 | connect(m_field, SIGNAL(prevTab()), this, SIGNAL(prevTab())); | 30 | connect(m_field, SIGNAL(prevTab()), this, SIGNAL(prevTab())); |
31 | connect(m_field, SIGNAL(closeTab()), this, SIGNAL(closeTab())); | 31 | connect(m_field, SIGNAL(closeTab()), this, SIGNAL(closeTab())); |
32 | connect(this, SIGNAL(editFocus()), m_field, SLOT(setEditFocus())); | 32 | connect(this, SIGNAL(editFocus()), m_field, SLOT(setEditFocus())); |
33 | 33 | ||
34 | QWhatsThis::add(m_field, tr("Type commands here. A list of available commands can be found inside the OpieIRC help")); | 34 | QWhatsThis::add(m_field, tr("Type commands here. A list of available commands can be found inside the OpieIRC help")); |
35 | m_layout->add(m_field); | 35 | m_layout->add(m_field); |
36 | connect(m_field, SIGNAL(returnPressed()), this, SLOT(processCommand())); | 36 | connect(m_field, SIGNAL(returnPressed()), this, SLOT(processCommand())); |
37 | connect(m_session, SIGNAL(outputReady(IRCOutput)), this, SLOT(display(IRCOutput))); | 37 | connect(m_session, SIGNAL(outputReady(IRCOutput)), this, SLOT(display(IRCOutput))); |
38 | connect(m_mainWindow, SIGNAL(updateScroll()), this, SLOT(scrolling())); | 38 | connect(m_mainWindow, SIGNAL(updateScroll()), this, SLOT(scrolling())); |
39 | connect(m_session, SIGNAL(updateChannels()), this, SLOT(slotUpdateChannels())); | 39 | connect(m_session, SIGNAL(updateChannels()), this, SLOT(slotUpdateChannels())); |
40 | settingsChanged(); | 40 | settingsChanged(); |
41 | 41 | ||
42 | m_field->setFocus(); | 42 | m_field->setFocus(); |
43 | m_field->setActiveWindow(); | 43 | m_field->setActiveWindow(); |
44 | 44 | ||
45 | } | 45 | } |
46 | 46 | ||
47 | void IRCServerTab::scrolling(){ | 47 | void IRCServerTab::scrolling(){ |
48 | m_textview->ensureVisible(0, m_textview->contentsHeight()); | 48 | m_textview->ensureVisible(0, m_textview->contentsHeight()); |
49 | } | 49 | } |
50 | 50 | ||
51 | 51 | ||
52 | void IRCServerTab::appendText(QString text) { | 52 | void IRCServerTab::appendText(QString text) { |
53 | /* not using append because it creates layout problems */ | 53 | /* not using append because it creates layout problems */ |
54 | QString txt = m_textview->text() + IRCTab::appendTimestamp( text ); | 54 | QString txt = m_textview->text() + IRCTab::appendTimestamp( text ); |
55 | 55 | ||
56 | 56 | ||
57 | 57 | ||
58 | if (m_maxLines > 0 && m_lines >= m_maxLines) { | 58 | if (m_maxLines > 0 && m_lines >= m_maxLines) { |
59 | int firstBreak = txt.find('\n'); | 59 | int firstBreak = txt.find('\n'); |
60 | if (firstBreak != -1) { | 60 | if (firstBreak != -1) { |
61 | txt = "<qt bgcolor=\"" + m_backgroundColor + "\"/>" + txt.right(txt.length() - (firstBreak + 1)); | 61 | txt = "<qt bgcolor=\"" + m_backgroundColor + "\"/>" + txt.right(txt.length() - (firstBreak + 1)); |
62 | } | 62 | } |
63 | } else { | 63 | } else { |
64 | m_lines++; | 64 | m_lines++; |
65 | } | 65 | } |
66 | m_textview->setText(txt); | 66 | m_textview->setText(txt); |
67 | m_textview->ensureVisible(0, m_textview->contentsHeight()); | 67 | m_textview->ensureVisible(0, m_textview->contentsHeight()); |
68 | emit changed(this); | 68 | emit changed(this); |
69 | } | 69 | } |
70 | 70 | ||
71 | IRCServerTab::~IRCServerTab() { | 71 | IRCServerTab::~IRCServerTab() { |
72 | delete m_session; | 72 | delete m_session; |
73 | } | 73 | } |
74 | 74 | ||
75 | void IRCServerTab::removeChannelTab(IRCChannelTab *tab) { | 75 | void IRCServerTab::removeChannelTab(IRCChannelTab *tab) { |
76 | m_channelTabs.remove(tab); | 76 | m_channelTabs.remove(tab); |
77 | } | 77 | } |
78 | 78 | ||
79 | void IRCServerTab::removeQueryTab(IRCQueryTab *tab) { | 79 | void IRCServerTab::removeQueryTab(IRCQueryTab *tab) { |
80 | m_queryTabs.remove(tab); | 80 | m_queryTabs.remove(tab); |
81 | } | 81 | } |
82 | 82 | ||
83 | void IRCServerTab::addQueryTab(IRCQueryTab *tab) { | 83 | void IRCServerTab::addQueryTab(IRCQueryTab *tab) { |
84 | m_queryTabs.append(tab); | 84 | m_queryTabs.append(tab); |
85 | } | 85 | } |
86 | 86 | ||
87 | QString IRCServerTab::title() { | 87 | QString IRCServerTab::title() { |
88 | return "Server"; | 88 | return "Server"; |
89 | } | 89 | } |
90 | 90 | ||
91 | IRCSession *IRCServerTab::session() { | 91 | IRCSession *IRCServerTab::session() { |
92 | return m_session; | 92 | return m_session; |
93 | } | 93 | } |
94 | /* | 94 | /* |
95 | QString *IRCServerTab::mynick() { | 95 | QString *IRCServerTab::mynick() { |
96 | return (*m_server->nick()); | 96 | return (*m_server->nick()); |
97 | } */ | 97 | } */ |
98 | 98 | ||
99 | IRCServer *IRCServerTab::server() { | 99 | IRCServer *IRCServerTab::server() { |
100 | return &m_server; | 100 | return &m_server; |
101 | } | 101 | } |
102 | 102 | ||
103 | void IRCServerTab::settingsChanged() { | 103 | void IRCServerTab::settingsChanged() { |
104 | m_textview->setText("<qt bgcolor=\"" + m_backgroundColor + "\"/>"); | 104 | m_textview->setText("<qt bgcolor=\"" + m_backgroundColor + "\"/>"); |
105 | m_lines = 0; | 105 | m_lines = 0; |
106 | } | 106 | } |
107 | 107 | ||
108 | void IRCServerTab::executeCommand(IRCTab *tab, QString line) { | 108 | void IRCServerTab::executeCommand(IRCTab *tab, QString line) { |
109 | QTextIStream stream(&line); | 109 | QTextIStream stream(&line); |
110 | QString command; | 110 | QString command; |
111 | stream >> command; | 111 | stream >> command; |
112 | command = command.upper().right(command.length()-1); | 112 | command = command.upper().right(command.length()-1); |
113 | 113 | ||
114 | //JOIN | 114 | //JOIN |
115 | if (command == "JOIN" || command == "J") { | 115 | if (command == "JOIN" || command == "J") { |
116 | QString channel; | 116 | QString channel; |
117 | stream >> channel; | 117 | stream >> channel; |
118 | /* According to RFC 1459 */ | 118 | /* According to RFC 1459 */ |
119 | if (channel.length() > 0 && channel.length() < 200 && | 119 | if (channel.length() > 0 && channel.length() < 200 && |
120 | channel.find(",") == -1 && channel.find("") == -1) { | 120 | channel.find(",") == -1 && channel.find('\007') == -1) { |
121 | 121 | ||
122 | if (!channel.startsWith("#") && !channel.startsWith("&")) { | 122 | if (!channel.startsWith("#") && !channel.startsWith("&") |
123 | && !channel.startsWith("+") && !channel.startsWith("!")) { | ||
123 | channel = channel.prepend("#"); | 124 | channel = channel.prepend("#"); |
124 | } | 125 | } |
125 | m_session->join(channel); | 126 | m_session->join(channel); |
126 | } else { | 127 | } else { |
127 | tab->appendText("<font color=\"" + m_errorColor + "\">Unknown channel format!</font><br>"); | 128 | tab->appendText("<font color=\"" + m_errorColor + "\">Unknown channel format!</font><br>"); |
128 | } | 129 | } |
129 | } | 130 | } |
130 | 131 | ||
131 | //KICK | 132 | //KICK |
132 | else if (command == "KICK"){ | 133 | else if (command == "KICK"){ |
133 | QString nickname; | 134 | QString nickname; |
134 | stream >> nickname; | 135 | stream >> nickname; |
135 | if (nickname.length() > 0) { | 136 | if (nickname.length() > 0) { |
136 | if (line.length() > 7 + nickname.length()) { | 137 | if (line.length() > 7 + nickname.length()) { |
137 | QString text = line.right(line.length()-nickname.length()-7); | 138 | QString text = line.right(line.length()-nickname.length()-7); |
138 | IRCPerson person; | 139 | IRCPerson person; |
139 | person.setNick(nickname); | 140 | person.setNick(nickname); |
140 | m_session->kick(((IRCChannelTab *)tab)->channel(), &person, text); | 141 | m_session->kick(((IRCChannelTab *)tab)->channel(), &person, text); |
141 | } else { | 142 | } else { |
142 | IRCPerson person; | 143 | IRCPerson person; |
143 | person.setNick(nickname); | 144 | person.setNick(nickname); |
144 | m_session->kick(((IRCChannelTab *)tab)->channel(), &person); | 145 | m_session->kick(((IRCChannelTab *)tab)->channel(), &person); |
145 | } | 146 | } |
146 | } | 147 | } |
147 | } | 148 | } |
148 | 149 | ||
149 | else if (command == "OP"){ | 150 | else if (command == "OP"){ |
150 | QString nickname; | 151 | QString nickname; |
151 | stream >> nickname; | 152 | stream >> nickname; |
152 | if (nickname.length() > 0) { | 153 | if (nickname.length() > 0) { |
153 | QString text = line.right(line.length()-nickname.length()-5); | 154 | QString text = line.right(line.length()-nickname.length()-5); |
154 | IRCPerson person; | 155 | IRCPerson person; |
155 | person.setNick(nickname); | 156 | person.setNick(nickname); |
156 | m_session->op(((IRCChannelTab *)tab)->channel(), &person); | 157 | m_session->op(((IRCChannelTab *)tab)->channel(), &person); |
157 | } | 158 | } |
158 | } | 159 | } |
159 | 160 | ||
160 | //SEND MODES | 161 | //SEND MODES |
161 | else if (command == "MODE"){ | 162 | else if (command == "MODE"){ |
162 | QString text = line.right(line.length()-6); | 163 | QString text = line.right(line.length()-6); |
163 | if (text.length() > 0) { | 164 | if (text.length() > 0) { |
164 | m_session->mode(text); | 165 | m_session->mode(text); |
165 | } else { | 166 | } else { |
166 | tab->appendText("<font color=\"" + m_errorColor + "\">/mode channel {[+|-]|o|p|s|i|t|n|b|v} [limit] [user] [ban mask]<br>/mode nickname {[+|-]|i|w|s|o}</font><br>"); | 167 | tab->appendText("<font color=\"" + m_errorColor + "\">/mode channel {[+|-]|o|p|s|i|t|n|b|v} [limit] [user] [ban mask]<br>/mode nickname {[+|-]|i|w|s|o}</font><br>"); |
167 | } | 168 | } |
168 | } | 169 | } |
169 | //SEND RAW MESSAGE TO SERVER, COMPLETELY UNCHECKED - anything in the RFC...or really anything you want | 170 | //SEND RAW MESSAGE TO SERVER, COMPLETELY UNCHECKED - anything in the RFC...or really anything you want |
170 | else if (command == "RAW"){ | 171 | else if (command == "RAW"){ |
171 | QString text = line.right(line.length()-5); | 172 | QString text = line.right(line.length()-5); |
172 | if (text.length() > 0) { | 173 | if (text.length() > 0) { |
173 | m_session->raw(text); | 174 | m_session->raw(text); |
174 | } | 175 | } |
175 | } | 176 | } |
176 | else if (command == "SUSPEND"){ | 177 | else if (command == "SUSPEND"){ |
177 | QString text = line.right(line.length()-9); | 178 | QString text = line.right(line.length()-9); |
178 | if (text.upper() == "ON") { | 179 | if (text.upper() == "ON") { |
179 | QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; | 180 | QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; |
180 | } | 181 | } |
181 | else if (text.upper() == "OFF"){ | 182 | else if (text.upper() == "OFF"){ |
182 | QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Disable; | 183 | QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Disable; |
183 | } else { | 184 | } else { |
184 | tab->appendText("<font color=\"" + m_errorColor + "\">Line: "+ line +"</font><br>Text: "+text); | 185 | tab->appendText("<font color=\"" + m_errorColor + "\">Line: "+ line +"</font><br>Text: "+text); |
185 | } | 186 | } |
186 | } | 187 | } |
187 | 188 | ||
188 | else if (command == "QUIT"){ | 189 | else if (command == "QUIT"){ |
189 | QString text = line.right(line.length()-6); | 190 | QString text = line.right(line.length()-6); |
190 | if (text.length() > 0) { | 191 | if (text.length() > 0) { |
191 | m_session->quit(text); | 192 | m_session->quit(text); |
192 | } else { | 193 | } else { |
193 | m_session->quit(); | 194 | m_session->quit(); |
194 | } | 195 | } |
195 | } | 196 | } |
196 | 197 | ||
197 | //SEND ACTION | 198 | //SEND ACTION |
198 | else if (command == "ME") { | 199 | else if (command == "ME") { |
199 | QString text = line.right(line.length()-4); | 200 | QString text = line.right(line.length()-4); |
200 | if (text.length() > 0) { | 201 | if (text.length() > 0) { |
201 | if (tab->isA("IRCChannelTab")) { | 202 | if (tab->isA("IRCChannelTab")) { |
202 | tab->appendText("<font color=\"" + m_selfColor + "\">*" + IRCOutput::toHTML(m_server.nick()) + " " + IRCOutput::toHTML(text) + "</font><br>"); | 203 | tab->appendText("<font color=\"" + m_selfColor + "\">*" + IRCOutput::toHTML(m_server.nick()) + " " + IRCOutput::toHTML(text) + "</font><br>"); |
203 | m_session->sendAction(((IRCChannelTab *)tab)->channel(), text); | 204 | m_session->sendAction(((IRCChannelTab *)tab)->channel(), text); |
204 | } else if (tab->isA("IRCQueryTab")) { | 205 | } else if (tab->isA("IRCQueryTab")) { |
205 | tab->appendText("<font color=\"" + m_selfColor + "\">*" + IRCOutput::toHTML(m_server.nick()) + " " + IRCOutput::toHTML(text) + "</font><br>"); | 206 | tab->appendText("<font color=\"" + m_selfColor + "\">*" + IRCOutput::toHTML(m_server.nick()) + " " + IRCOutput::toHTML(text) + "</font><br>"); |
206 | m_session->sendAction(((IRCQueryTab *)tab)->person(), text); | 207 | m_session->sendAction(((IRCQueryTab *)tab)->person(), text); |
207 | } else { | 208 | } else { |
208 | tab->appendText("<font color=\"" + m_errorColor + "\">Invalid tab for this command</font><br>"); | 209 | tab->appendText("<font color=\"" + m_errorColor + "\">Invalid tab for this command</font><br>"); |
209 | } | 210 | } |
210 | } | 211 | } |
211 | } | 212 | } |
212 | //SEND PRIVMSG | 213 | //SEND PRIVMSG |
213 | else if (command == "MSG") { | 214 | else if (command == "MSG") { |
214 | QString nickname; | 215 | QString nickname; |
215 | stream >> nickname; | 216 | stream >> nickname; |
216 | if (nickname.length() > 0) { | 217 | if (nickname.length() > 0) { |
217 | if (line.length() > 6 + nickname.length()) { | 218 | if (line.length() > 6 + nickname.length()) { |
218 | QString text = line.right(line.length()-nickname.length()-6); | 219 | QString text = line.right(line.length()-nickname.length()-6); |
219 | IRCPerson person; | 220 | IRCPerson person; |
220 | person.setNick(nickname); | 221 | person.setNick(nickname); |
221 | tab->appendText("<font color=\"" + m_textColor + "\">></font><font color=\"" + m_otherColor + "\">"+IRCOutput::toHTML(nickname)+"</font><font color=\"" + m_textColor + "\">< "+IRCOutput::toHTML(text)+"</font><br>"); | 222 | tab->appendText("<font color=\"" + m_textColor + "\">></font><font color=\"" + m_otherColor + "\">"+IRCOutput::toHTML(nickname)+"</font><font color=\"" + m_textColor + "\">< "+IRCOutput::toHTML(text)+"</font><br>"); |
222 | m_session->sendMessage(&person, text); | 223 | m_session->sendMessage(&person, text); |
223 | } | 224 | } |
224 | } | 225 | } |
225 | } | 226 | } |
226 | else { | 227 | else { |
227 | tab->appendText("<font color=\"" + m_errorColor + "\">Unknown command</font><br>"); | 228 | tab->appendText("<font color=\"" + m_errorColor + "\">Unknown command</font><br>"); |
228 | } | 229 | } |
229 | } | 230 | } |
230 | 231 | ||
231 | void IRCServerTab::processCommand() { | 232 | void IRCServerTab::processCommand() { |
232 | QString text = m_field->text(); | 233 | QString text = m_field->text(); |
233 | if (text.startsWith("/") && !text.startsWith("//")) { | 234 | if (text.startsWith("/") && !text.startsWith("//")) { |
234 | /* Command mode */ | 235 | /* Command mode */ |
235 | executeCommand(this, text); | 236 | executeCommand(this, text); |
236 | } | 237 | } |
237 | m_field->clear(); | 238 | m_field->clear(); |
238 | } | 239 | } |
239 | 240 | ||
240 | void IRCServerTab::doConnect() { | 241 | void IRCServerTab::doConnect() { |
241 | m_session->beginSession(); | 242 | m_session->beginSession(); |
242 | } | 243 | } |
243 | 244 | ||
244 | void IRCServerTab::remove() { | 245 | void IRCServerTab::remove() { |
245 | /* Close requested */ | 246 | /* Close requested */ |
246 | if (m_session->isSessionActive()) { | 247 | if (m_session->isSessionActive()) { |
247 | /* While there is a running session */ | 248 | /* While there is a running session */ |
248 | m_close = TRUE; | 249 | m_close = TRUE; |
249 | m_session->endSession(); | 250 | m_session->endSession(); |
250 | } else { | 251 | } else { |
251 | /* Session has previously been closed */ | 252 | /* Session has previously been closed */ |
252 | m_channelTabs.first(); | 253 | m_channelTabs.first(); |
253 | while (m_channelTabs.current() != 0) { | 254 | while (m_channelTabs.current() != 0) { |
254 | m_mainWindow->killTab(m_channelTabs.current(), true); | 255 | m_mainWindow->killTab(m_channelTabs.current(), true); |
255 | } | 256 | } |
256 | m_queryTabs.first(); | 257 | m_queryTabs.first(); |
257 | while (m_queryTabs.current() != 0) { | 258 | while (m_queryTabs.current() != 0) { |
258 | m_mainWindow->killTab(m_queryTabs.current(), true); | 259 | m_mainWindow->killTab(m_queryTabs.current(), true); |
259 | } | 260 | } |
260 | m_mainWindow->killTab(this); | 261 | m_mainWindow->killTab(this); |
261 | } | 262 | } |
262 | } | 263 | } |
263 | 264 | ||
264 | IRCChannelTab *IRCServerTab::getTabForChannel(IRCChannel *channel) { | 265 | IRCChannelTab *IRCServerTab::getTabForChannel(IRCChannel *channel) { |
265 | QListIterator<IRCChannelTab> it(m_channelTabs); | 266 | QListIterator<IRCChannelTab> it(m_channelTabs); |
266 | 267 | ||
267 | for (; it.current(); ++it) { | 268 | for (; it.current(); ++it) { |
268 | if (it.current()->channel() == channel) | 269 | if (it.current()->channel() == channel) |
269 | return it.current(); | 270 | return it.current(); |
270 | } | 271 | } |
271 | return 0; | 272 | return 0; |
272 | } | 273 | } |
273 | 274 | ||
274 | IRCQueryTab *IRCServerTab::getTabForQuery(IRCPerson *person) { | 275 | IRCQueryTab *IRCServerTab::getTabForQuery(IRCPerson *person) { |
275 | QListIterator<IRCQueryTab> it(m_queryTabs); | 276 | QListIterator<IRCQueryTab> it(m_queryTabs); |
276 | 277 | ||
277 | for (; it.current(); ++it) { | 278 | for (; it.current(); ++it) { |
278 | if (it.current()->person()->nick() == person->nick()) | 279 | if (it.current()->person()->nick() == person->nick()) |
279 | return it.current(); | 280 | return it.current(); |
280 | } | 281 | } |
281 | return 0; | 282 | return 0; |
282 | } | 283 | } |
283 | 284 | ||
284 | void IRCServerTab::display(IRCOutput output) { | 285 | void IRCServerTab::display(IRCOutput output) { |
285 | 286 | ||
286 | /* All messages to be displayed inside the GUI get here */ | 287 | /* All messages to be displayed inside the GUI get here */ |
287 | switch (output.type()) { | 288 | switch (output.type()) { |
288 | case OUTPUT_CONNCLOSE: | 289 | case OUTPUT_CONNCLOSE: |
289 | if (m_close) { | 290 | if (m_close) { |
290 | m_channelTabs.first(); | 291 | m_channelTabs.first(); |
291 | while (m_channelTabs.current() != 0) { | 292 | while (m_channelTabs.current() != 0) { |
292 | m_mainWindow->killTab(m_channelTabs.current(), true); | 293 | m_mainWindow->killTab(m_channelTabs.current(), true); |
293 | } | 294 | } |
294 | m_queryTabs.first(); | 295 | m_queryTabs.first(); |
295 | while (m_queryTabs.current() != 0) { | 296 | while (m_queryTabs.current() != 0) { |
296 | m_mainWindow->killTab(m_queryTabs.current(), true); | 297 | m_mainWindow->killTab(m_queryTabs.current(), true); |
297 | } | 298 | } |
298 | m_mainWindow->killTab(this); | 299 | m_mainWindow->killTab(this); |
299 | } else { | 300 | } else { |
300 | appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() +"</font><br>"); | 301 | appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() +"</font><br>"); |
301 | QListIterator<IRCChannelTab> it(m_channelTabs); | 302 | QListIterator<IRCChannelTab> it(m_channelTabs); |
302 | for (; it.current(); ++it) { | 303 | for (; it.current(); ++it) { |
303 | it.current()->appendText("<font color=\"" + m_serverColor + "\">" + output.htmlMessage() +"</font><br>"); | 304 | it.current()->appendText("<font color=\"" + m_serverColor + "\">" + output.htmlMessage() +"</font><br>"); |
304 | } | 305 | } |
305 | } | 306 | } |
306 | break; | 307 | break; |
307 | case OUTPUT_SELFJOIN: { | 308 | case OUTPUT_SELFJOIN: { |
308 | IRCChannelTab *channeltab = new IRCChannelTab((IRCChannel *)output.getParam(0), this, m_mainWindow, (QWidget *)parent()); | 309 | IRCChannelTab *channeltab = new IRCChannelTab((IRCChannel *)output.getParam(0), this, m_mainWindow, (QWidget *)parent()); |
309 | m_channelTabs.append(channeltab); | 310 | m_channelTabs.append(channeltab); |
310 | m_mainWindow->addTab(channeltab); | 311 | m_mainWindow->addTab(channeltab); |
311 | } | 312 | } |
312 | break; | 313 | break; |
313 | case OUTPUT_CHANPRIVMSG: { | 314 | case OUTPUT_CHANPRIVMSG: { |
314 | IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); | 315 | IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); |
315 | channelTab->appendText("<font color=\"" + m_textColor + "\"><</font><font color=\"" + m_otherColor + "\">"+IRCOutput::toHTML(((IRCChannelPerson *)output.getParam(1))->nick())+"</font><font color=\"" + m_textColor + "\">> " + output.htmlMessage()+"</font><br>"); | 316 | channelTab->appendText("<font color=\"" + m_textColor + "\"><</font><font color=\"" + m_otherColor + "\">"+IRCOutput::toHTML(((IRCChannelPerson *)output.getParam(1))->nick())+"</font><font color=\"" + m_textColor + "\">> " + output.htmlMessage()+"</font><br>"); |
316 | } | 317 | } |
317 | break; | 318 | break; |
318 | case OUTPUT_QUERYACTION: | 319 | case OUTPUT_QUERYACTION: |
319 | case OUTPUT_QUERYPRIVMSG: { | 320 | case OUTPUT_QUERYPRIVMSG: { |
320 | IRCQueryTab *queryTab = getTabForQuery((IRCPerson *)output.getParam(0)); | 321 | IRCQueryTab *queryTab = getTabForQuery((IRCPerson *)output.getParam(0)); |
321 | if (!queryTab) { | 322 | if (!queryTab) { |
322 | queryTab = new IRCQueryTab((IRCPerson *)output.getParam(0), this, m_mainWindow, (QWidget *)parent()); | 323 | queryTab = new IRCQueryTab((IRCPerson *)output.getParam(0), this, m_mainWindow, (QWidget *)parent()); |
323 | m_queryTabs.append(queryTab); | 324 | m_queryTabs.append(queryTab); |
324 | m_mainWindow->addTab(queryTab); | 325 | m_mainWindow->addTab(queryTab); |
325 | } | 326 | } |
326 | queryTab->display(output); | 327 | queryTab->display(output); |
327 | } | 328 | } |
328 | break; | 329 | break; |
329 | case OUTPUT_SELFPART: { | 330 | case OUTPUT_SELFPART: { |
330 | IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); | 331 | IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); |
331 | if (channelTab) | 332 | if (channelTab) |
332 | m_mainWindow->killTab(channelTab, true); | 333 | m_mainWindow->killTab(channelTab, true); |
333 | } | 334 | } |
334 | break; | 335 | break; |
335 | case OUTPUT_SELFKICK: { | 336 | case OUTPUT_SELFKICK: { |
336 | appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() + "</font><br>"); | 337 | appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() + "</font><br>"); |
337 | IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); | 338 | IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); |
338 | if (channelTab) | 339 | if (channelTab) |
339 | m_mainWindow->killTab(channelTab, true); | 340 | m_mainWindow->killTab(channelTab, true); |
340 | } | 341 | } |
341 | break; | 342 | break; |
342 | case OUTPUT_CHANACTION: { | 343 | case OUTPUT_CHANACTION: { |
343 | IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); | 344 | IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); |
344 | channelTab->appendText("<font color=\"" + m_otherColor + "\">"+output.htmlMessage()+"</font><br>"); | 345 | channelTab->appendText("<font color=\"" + m_otherColor + "\">"+output.htmlMessage()+"</font><br>"); |
345 | } | 346 | } |
346 | break; | 347 | break; |
347 | case OUTPUT_TOPIC: { | 348 | case OUTPUT_TOPIC: { |
348 | IRCChannel *channel = (IRCChannel *) output.getParam(0); | 349 | IRCChannel *channel = (IRCChannel *) output.getParam(0); |
349 | if (channel) { | 350 | if (channel) { |
350 | IRCChannelTab *channelTab = getTabForChannel(channel); | 351 | IRCChannelTab *channelTab = getTabForChannel(channel); |
351 | if (channelTab) { | 352 | if (channelTab) { |
352 | channelTab->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); | 353 | channelTab->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); |
353 | return; | 354 | return; |
354 | } | 355 | } |
355 | } | 356 | } |
356 | IRCChannelTab::enqueue(channel->channelname(), "<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); | 357 | IRCChannelTab::enqueue(channel->channelname(), "<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); |
357 | } | 358 | } |
358 | break; | 359 | break; |
359 | case OUTPUT_QUIT: { | 360 | case OUTPUT_QUIT: { |
360 | QString nick = ((IRCPerson *)output.getParam(0))->nick(); | 361 | QString nick = ((IRCPerson *)output.getParam(0))->nick(); |
361 | QListIterator<IRCChannelTab> it(m_channelTabs); | 362 | QListIterator<IRCChannelTab> it(m_channelTabs); |
362 | for (; it.current(); ++it) { | 363 | for (; it.current(); ++it) { |
363 | if (it.current()->list()->hasPerson(nick)) { | 364 | if (it.current()->list()->hasPerson(nick)) { |
364 | it.current()->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); | 365 | it.current()->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); |
365 | it.current()->list()->update(); | 366 | it.current()->list()->update(); |
366 | } | 367 | } |
367 | } | 368 | } |
368 | } | 369 | } |
369 | break; | 370 | break; |
370 | case OUTPUT_NICKCHANGE: { | 371 | case OUTPUT_NICKCHANGE: { |
371 | QString *nick = static_cast<QString*>(output.getParam(0)); | 372 | QString *nick = static_cast<QString*>(output.getParam(0)); |
372 | if(!nick) { | 373 | if(!nick) { |
373 | appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); | 374 | appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); |
374 | break; | 375 | break; |
375 | } | 376 | } |
376 | QListIterator<IRCChannelTab> it(m_channelTabs); | 377 | QListIterator<IRCChannelTab> it(m_channelTabs); |
377 | for (; it.current(); ++it) { | 378 | for (; it.current(); ++it) { |
378 | if (it.current()->list()->hasPerson(*nick)) { | 379 | if (it.current()->list()->hasPerson(*nick)) { |
379 | it.current()->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); | 380 | it.current()->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); |
380 | } | 381 | } |
381 | } | 382 | } |
382 | delete nick; | 383 | delete nick; |
383 | } | 384 | } |
384 | break; | 385 | break; |
385 | case OUTPUT_OTHERJOIN: | 386 | case OUTPUT_OTHERJOIN: |
386 | case OUTPUT_OTHERKICK: | 387 | case OUTPUT_OTHERKICK: |
387 | case OUTPUT_CHANPERSONMODE: | 388 | case OUTPUT_CHANPERSONMODE: |
388 | case OUTPUT_OTHERPART: { | 389 | case OUTPUT_OTHERPART: { |
389 | IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); | 390 | IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); |
390 | channelTab->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); | 391 | channelTab->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); |
391 | channelTab->list()->update(); | 392 | channelTab->list()->update(); |
392 | } | 393 | } |
393 | break; | 394 | break; |
394 | case OUTPUT_CTCP: | 395 | case OUTPUT_CTCP: |
395 | appendText("<font color=\"" + m_notificationColor + "\">" + output.htmlMessage() + "</font><br>"); | 396 | appendText("<font color=\"" + m_notificationColor + "\">" + output.htmlMessage() + "</font><br>"); |
396 | break; | 397 | break; |
397 | case OUTPUT_ERROR: | 398 | case OUTPUT_ERROR: |
398 | appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() + "</font><br>"); | 399 | appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() + "</font><br>"); |
399 | break; | 400 | break; |
400 | case OUTPUT_TITLE: | 401 | case OUTPUT_TITLE: |
401 | m_description->setText(output.message()); | 402 | m_description->setText(output.message()); |
402 | break; | 403 | break; |
403 | default: | 404 | default: |
404 | appendText("<font color=\"" + m_serverColor + "\">" + output.htmlMessage() + "</font><br>"); | 405 | appendText("<font color=\"" + m_serverColor + "\">" + output.htmlMessage() + "</font><br>"); |
405 | break; | 406 | break; |
406 | } | 407 | } |
407 | } | 408 | } |
408 | 409 | ||
409 | void IRCServerTab::slotUpdateChannels() { | 410 | void IRCServerTab::slotUpdateChannels() { |
410 | QListIterator<IRCChannelTab> it(m_channelTabs); | 411 | QListIterator<IRCChannelTab> it(m_channelTabs); |
411 | for (; it.current(); ++it) { | 412 | for (; it.current(); ++it) { |
412 | it.current()->list()->update(); | 413 | it.current()->list()->update(); |
413 | } | 414 | } |
414 | } | 415 | } |
415 | 416 | ||
416 | MainWindow *IRCServerTab::mainwindow() { | 417 | MainWindow *IRCServerTab::mainwindow() { |
417 | return m_mainWindow; | 418 | return m_mainWindow; |
418 | } | 419 | } |
419 | 420 | ||