summaryrefslogtreecommitdiff
path: root/noncore/net
authorwazlaf <wazlaf>2002-09-20 23:28:14 (UTC)
committer wazlaf <wazlaf>2002-09-20 23:28:14 (UTC)
commit912092425248f7fc5155b4c7c46b7d00ec2676bc (patch) (unidiff)
tree5bbf746e83b2dffad89542c42031a573c34da751 /noncore/net
parentcd3df897c1b0ed93c2be3ab411011a0bdfe88bf9 (diff)
downloadopie-912092425248f7fc5155b4c7c46b7d00ec2676bc.zip
opie-912092425248f7fc5155b4c7c46b7d00ec2676bc.tar.gz
opie-912092425248f7fc5155b4c7c46b7d00ec2676bc.tar.bz2
support for client commands (only /join implemented so far), crash bugfix, fixed 2 leaks, server browser now includes a channel list
Diffstat (limited to 'noncore/net') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/opieirc/ircchannel.cpp5
-rw-r--r--noncore/net/opieirc/ircchannel.h1
-rw-r--r--noncore/net/opieirc/ircchanneltab.cpp26
-rw-r--r--noncore/net/opieirc/ircconnection.cpp8
-rw-r--r--noncore/net/opieirc/ircmessage.cpp3
-rw-r--r--noncore/net/opieirc/ircmessageparser.cpp3
-rw-r--r--noncore/net/opieirc/ircoutput.cpp7
-rw-r--r--noncore/net/opieirc/ircoutput.h2
-rw-r--r--noncore/net/opieirc/ircserver.cpp12
-rw-r--r--noncore/net/opieirc/ircserver.h6
-rw-r--r--noncore/net/opieirc/ircservereditor.cpp19
-rw-r--r--noncore/net/opieirc/ircservereditor.h1
-rw-r--r--noncore/net/opieirc/ircserverlist.cpp2
-rw-r--r--noncore/net/opieirc/ircservertab.cpp70
-rw-r--r--noncore/net/opieirc/ircservertab.h3
-rw-r--r--noncore/net/opieirc/ircsession.cpp4
-rw-r--r--noncore/net/opieirc/irctab.h1
-rw-r--r--noncore/net/opieirc/ircversion.h2
18 files changed, 151 insertions, 24 deletions
diff --git a/noncore/net/opieirc/ircchannel.cpp b/noncore/net/opieirc/ircchannel.cpp
index 71ec03b..9814a26 100644
--- a/noncore/net/opieirc/ircchannel.cpp
+++ b/noncore/net/opieirc/ircchannel.cpp
@@ -1,20 +1,25 @@
1#include "ircchannel.h" 1#include "ircchannel.h"
2#include <stdio.h> 2#include <stdio.h>
3 3
4IRCChannel::IRCChannel(QString channelname) { 4IRCChannel::IRCChannel(QString channelname) {
5 m_hasPeople = FALSE; 5 m_hasPeople = FALSE;
6 m_channelname = channelname; 6 m_channelname = channelname;
7} 7}
8 8
9IRCChannel::~IRCChannel() {
10 /* We want this to get deleted */
11 m_people.setAutoDelete(TRUE);
12}
13
9QString IRCChannel::channelname() { 14QString IRCChannel::channelname() {
10 return m_channelname; 15 return m_channelname;
11} 16}
12 17
13bool IRCChannel::hasPeople() { 18bool IRCChannel::hasPeople() {
14 return m_hasPeople; 19 return m_hasPeople;
15} 20}
16 21
17void IRCChannel::setHasPeople(bool hasPeople) { 22void IRCChannel::setHasPeople(bool hasPeople) {
18 m_hasPeople = hasPeople; 23 m_hasPeople = hasPeople;
19} 24}
20 25
diff --git a/noncore/net/opieirc/ircchannel.h b/noncore/net/opieirc/ircchannel.h
index c800b99..e78f182 100644
--- a/noncore/net/opieirc/ircchannel.h
+++ b/noncore/net/opieirc/ircchannel.h
@@ -38,24 +38,25 @@ enum IRCChannelPersonFlag {
38typedef struct IRCChannelPerson { 38typedef struct IRCChannelPerson {
39 IRCPerson *person; 39 IRCPerson *person;
40 unsigned int flags; 40 unsigned int flags;
41}; 41};
42 42
43/* IRCChannel is the object-oriented representation 43/* IRCChannel is the object-oriented representation
44 of an IRC channel. It basically acts as a container 44 of an IRC channel. It basically acts as a container
45 for IRCChannelPersons */ 45 for IRCChannelPersons */
46class IRCChannel : public QObject { 46class IRCChannel : public QObject {
47 Q_OBJECT 47 Q_OBJECT
48public: 48public:
49 IRCChannel(QString channelname); 49 IRCChannel(QString channelname);
50 ~IRCChannel();
50 51
51 void addPerson(IRCChannelPerson *person); 52 void addPerson(IRCChannelPerson *person);
52 void removePerson(IRCChannelPerson *person); 53 void removePerson(IRCChannelPerson *person);
53 IRCChannelPerson *getPerson(QString nickname); 54 IRCChannelPerson *getPerson(QString nickname);
54 QListIterator<IRCChannelPerson> people(); 55 QListIterator<IRCChannelPerson> people();
55 56
56 /* hasPeople identifies whether the irc channel is 57 /* hasPeople identifies whether the irc channel is
57 done synchronizing with the current state - 58 done synchronizing with the current state -
58 this is only relevant when joining a channel */ 59 this is only relevant when joining a channel */
59 void setHasPeople(bool hasPeople); 60 void setHasPeople(bool hasPeople);
60 QString channelname(); 61 QString channelname();
61 bool hasPeople(); 62 bool hasPeople();
diff --git a/noncore/net/opieirc/ircchanneltab.cpp b/noncore/net/opieirc/ircchanneltab.cpp
index c96a365..754442a 100644
--- a/noncore/net/opieirc/ircchanneltab.cpp
+++ b/noncore/net/opieirc/ircchanneltab.cpp
@@ -29,49 +29,65 @@ IRCChannelTab::IRCChannelTab(IRCChannel *channel, IRCServerTab *parentTab, MainW
29 29
30void IRCChannelTab::appendText(QString text) { 30void IRCChannelTab::appendText(QString text) {
31 /* not using append because it creates layout problems */ 31 /* not using append because it creates layout problems */
32 m_textview->setText(m_textview->text() + text); 32 m_textview->setText(m_textview->text() + text);
33 m_textview->ensureVisible(0, m_textview->contentsHeight()); 33 m_textview->ensureVisible(0, m_textview->contentsHeight());
34} 34}
35 35
36IRCChannelTab::~IRCChannelTab() { 36IRCChannelTab::~IRCChannelTab() {
37 m_parentTab->removeChannelTab(this); 37 m_parentTab->removeChannelTab(this);
38} 38}
39 39
40void IRCChannelTab::processCommand() { 40void IRCChannelTab::processCommand() {
41 if (m_field->text().length()>0) { 41 QString text = m_field->text();
42 session()->sendMessage(m_channel, m_field->text()); 42 if (text.length()>0) {
43 appendText("&lt;<font color=\"#dd0000\">"+m_parentTab->server()->nick()+"</font>&gt; "+m_field->text()+"<br>"); 43 if (session()->isSessionActive()) {
44 m_field->clear(); 44 if (text.startsWith("/") && !text.startsWith("//")) {
45 /* Command mode */
46 m_parentTab->executeCommand(this, text);;
47 } else {
48 if (session()->isSessionActive()) {
49 session()->sendMessage(m_channel, m_field->text());
50 appendText("&lt;<font color=\"#dd0000\">"+m_parentTab->server()->nick()+"</font>&gt; "+m_field->text()+"<br>");
51 }
52 }
53 } else {
54 appendText("<font color=\"#ff0000\">"+tr("Disconnected")+"</font><br>");
55 }
45 } 56 }
57 m_field->clear();
46} 58}
47 59
48void IRCChannelTab::toggleList() { 60void IRCChannelTab::toggleList() {
49 if (m_listVisible) { 61 if (m_listVisible) {
50 m_list->setMaximumWidth(0); 62 m_list->setMaximumWidth(0);
51 m_listButton->setText("<"); 63 m_listButton->setText("<");
52 } else { 64 } else {
53 m_list->setMaximumWidth(LISTWIDTH); 65 m_list->setMaximumWidth(LISTWIDTH);
54 m_listButton->setText(">"); 66 m_listButton->setText(">");
55 } 67 }
56 m_listVisible = !m_listVisible; 68 m_listVisible = !m_listVisible;
57} 69}
58 70
59QString IRCChannelTab::title() { 71QString IRCChannelTab::title() {
60 return m_channel->channelname(); 72 return m_channel->channelname();
61} 73}
62 74
63IRCSession *IRCChannelTab::session() { 75IRCSession *IRCChannelTab::session() {
64 return m_parentTab->session(); 76 return m_parentTab->session();
65} 77}
66 78
67void IRCChannelTab::remove() { 79void IRCChannelTab::remove() {
68 session()->part(m_channel); 80 if (session()->isSessionActive()) {
81 session()->part(m_channel);
82 } else {
83 m_mainWindow->killTab(this);
84 }
69} 85}
70 86
71IRCChannel *IRCChannelTab::channel() { 87IRCChannel *IRCChannelTab::channel() {
72 return m_channel; 88 return m_channel;
73} 89}
74 90
75IRCChannelList *IRCChannelTab::list() { 91IRCChannelList *IRCChannelTab::list() {
76 return m_list; 92 return m_list;
77} 93}
diff --git a/noncore/net/opieirc/ircconnection.cpp b/noncore/net/opieirc/ircconnection.cpp
index 02c4897..5eb0cf2 100644
--- a/noncore/net/opieirc/ircconnection.cpp
+++ b/noncore/net/opieirc/ircconnection.cpp
@@ -51,24 +51,32 @@ void IRCConnection::login() {
51 } 51 }
52 loginString += "NICK " + m_server->nick() + "\r\n" + 52 loginString += "NICK " + m_server->nick() + "\r\n" +
53 "USER " + m_server->username() + " " + hostname + 53 "USER " + m_server->username() + " " + hostname +
54 " " + m_server->hostname() + " :" + m_server->realname() + "\r\n"; 54 " " + m_server->hostname() + " :" + m_server->realname() + "\r\n";
55 sendLine(loginString); 55 sendLine(loginString);
56} 56}
57 57
58/* Called when data arrives on the socket */ 58/* Called when data arrives on the socket */
59void IRCConnection::dataReady() { 59void IRCConnection::dataReady() {
60 while(m_socket->canReadLine()) { 60 while(m_socket->canReadLine()) {
61 IRCMessage message(m_socket->readLine()); 61 IRCMessage message(m_socket->readLine());
62 if (!m_loggedIn && message.isNumerical() && message.commandNumber() == 1) { 62 if (!m_loggedIn && message.isNumerical() && message.commandNumber() == 1) {
63 /* Now autojoin all channels specified inside the server profile */
64 QStringList channels = QStringList::split(QChar(','), m_server->channels());
65 for (QStringList::Iterator it = channels.begin(); it != channels.end(); ++it) {
66 QString channelName = (*it).stripWhiteSpace();
67 if (channelName.startsWith("#")) {
68 sendLine("JOIN "+ channelName);
69 }
70 }
63 m_loggedIn = TRUE; 71 m_loggedIn = TRUE;
64 emit outputReady(IRCOutput(OUTPUT_CLIENTMESSAGE, tr("Successfully logged in."))); 72 emit outputReady(IRCOutput(OUTPUT_CLIENTMESSAGE, tr("Successfully logged in.")));
65 } 73 }
66 emit messageArrived(&message); 74 emit messageArrived(&message);
67 } 75 }
68} 76}
69 77
70/* Called if any type of socket error occurs */ 78/* Called if any type of socket error occurs */
71void IRCConnection::error(int num) { 79void IRCConnection::error(int num) {
72 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Socket error : ") + strerror(num))); 80 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Socket error : ") + strerror(num)));
73} 81}
74 82
diff --git a/noncore/net/opieirc/ircmessage.cpp b/noncore/net/opieirc/ircmessage.cpp
index 74e9c6f..9c2869c 100644
--- a/noncore/net/opieirc/ircmessage.cpp
+++ b/noncore/net/opieirc/ircmessage.cpp
@@ -15,36 +15,39 @@ IRCMessage::IRCMessage(QString line) {
15 15
16 stream >> temp; 16 stream >> temp;
17 if (temp.startsWith(":")) { 17 if (temp.startsWith(":")) {
18 /* extract the prefix */ 18 /* extract the prefix */
19 m_prefix = temp.right(temp.length()-1); 19 m_prefix = temp.right(temp.length()-1);
20 stream >> temp; 20 stream >> temp;
21 m_command = temp.upper(); 21 m_command = temp.upper();
22 m_allParameters = line.right(line.length() - m_prefix.length() - m_command.length() - 3); 22 m_allParameters = line.right(line.length() - m_prefix.length() - m_command.length() - 3);
23 } else { 23 } else {
24 m_command = temp.upper(); 24 m_command = temp.upper();
25 m_allParameters = line.right(line.length() - m_command.length() - 1); 25 m_allParameters = line.right(line.length() - m_command.length() - 1);
26 } 26 }
27
27 /* Create a list of all parameters */ 28 /* Create a list of all parameters */
28 while(!(stream.atEnd())) { 29 while(!(stream.atEnd())) {
29 stream >> temp; 30 stream >> temp;
30 if (temp.startsWith(":")) { 31 if (temp.startsWith(":")) {
31 /* last parameter */ 32 /* last parameter */
32 m_trailing = line.right(line.length() - line.find(QChar(':'), 1) - 1); 33 m_trailing = line.right(line.length() - line.find(QChar(':'), 1) - 1);
33 m_parameters << m_trailing; 34 m_parameters << m_trailing;
34 break; 35 break;
35 } else { 36 } else {
36 m_parameters << temp; 37 m_parameters << temp;
37 } 38 }
38 } 39 }
40
41
39 m_commandNumber = m_command.toInt(&m_isNumerical); 42 m_commandNumber = m_command.toInt(&m_isNumerical);
40 /* Is this a CTCP command */ 43 /* Is this a CTCP command */
41 if ((m_command == "PRIVMSG" || m_command == "NOTICE") && m_trailing.length()>0 && m_trailing.left(1) == QChar(1)) { 44 if ((m_command == "PRIVMSG" || m_command == "NOTICE") && m_trailing.length()>0 && m_trailing.left(1) == QChar(1)) {
42 m_ctcp = TRUE; 45 m_ctcp = TRUE;
43 /* Strip CTCP \001 characters */ 46 /* Strip CTCP \001 characters */
44 m_allParameters = m_allParameters.replace(QRegExp(QChar(1)), ""); 47 m_allParameters = m_allParameters.replace(QRegExp(QChar(1)), "");
45 QTextIStream ctcpStream(&m_allParameters); 48 QTextIStream ctcpStream(&m_allParameters);
46 if (m_command == "PRIVMSG") 49 if (m_command == "PRIVMSG")
47 ctcpStream >> m_ctcpDestination; 50 ctcpStream >> m_ctcpDestination;
48 ctcpStream >> temp; 51 ctcpStream >> temp;
49 m_ctcpCommand = temp.upper().right(temp.length()-1); 52 m_ctcpCommand = temp.upper().right(temp.length()-1);
50 m_parameters.clear(); 53 m_parameters.clear();
diff --git a/noncore/net/opieirc/ircmessageparser.cpp b/noncore/net/opieirc/ircmessageparser.cpp
index a2be5a4..4038673 100644
--- a/noncore/net/opieirc/ircmessageparser.cpp
+++ b/noncore/net/opieirc/ircmessageparser.cpp
@@ -17,24 +17,25 @@ IRCLiteralMessageParserStruct IRCMessageParser::literalParserProcTable[] = {
17 { "MODE", FUNC(parseLiteralMode) }, 17 { "MODE", FUNC(parseLiteralMode) },
18 { "KICK", FUNC(parseLiteralKick) }, 18 { "KICK", FUNC(parseLiteralKick) },
19 { 0 , 0 } 19 { 0 , 0 }
20}; 20};
21 21
22/* Lookup table for literal commands */ 22/* Lookup table for literal commands */
23IRCCTCPMessageParserStruct IRCMessageParser::ctcpParserProcTable[] = { 23IRCCTCPMessageParserStruct IRCMessageParser::ctcpParserProcTable[] = {
24 { "PING", FUNC(parseCTCPPing) }, 24 { "PING", FUNC(parseCTCPPing) },
25 { "VERSION", FUNC(parseCTCPVersion) }, 25 { "VERSION", FUNC(parseCTCPVersion) },
26 { "ACTION", FUNC(parseCTCPAction) }, 26 { "ACTION", FUNC(parseCTCPAction) },
27 { 0 , 0 } 27 { 0 , 0 }
28}; 28};
29
29/* Lookup table for numerical commands */ 30/* Lookup table for numerical commands */
30IRCNumericalMessageParserStruct IRCMessageParser::numericalParserProcTable[] = { 31IRCNumericalMessageParserStruct IRCMessageParser::numericalParserProcTable[] = {
31 { 1, FUNC(parseNumerical001) }, // RPL_WELCOME 32 { 1, FUNC(parseNumerical001) }, // RPL_WELCOME
32 { 2, FUNC(parseNumerical002) }, // RPL_YOURHOST 33 { 2, FUNC(parseNumerical002) }, // RPL_YOURHOST
33 { 3, FUNC(parseNumerical003) }, // RPL_CREATED 34 { 3, FUNC(parseNumerical003) }, // RPL_CREATED
34 { 4, FUNC(parseNumerical004) }, // RPL_MYINFO 35 { 4, FUNC(parseNumerical004) }, // RPL_MYINFO
35 { 5, FUNC(parseNumerical005) }, // RPL_BOUNCE, RPL_PROTOCTL 36 { 5, FUNC(parseNumerical005) }, // RPL_BOUNCE, RPL_PROTOCTL
36 { 251, FUNC(parseNumericalStats) }, // RPL_LUSERCLIENT 37 { 251, FUNC(parseNumericalStats) }, // RPL_LUSERCLIENT
37 { 254, FUNC(nullFunc)}, // RPL_LUSERCHANNELS 38 { 254, FUNC(nullFunc)}, // RPL_LUSERCHANNELS
38 { 255, FUNC(parseNumericalStats) }, // RPL_LUSERNAME 39 { 255, FUNC(parseNumericalStats) }, // RPL_LUSERNAME
39 { 353, FUNC(parseNumericalNames) }, // RPL_NAMREPLY 40 { 353, FUNC(parseNumericalNames) }, // RPL_NAMREPLY
40 { 366, FUNC(parseNumericalEndOfNames) }, // RPL_ENDOFNAMES 41 { 366, FUNC(parseNumericalEndOfNames) }, // RPL_ENDOFNAMES
@@ -219,29 +220,31 @@ void IRCMessageParser::parseLiteralNick(IRCMessage *message) {
219} 220}
220 221
221void IRCMessageParser::parseLiteralQuit(IRCMessage *message) { 222void IRCMessageParser::parseLiteralQuit(IRCMessage *message) {
222 IRCPerson mask(message->prefix()); 223 IRCPerson mask(message->prefix());
223 IRCPerson *person = m_session->getPerson(mask.nick()); 224 IRCPerson *person = m_session->getPerson(mask.nick());
224 if (person) { 225 if (person) {
225 QList<IRCChannel> channels; 226 QList<IRCChannel> channels;
226 m_session->getChannelsByPerson(person, channels); 227 m_session->getChannelsByPerson(person, channels);
227 QListIterator<IRCChannel> it(channels); 228 QListIterator<IRCChannel> it(channels);
228 for (;it.current(); ++it) { 229 for (;it.current(); ++it) {
229 IRCChannelPerson *chanperson = it.current()->getPerson(mask.nick()); 230 IRCChannelPerson *chanperson = it.current()->getPerson(mask.nick());
230 it.current()->removePerson(chanperson); 231 it.current()->removePerson(chanperson);
232 delete chanperson;
231 } 233 }
232 m_session->removePerson(person); 234 m_session->removePerson(person);
233 IRCOutput output(OUTPUT_QUIT, mask.nick() + tr(" has quit ") + "(" + message->param(0) + ")"); 235 IRCOutput output(OUTPUT_QUIT, mask.nick() + tr(" has quit ") + "(" + message->param(0) + ")");
234 output.addParam(person); 236 output.addParam(person);
235 emit outputReady(output); 237 emit outputReady(output);
238 delete person;
236 } else { 239 } else {
237 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Unknown person quit - desynchronized?"))); 240 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Unknown person quit - desynchronized?")));
238 } 241 }
239} 242}
240 243
241void IRCMessageParser::parseLiteralError(IRCMessage *message) { 244void IRCMessageParser::parseLiteralError(IRCMessage *message) {
242 emit outputReady(IRCOutput(OUTPUT_ERROR, message->allParameters())); 245 emit outputReady(IRCOutput(OUTPUT_ERROR, message->allParameters()));
243} 246}
244 247
245void IRCMessageParser::parseCTCPPing(IRCMessage *message) { 248void IRCMessageParser::parseCTCPPing(IRCMessage *message) {
246 IRCPerson mask(message->prefix()); 249 IRCPerson mask(message->prefix());
247 m_session->m_connection->sendCTCP(mask.nick(), "PING " + message->allParameters()); 250 m_session->m_connection->sendCTCP(mask.nick(), "PING " + message->allParameters());
diff --git a/noncore/net/opieirc/ircoutput.cpp b/noncore/net/opieirc/ircoutput.cpp
index aa57d86..878bc9b 100644
--- a/noncore/net/opieirc/ircoutput.cpp
+++ b/noncore/net/opieirc/ircoutput.cpp
@@ -4,19 +4,26 @@ IRCOutput::IRCOutput(IRCOutputType type, QString message) {
4 m_type = type; 4 m_type = type;
5 m_message = message; 5 m_message = message;
6} 6}
7 7
8IRCOutputType IRCOutput::type() { 8IRCOutputType IRCOutput::type() {
9 return m_type; 9 return m_type;
10} 10}
11 11
12QString IRCOutput::message() { 12QString IRCOutput::message() {
13 return m_message; 13 return m_message;
14} 14}
15 15
16QString IRCOutput::htmlMessage() {
17 QString htmlMessage =m_message.replace(QRegExp("&"), "&amp;");
18 htmlMessage = htmlMessage.replace(QRegExp(">"), "&gt;");
19 htmlMessage = htmlMessage.replace(QRegExp("<"), "&lt;");
20 return htmlMessage;
21}
22
16void IRCOutput::addParam(void *data) { 23void IRCOutput::addParam(void *data) {
17 m_parameters.append(data); 24 m_parameters.append(data);
18} 25}
19 26
20void *IRCOutput::getParam(int index) { 27void *IRCOutput::getParam(int index) {
21 return m_parameters.at(index); 28 return m_parameters.at(index);
22} 29}
diff --git a/noncore/net/opieirc/ircoutput.h b/noncore/net/opieirc/ircoutput.h
index 4b757ed..72361d4 100644
--- a/noncore/net/opieirc/ircoutput.h
+++ b/noncore/net/opieirc/ircoutput.h
@@ -51,20 +51,22 @@ enum IRCOutputType {
51 IRC parser to inform the GUI of changes. This could for example be a 51 IRC parser to inform the GUI of changes. This could for example be a
52 channel message or a nickname change */ 52 channel message or a nickname change */
53 53
54class IRCOutput { 54class IRCOutput {
55public: 55public:
56 IRCOutput(IRCOutputType type, QString message); 56 IRCOutput(IRCOutputType type, QString message);
57 /* Used to add a parameter to this IRCOutput. Parameters are dependent 57 /* Used to add a parameter to this IRCOutput. Parameters are dependent
58 on which IRCOutputType we are using (see above) */ 58 on which IRCOutputType we are using (see above) */
59 void addParam(void *data); 59 void addParam(void *data);
60 60
61 IRCOutputType type(); 61 IRCOutputType type();
62 QString message(); 62 QString message();
63 /* Return the message with all HTML code escaped (for example &lt; instead of '<') */
64 QString htmlMessage();
63 void *getParam(int index); 65 void *getParam(int index);
64protected: 66protected:
65 IRCOutputType m_type; 67 IRCOutputType m_type;
66 QString m_message; 68 QString m_message;
67 QList<void> m_parameters; 69 QList<void> m_parameters;
68}; 70};
69 71
70#endif 72#endif
diff --git a/noncore/net/opieirc/ircserver.cpp b/noncore/net/opieirc/ircserver.cpp
index e16e2b2..e27e41d 100644
--- a/noncore/net/opieirc/ircserver.cpp
+++ b/noncore/net/opieirc/ircserver.cpp
@@ -1,18 +1,20 @@
1#include "ircserver.h" 1#include "ircserver.h"
2 2
3IRCServer::IRCServer() { 3IRCServer::IRCServer() {
4 m_port = 6667; 4 m_port = 6667;
5} 5}
6 6
7/* Setter implementations */
8
7void IRCServer::setHostname(QString hostname) { 9void IRCServer::setHostname(QString hostname) {
8 m_hostname = hostname; 10 m_hostname = hostname;
9} 11}
10 12
11void IRCServer::setName(QString name) { 13void IRCServer::setName(QString name) {
12 m_name = name; 14 m_name = name;
13} 15}
14 16
15void IRCServer::setPort(int port) { 17void IRCServer::setPort(int port) {
16 m_port = port; 18 m_port = port;
17} 19}
18 20
@@ -23,24 +25,30 @@ void IRCServer::setUsername(QString username) {
23void IRCServer::setPassword(QString password) { 25void IRCServer::setPassword(QString password) {
24 m_password = password; 26 m_password = password;
25} 27}
26 28
27void IRCServer::setNick(QString nick) { 29void IRCServer::setNick(QString nick) {
28 m_nick = nick; 30 m_nick = nick;
29} 31}
30 32
31void IRCServer::setRealname(QString realname) { 33void IRCServer::setRealname(QString realname) {
32 m_realname = realname; 34 m_realname = realname;
33} 35}
34 36
37void IRCServer::setChannels(QString channels) {
38 m_channels = channels;
39}
40
41/* Getter implementations */
42
35QString IRCServer::hostname() { 43QString IRCServer::hostname() {
36 return m_hostname; 44 return m_hostname;
37} 45}
38 46
39QString IRCServer::name() { 47QString IRCServer::name() {
40 return m_name; 48 return m_name;
41} 49}
42 50
43unsigned short int IRCServer::port() { 51unsigned short int IRCServer::port() {
44 return m_port; 52 return m_port;
45} 53}
46 54
@@ -51,12 +59,16 @@ QString IRCServer::username() {
51QString IRCServer::password() { 59QString IRCServer::password() {
52 return m_password; 60 return m_password;
53} 61}
54 62
55QString IRCServer::nick() { 63QString IRCServer::nick() {
56 return m_nick; 64 return m_nick;
57} 65}
58 66
59QString IRCServer::realname() { 67QString IRCServer::realname() {
60 return m_realname; 68 return m_realname;
61} 69}
62 70
71QString IRCServer::channels() {
72 return m_channels;
73}
74
diff --git a/noncore/net/opieirc/ircserver.h b/noncore/net/opieirc/ircserver.h
index f56f231..0bc7d4c 100644
--- a/noncore/net/opieirc/ircserver.h
+++ b/noncore/net/opieirc/ircserver.h
@@ -19,40 +19,46 @@
19*/ 19*/
20 20
21#ifndef __IRCSERVER_H 21#ifndef __IRCSERVER_H
22#define __IRCSERVER_H 22#define __IRCSERVER_H
23 23
24#include <qstring.h> 24#include <qstring.h>
25 25
26/* IRCServer stores all information required to 26/* IRCServer stores all information required to
27 establish a connection to a server. */ 27 establish a connection to a server. */
28 28
29class IRCServer { 29class IRCServer {
30public: 30public:
31 /* Initialize to the default values */
31 IRCServer(); 32 IRCServer();
32 33
34 /* Setters */
33 void setName(QString name); 35 void setName(QString name);
34 void setHostname(QString hostname); 36 void setHostname(QString hostname);
35 void setPort(int port); 37 void setPort(int port);
36 void setUsername(QString username); 38 void setUsername(QString username);
37 void setPassword(QString password); 39 void setPassword(QString password);
38 void setNick(QString nick); 40 void setNick(QString nick);
39 void setRealname(QString realname); 41 void setRealname(QString realname);
42 void setChannels(QString channels);
40 43
44 /* Getters */
41 QString hostname(); 45 QString hostname();
42 QString name(); 46 QString name();
43 unsigned short int port(); 47 unsigned short int port();
44 QString username(); 48 QString username();
45 QString password(); 49 QString password();
46 QString nick(); 50 QString nick();
47 QString realname(); 51 QString realname();
52 QString channels();
48protected: 53protected:
49 QString m_hostname; 54 QString m_hostname;
50 QString m_name; 55 QString m_name;
51 unsigned short int m_port; 56 unsigned short int m_port;
52 QString m_username; 57 QString m_username;
53 QString m_password; 58 QString m_password;
54 QString m_nick; 59 QString m_nick;
55 QString m_realname; 60 QString m_realname;
61 QString m_channels;
56}; 62};
57 63
58#endif /* __IRCSERVER_H */ 64#endif /* __IRCSERVER_H */
diff --git a/noncore/net/opieirc/ircservereditor.cpp b/noncore/net/opieirc/ircservereditor.cpp
index 798081f..c3a444d 100644
--- a/noncore/net/opieirc/ircservereditor.cpp
+++ b/noncore/net/opieirc/ircservereditor.cpp
@@ -1,61 +1,76 @@
1#include <qmessagebox.h> 1#include <qmessagebox.h>
2#include <qlayout.h> 2#include <qlayout.h>
3#include <qlabel.h> 3#include <qlabel.h>
4#include "ircservereditor.h" 4#include "ircservereditor.h"
5 5
6IRCServerEditor::IRCServerEditor(IRCServer server, QWidget* parent, const char* name, bool modal = FALSE, WFlags f) : QDialog(parent, name, modal, f) { 6IRCServerEditor::IRCServerEditor(IRCServer server, QWidget* parent, const char* name, bool modal = FALSE, WFlags f) : QDialog(parent, name, modal, f) {
7 QGridLayout *layout = new QGridLayout(this, 6, 2, 5, 5); 7 QGridLayout *layout = new QGridLayout(this, 7, 2, 5, 5);
8 QLabel *label = new QLabel(tr("Profile name :"), this); 8 QLabel *label = new QLabel(tr("Profile name :"), this);
9 m_name = new QLineEdit(server.name(), this); 9 m_name = new QLineEdit(server.name(), this);
10 layout->addWidget(label, 0, 0); 10 layout->addWidget(label, 0, 0);
11 layout->addWidget(m_name, 0, 1); 11 layout->addWidget(m_name, 0, 1);
12 label = new QLabel(tr("Hostname :"), this); 12 label = new QLabel(tr("Hostname :"), this);
13 m_hostname = new QLineEdit(server.hostname(), this); 13 m_hostname = new QLineEdit(server.hostname(), this);
14 layout->addWidget(label, 1, 0); 14 layout->addWidget(label, 1, 0);
15 layout->addWidget(m_hostname, 1, 1); 15 layout->addWidget(m_hostname, 1, 1);
16 label = new QLabel(tr("Port :"), this); 16 label = new QLabel(tr("Port :"), this);
17 m_port = new QLineEdit(QString::number(server.port()), this); 17 m_port = new QLineEdit(QString::number(server.port()), this);
18 layout->addWidget(label, 2, 0); 18 layout->addWidget(label, 2, 0);
19 layout->addWidget(m_port, 2, 1); 19 layout->addWidget(m_port, 2, 1);
20 label = new QLabel(tr("Nickname :"), this); 20 label = new QLabel(tr("Nickname :"), this);
21 m_nickname = new QLineEdit(server.nick(), this); 21 m_nickname = new QLineEdit(server.nick(), this);
22 layout->addWidget(label, 3, 0); 22 layout->addWidget(label, 3, 0);
23 layout->addWidget(m_nickname, 3, 1); 23 layout->addWidget(m_nickname, 3, 1);
24 label = new QLabel(tr("Realname :"), this); 24 label = new QLabel(tr("Realname :"), this);
25 m_realname = new QLineEdit(server.realname(), this); 25 m_realname = new QLineEdit(server.realname(), this);
26 layout->addWidget(label, 4, 0); 26 layout->addWidget(label, 4, 0);
27 layout->addWidget(m_realname, 4, 1); 27 layout->addWidget(m_realname, 4, 1);
28 label = new QLabel(tr("Password :"), this); 28 label = new QLabel(tr("Password :"), this);
29 m_password = new QLineEdit(server.password(), this); 29 m_password = new QLineEdit(server.password(), this);
30 layout->addWidget(label, 5, 0); 30 layout->addWidget(label, 5, 0);
31 layout->addWidget(m_password, 5, 1); 31 layout->addWidget(m_password, 5, 1);
32 label = new QLabel(tr("Channels :"), this);
33 m_channels = new QLineEdit(server.channels(), this);
34 layout->addWidget(label, 6, 0);
35 layout->addWidget(m_channels, 6, 1);
32 showMaximized(); 36 showMaximized();
33} 37}
34 38
35 39
36void IRCServerEditor::accept() { 40void IRCServerEditor::accept() {
37 if (m_name->text().length()==0) 41 if (m_name->text().length()==0)
38 QMessageBox::critical(this, tr("Error"), tr("Profile name required")); 42 QMessageBox::critical(this, tr("Error"), tr("Profile name required"));
39 else if (m_hostname->text().length()==0) 43 else if (m_hostname->text().length()==0)
40 QMessageBox::critical(this, tr("Error"), tr("Host name required")); 44 QMessageBox::critical(this, tr("Error"), tr("Host name required"));
41 else if (m_port->text().toInt()<=0) 45 else if (m_port->text().toInt()<=0)
42 QMessageBox::critical(this, tr("Error"), tr("Port required")); 46 QMessageBox::critical(this, tr("Error"), tr("Port required"));
43 else if (m_nickname->text().length()==0) 47 else if (m_nickname->text().length()==0)
44 QMessageBox::critical(this, tr("Error"), tr("Nickname required")); 48 QMessageBox::critical(this, tr("Error"), tr("Nickname required"));
45 else if (m_realname->text().length()==0) 49 else if (m_realname->text().length()==0)
46 QMessageBox::critical(this, tr("Error"), tr("Realname required")); 50 QMessageBox::critical(this, tr("Error"), tr("Realname required"));
47 else 51 else {
52 /* Now verify whether the channel list has a valid format */
53 QStringList channels = QStringList::split(QChar(','), m_channels->text());
54 for (QStringList::Iterator it = channels.begin(); it != channels.end(); ++it) {
55 QString channelName = (*it).stripWhiteSpace();
56 if (!channelName.startsWith("#")) {
57 QMessageBox::critical(this, tr("Error"), tr("The channel list needs to contain a\ncomma separated list of channel\n names which start with '#'"));
58 return;
59 }
60 }
48 QDialog::accept(); 61 QDialog::accept();
62 }
49} 63}
50 64
51IRCServer IRCServerEditor::getServer() { 65IRCServer IRCServerEditor::getServer() {
52 IRCServer server; 66 IRCServer server;
53 server.setName(m_name->text()); 67 server.setName(m_name->text());
54 server.setHostname(m_hostname->text()); 68 server.setHostname(m_hostname->text());
55 server.setPort(m_port->text().toInt()); 69 server.setPort(m_port->text().toInt());
56 server.setNick(m_nickname->text()); 70 server.setNick(m_nickname->text());
57 server.setRealname(m_realname->text()); 71 server.setRealname(m_realname->text());
58 server.setUsername(m_nickname->text()); 72 server.setUsername(m_nickname->text());
59 server.setPassword(m_password->text()); 73 server.setPassword(m_password->text());
74 server.setChannels(m_channels->text());
60 return server; 75 return server;
61} 76}
diff --git a/noncore/net/opieirc/ircservereditor.h b/noncore/net/opieirc/ircservereditor.h
index 20c94f7..22311f7 100644
--- a/noncore/net/opieirc/ircservereditor.h
+++ b/noncore/net/opieirc/ircservereditor.h
@@ -30,15 +30,16 @@ class IRCServerEditor : public QDialog {
30public: 30public:
31 IRCServerEditor(IRCServer server, QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags f = 0); 31 IRCServerEditor(IRCServer server, QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags f = 0);
32 IRCServer getServer(); 32 IRCServer getServer();
33protected slots: 33protected slots:
34 void accept(); 34 void accept();
35protected: 35protected:
36 QLineEdit *m_name; 36 QLineEdit *m_name;
37 QLineEdit *m_hostname; 37 QLineEdit *m_hostname;
38 QLineEdit *m_port; 38 QLineEdit *m_port;
39 QLineEdit *m_nickname; 39 QLineEdit *m_nickname;
40 QLineEdit *m_password; 40 QLineEdit *m_password;
41 QLineEdit *m_realname; 41 QLineEdit *m_realname;
42 QLineEdit *m_channels;
42}; 43};
43 44
44#endif /* __IRCSERVEREDITOR_H */ 45#endif /* __IRCSERVEREDITOR_H */
diff --git a/noncore/net/opieirc/ircserverlist.cpp b/noncore/net/opieirc/ircserverlist.cpp
index b2d746a..e664ba1 100644
--- a/noncore/net/opieirc/ircserverlist.cpp
+++ b/noncore/net/opieirc/ircserverlist.cpp
@@ -50,24 +50,25 @@ IRCServerList::IRCServerList(QWidget* parent, const char *name, bool modal, WFla
50 m_config->setGroup("OpieIRC"); 50 m_config->setGroup("OpieIRC");
51 QString name = m_config->readEntry("Server"+QString::number(i)); 51 QString name = m_config->readEntry("Server"+QString::number(i));
52 if (name.length() > 0) { 52 if (name.length() > 0) {
53 IRCServer server; 53 IRCServer server;
54 m_config->setGroup(name); 54 m_config->setGroup(name);
55 server.setName(name); 55 server.setName(name);
56 server.setHostname(m_config->readEntry("Hostname")); 56 server.setHostname(m_config->readEntry("Hostname"));
57 server.setPort(m_config->readNumEntry("Port")); 57 server.setPort(m_config->readNumEntry("Port"));
58 server.setUsername(m_config->readEntry("Username")); 58 server.setUsername(m_config->readEntry("Username"));
59 server.setPassword(m_config->readEntry("Password")); 59 server.setPassword(m_config->readEntry("Password"));
60 server.setNick(m_config->readEntry("Nick")); 60 server.setNick(m_config->readEntry("Nick"));
61 server.setRealname(m_config->readEntry("Realname")); 61 server.setRealname(m_config->readEntry("Realname"));
62 server.setChannels(m_config->readEntry("Channels"));
62 m_list->insertItem(new IRCListBoxServer(server)); 63 m_list->insertItem(new IRCListBoxServer(server));
63 } 64 }
64 } 65 }
65 } 66 }
66 67
67 showMaximized(); 68 showMaximized();
68} 69}
69 70
70void IRCServerList::addServer() { 71void IRCServerList::addServer() {
71 IRCServer server; 72 IRCServer server;
72 IRCServerEditor editor(server, this, "ServerEditor", TRUE); 73 IRCServerEditor editor(server, this, "ServerEditor", TRUE);
73 if (editor.exec() == QDialog::Accepted) { 74 if (editor.exec() == QDialog::Accepted) {
@@ -105,24 +106,25 @@ int IRCServerList::exec() {
105 m_config->writeEntry("ServerCount", QString::number(m_list->count())); 106 m_config->writeEntry("ServerCount", QString::number(m_list->count()));
106 for (unsigned int i=0; i<m_list->count(); i++) { 107 for (unsigned int i=0; i<m_list->count(); i++) {
107 IRCServer server = ((IRCListBoxServer *)m_list->item(i))->server(); 108 IRCServer server = ((IRCListBoxServer *)m_list->item(i))->server();
108 m_config->setGroup("OpieIRC"); 109 m_config->setGroup("OpieIRC");
109 m_config->writeEntry("Server"+QString::number(i), server.name()); 110 m_config->writeEntry("Server"+QString::number(i), server.name());
110 m_config->setGroup(server.name()); 111 m_config->setGroup(server.name());
111 m_config->writeEntry("Hostname", server.hostname()); 112 m_config->writeEntry("Hostname", server.hostname());
112 m_config->writeEntry("Port", QString::number(server.port())); 113 m_config->writeEntry("Port", QString::number(server.port()));
113 m_config->writeEntry("Username", server.username()); 114 m_config->writeEntry("Username", server.username());
114 m_config->writeEntry("Password", server.password()); 115 m_config->writeEntry("Password", server.password());
115 m_config->writeEntry("Nick", server.nick()); 116 m_config->writeEntry("Nick", server.nick());
116 m_config->writeEntry("Realname", server.realname()); 117 m_config->writeEntry("Realname", server.realname());
118 m_config->writeEntry("Channels", server.channels());
117 } 119 }
118 return returncode; 120 return returncode;
119} 121}
120 122
121bool IRCServerList::hasServer() { 123bool IRCServerList::hasServer() {
122 return (m_list->currentItem() != -1); 124 return (m_list->currentItem() != -1);
123} 125}
124 126
125IRCServer IRCServerList::server() { 127IRCServer IRCServerList::server() {
126 return ((IRCListBoxServer *)m_list->item(m_list->currentItem()))->server(); 128 return ((IRCListBoxServer *)m_list->item(m_list->currentItem()))->server();
127} 129}
128 130
diff --git a/noncore/net/opieirc/ircservertab.cpp b/noncore/net/opieirc/ircservertab.cpp
index 724f4bd..2ad56a8 100644
--- a/noncore/net/opieirc/ircservertab.cpp
+++ b/noncore/net/opieirc/ircservertab.cpp
@@ -1,13 +1,14 @@
1#include <stdio.h> 1#include <stdio.h>
2#include <qtextstream.h>
2#include "ircservertab.h" 3#include "ircservertab.h"
3 4
4IRCServerTab::IRCServerTab(IRCServer server, MainWindow *mainWindow, QWidget *parent, const char *name, WFlags f) : IRCTab(parent, name, f) { 5IRCServerTab::IRCServerTab(IRCServer server, MainWindow *mainWindow, QWidget *parent, const char *name, WFlags f) : IRCTab(parent, name, f) {
5 m_server = server; 6 m_server = server;
6 m_session = new IRCSession(&m_server); 7 m_session = new IRCSession(&m_server);
7 m_mainWindow = mainWindow; 8 m_mainWindow = mainWindow;
8 m_close = FALSE; 9 m_close = FALSE;
9 m_description->setText(tr("Connection to")+" <b>" + server.hostname() + ":" + QString::number(server.port()) + "</b>"); 10 m_description->setText(tr("Connection to")+" <b>" + server.hostname() + ":" + QString::number(server.port()) + "</b>");
10 m_textview = new QTextView(this); 11 m_textview = new QTextView(this);
11 m_textview->setHScrollBarMode(QScrollView::AlwaysOff); 12 m_textview->setHScrollBarMode(QScrollView::AlwaysOff);
12 m_textview->setVScrollBarMode(QScrollView::AlwaysOn); 13 m_textview->setVScrollBarMode(QScrollView::AlwaysOn);
13 m_layout->add(m_textview); 14 m_layout->add(m_textview);
@@ -16,131 +17,168 @@ IRCServerTab::IRCServerTab(IRCServer server, MainWindow *mainWindow, QWidget *pa
16 connect(m_field, SIGNAL(returnPressed()), this, SLOT(processCommand())); 17 connect(m_field, SIGNAL(returnPressed()), this, SLOT(processCommand()));
17 m_field->setFocus(); 18 m_field->setFocus();
18 connect(m_session, SIGNAL(outputReady(IRCOutput)), this, SLOT(display(IRCOutput))); 19 connect(m_session, SIGNAL(outputReady(IRCOutput)), this, SLOT(display(IRCOutput)));
19} 20}
20 21
21void IRCServerTab::appendText(QString text) { 22void IRCServerTab::appendText(QString text) {
22 /* not using append because it creates layout problems */ 23 /* not using append because it creates layout problems */
23 m_textview->setText(m_textview->text() + text); 24 m_textview->setText(m_textview->text() + text);
24 m_textview->ensureVisible(0, m_textview->contentsHeight()); 25 m_textview->ensureVisible(0, m_textview->contentsHeight());
25} 26}
26 27
27IRCServerTab::~IRCServerTab() { 28IRCServerTab::~IRCServerTab() {
28 QListIterator<IRCChannelTab> it(m_channelTabs);
29 for (; it.current(); ++it) {
30 m_mainWindow->killTab(it.current());
31 }
32 delete m_session; 29 delete m_session;
33} 30}
34 31
35void IRCServerTab::removeChannelTab(IRCChannelTab *tab) { 32void IRCServerTab::removeChannelTab(IRCChannelTab *tab) {
36 m_channelTabs.remove(tab); 33 m_channelTabs.remove(tab);
37} 34}
38 35
39QString IRCServerTab::title() { 36QString IRCServerTab::title() {
40 return "Server"; 37 return "Server";
41} 38}
42 39
43IRCSession *IRCServerTab::session() { 40IRCSession *IRCServerTab::session() {
44 return m_session; 41 return m_session;
45} 42}
46 43
47IRCServer *IRCServerTab::server() { 44IRCServer *IRCServerTab::server() {
48 return &m_server; 45 return &m_server;
49} 46}
50 47
48void IRCServerTab::executeCommand(IRCTab *tab, QString line) {
49 QTextIStream stream(&line);
50 QString command;
51 stream >> command;
52 command = command.upper().right(command.length()-1);
53
54 if (command == "JOIN") {
55 QString channel;
56 stream >> channel;
57 if (channel.length() > 0 && channel.startsWith("#")) {
58 m_session->join(channel);
59 } else {
60 tab->appendText("<font color=\"#ff0000\">Unknown channel format!</font><br>");
61 }
62 } else {
63 tab->appendText("<font color=\"#ff0000\">Unknown command</font><br>");
64 }
65}
66
51void IRCServerTab::processCommand() { 67void IRCServerTab::processCommand() {
68 QString text = m_field->text();
69 if (text.startsWith("/") && !text.startsWith("//")) {
70 /* Command mode */
71 executeCommand(this, text);
72 }
52 m_field->clear(); 73 m_field->clear();
53 appendText("<font color=\"#ff0000\">Not supported yet</font><br>");
54} 74}
55 75
56void IRCServerTab::doConnect() { 76void IRCServerTab::doConnect() {
57 m_session->beginSession(); 77 m_session->beginSession();
58} 78}
59 79
60void IRCServerTab::remove() { 80void IRCServerTab::remove() {
81 /* Close requested */
61 if (m_session->isSessionActive()) { 82 if (m_session->isSessionActive()) {
83 /* While there is a running session */
62 m_close = TRUE; 84 m_close = TRUE;
63 m_session->endSession(); 85 m_session->endSession();
64 } else { 86 } else {
87 /* Session has previously been closed */
88 m_channelTabs.first();
89 while (m_channelTabs.current() != 0) {
90 m_mainWindow->killTab(m_channelTabs.current());
91 }
65 m_mainWindow->killTab(this); 92 m_mainWindow->killTab(this);
66 } 93 }
67} 94}
68 95
69IRCChannelTab *IRCServerTab::getTabForChannel(IRCChannel *channel) { 96IRCChannelTab *IRCServerTab::getTabForChannel(IRCChannel *channel) {
70 QListIterator<IRCChannelTab> it(m_channelTabs); 97 QListIterator<IRCChannelTab> it(m_channelTabs);
71 98
72 for (; it.current(); ++it) { 99 for (; it.current(); ++it) {
73 if (it.current()->channel() == channel) 100 if (it.current()->channel() == channel)
74 return it.current(); 101 return it.current();
75 } 102 }
76 return 0; 103 return 0;
77} 104}
78 105
79void IRCServerTab::display(IRCOutput output) { 106void IRCServerTab::display(IRCOutput output) {
107
108 /* All messages to be displayed inside the GUI get here */
80 switch (output.type()) { 109 switch (output.type()) {
81 case OUTPUT_CONNCLOSE: 110 case OUTPUT_CONNCLOSE:
82 if (m_close) 111 if (m_close) {
112 m_channelTabs.first();
113 while (m_channelTabs.current() != 0) {
114 m_mainWindow->killTab(m_channelTabs.current());
115 }
83 m_mainWindow->killTab(this); 116 m_mainWindow->killTab(this);
84 else 117 } else {
85 appendText("<font color=\"#0000dd\">" + output.message() +"</font><br>"); 118 appendText("<font color=\"#0000dd\">" + output.htmlMessage() +"</font><br>");
119 QListIterator<IRCChannelTab> it(m_channelTabs);
120 for (; it.current(); ++it) {
121 it.current()->appendText("<font color=\"#0000dd\">" + output.htmlMessage() +"</font><br>");
122 }
123 }
86 break; 124 break;
87 case OUTPUT_SELFJOIN: { 125 case OUTPUT_SELFJOIN: {
88 IRCChannelTab *channeltab = new IRCChannelTab((IRCChannel *)output.getParam(0), this, m_mainWindow, (QWidget *)parent()); 126 IRCChannelTab *channeltab = new IRCChannelTab((IRCChannel *)output.getParam(0), this, m_mainWindow, (QWidget *)parent());
89 m_channelTabs.append(channeltab); 127 m_channelTabs.append(channeltab);
90 m_mainWindow->addTab(channeltab); 128 m_mainWindow->addTab(channeltab);
91 } 129 }
92 break; 130 break;
93 case OUTPUT_CHANPRIVMSG: { 131 case OUTPUT_CHANPRIVMSG: {
94 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); 132 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0));
95 channelTab->appendText("&lt;<font color=\"#0000dd\">"+((IRCChannelPerson *)output.getParam(1))->person->nick()+"</font>&gt; "+output.message()+"<br>"); 133 channelTab->appendText("&lt;<font color=\"#0000dd\">"+((IRCChannelPerson *)output.getParam(1))->person->nick()+"</font>&gt; "+output.htmlMessage()+"<br>");
96 } 134 }
97 break; 135 break;
98 case OUTPUT_SELFPART: { 136 case OUTPUT_SELFPART: {
99 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); 137 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0));
100 if (channelTab) 138 if (channelTab)
101 m_mainWindow->killTab(channelTab); 139 m_mainWindow->killTab(channelTab);
102 } 140 }
103 break; 141 break;
104 case OUTPUT_SELFKICK: { 142 case OUTPUT_SELFKICK: {
105 appendText("<font color=\"#ff0000\">" + output.message() + "</font><br>"); 143 appendText("<font color=\"#ff0000\">" + output.htmlMessage() + "</font><br>");
106 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); 144 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0));
107 if (channelTab) 145 if (channelTab)
108 m_mainWindow->killTab(channelTab); 146 m_mainWindow->killTab(channelTab);
109 } 147 }
110 break; 148 break;
111 case OUTPUT_CHANACTION: { 149 case OUTPUT_CHANACTION: {
112 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); 150 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0));
113 channelTab->appendText("<font color=\"#cc0000\">"+output.message()+"</font><br>"); 151 channelTab->appendText("<font color=\"#cc0000\">"+output.htmlMessage()+"</font><br>");
114 } 152 }
115 break; 153 break;
116 case OUTPUT_QUIT: { 154 case OUTPUT_QUIT: {
117 QString nick = ((IRCPerson *)output.getParam(0))->nick(); 155 QString nick = ((IRCPerson *)output.getParam(0))->nick();
118 QListIterator<IRCChannelTab> it(m_channelTabs); 156 QListIterator<IRCChannelTab> it(m_channelTabs);
119 for (; it.current(); ++it) { 157 for (; it.current(); ++it) {
120 if (it.current()->list()->hasPerson(nick)) { 158 if (it.current()->list()->hasPerson(nick)) {
121 it.current()->appendText("<font color=\"#aa3e00\">"+output.message()+"</font><br>"); 159 it.current()->appendText("<font color=\"#aa3e00\">"+output.htmlMessage()+"</font><br>");
122 it.current()->list()->update(); 160 it.current()->list()->update();
123 } 161 }
124 } 162 }
125 } 163 }
126 break; 164 break;
127 case OUTPUT_OTHERJOIN: 165 case OUTPUT_OTHERJOIN:
128 case OUTPUT_OTHERKICK: 166 case OUTPUT_OTHERKICK:
129 case OUTPUT_CHANPERSONMODE: 167 case OUTPUT_CHANPERSONMODE:
130 case OUTPUT_OTHERPART: { 168 case OUTPUT_OTHERPART: {
131 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); 169 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0));
132 channelTab->appendText("<font color=\"#aa3e00\">"+output.message()+"</font><br>"); 170 channelTab->appendText("<font color=\"#aa3e00\">"+output.htmlMessage()+"</font><br>");
133 channelTab->list()->update(); 171 channelTab->list()->update();
134 } 172 }
135 break; 173 break;
136 case OUTPUT_CTCP: 174 case OUTPUT_CTCP:
137 appendText("<font color=\"#00bb00\">" + output.message() + "</font><br>"); 175 appendText("<font color=\"#00bb00\">" + output.htmlMessage() + "</font><br>");
138 break; 176 break;
139 case OUTPUT_ERROR: 177 case OUTPUT_ERROR:
140 appendText("<font color=\"#ff0000\">" + output.message() + "</font><br>"); 178 appendText("<font color=\"#ff0000\">" + output.htmlMessage() + "</font><br>");
141 break; 179 break;
142 default: 180 default:
143 appendText("<font color=\"#0000dd\">" + output.message() + "</font><br>"); 181 appendText("<font color=\"#0000dd\">" + output.htmlMessage() + "</font><br>");
144 break; 182 break;
145 } 183 }
146} 184}
diff --git a/noncore/net/opieirc/ircservertab.h b/noncore/net/opieirc/ircservertab.h
index fa9a0a3..cfa0832 100644
--- a/noncore/net/opieirc/ircservertab.h
+++ b/noncore/net/opieirc/ircservertab.h
@@ -30,24 +30,27 @@ class IRCServerTab : public IRCTab {
30 Q_OBJECT 30 Q_OBJECT
31public: 31public:
32 /* IRCTab implementation */ 32 /* IRCTab implementation */
33 IRCServerTab(IRCServer server, MainWindow *mainWindow, QWidget *parent = 0, const char *name = 0, WFlags f = 0); 33 IRCServerTab(IRCServer server, MainWindow *mainWindow, QWidget *parent = 0, const char *name = 0, WFlags f = 0);
34 ~IRCServerTab(); 34 ~IRCServerTab();
35 QString title(); 35 QString title();
36 IRCSession *session(); 36 IRCSession *session();
37 IRCServer *server(); 37 IRCServer *server();
38 38
39 /* Start the server session */ 39 /* Start the server session */
40 void doConnect(); 40 void doConnect();
41 void removeChannelTab(IRCChannelTab *tab); 41 void removeChannelTab(IRCChannelTab *tab);
42
43 /* Execute a user command such as /join */
44 void executeCommand(IRCTab *tab, QString line);
42protected: 45protected:
43 void appendText(QString text); 46 void appendText(QString text);
44 IRCChannelTab *getTabForChannel(IRCChannel *channel); 47 IRCChannelTab *getTabForChannel(IRCChannel *channel);
45public slots: 48public slots:
46 void remove(); 49 void remove();
47 void processCommand(); 50 void processCommand();
48protected slots: 51protected slots:
49 void display(IRCOutput output); 52 void display(IRCOutput output);
50protected: 53protected:
51 bool m_close; 54 bool m_close;
52 IRCServer m_server; 55 IRCServer m_server;
53 IRCSession *m_session; 56 IRCSession *m_session;
diff --git a/noncore/net/opieirc/ircsession.cpp b/noncore/net/opieirc/ircsession.cpp
index b81038f..89df68c 100644
--- a/noncore/net/opieirc/ircsession.cpp
+++ b/noncore/net/opieirc/ircsession.cpp
@@ -3,24 +3,28 @@
3#include "ircversion.h" 3#include "ircversion.h"
4 4
5IRCSession::IRCSession(IRCServer *server) { 5IRCSession::IRCSession(IRCServer *server) {
6 m_server = server; 6 m_server = server;
7 m_connection = new IRCConnection(m_server); 7 m_connection = new IRCConnection(m_server);
8 m_parser = new IRCMessageParser(this); 8 m_parser = new IRCMessageParser(this);
9 connect(m_connection, SIGNAL(messageArrived(IRCMessage *)), this, SLOT(handleMessage(IRCMessage *))); 9 connect(m_connection, SIGNAL(messageArrived(IRCMessage *)), this, SLOT(handleMessage(IRCMessage *)));
10 connect(m_parser, SIGNAL(outputReady(IRCOutput)), this, SIGNAL(outputReady(IRCOutput))); 10 connect(m_parser, SIGNAL(outputReady(IRCOutput)), this, SIGNAL(outputReady(IRCOutput)));
11 connect(m_connection, SIGNAL(outputReady(IRCOutput)), this, SIGNAL(outputReady(IRCOutput))); 11 connect(m_connection, SIGNAL(outputReady(IRCOutput)), this, SIGNAL(outputReady(IRCOutput)));
12} 12}
13 13
14IRCSession::~IRCSession() { 14IRCSession::~IRCSession() {
15 /* We want this to get deleted automatically */
16 m_channels.setAutoDelete(TRUE);
17 m_people.setAutoDelete(TRUE);
18
15 delete m_parser; 19 delete m_parser;
16 delete m_connection; 20 delete m_connection;
17} 21}
18 22
19void IRCSession::beginSession() { 23void IRCSession::beginSession() {
20 m_connection->doConnect(); 24 m_connection->doConnect();
21} 25}
22 26
23void IRCSession::join(QString channelname) { 27void IRCSession::join(QString channelname) {
24 m_connection->sendLine("JOIN "+channelname); 28 m_connection->sendLine("JOIN "+channelname);
25} 29}
26 30
diff --git a/noncore/net/opieirc/irctab.h b/noncore/net/opieirc/irctab.h
index 3124980..0ce9777 100644
--- a/noncore/net/opieirc/irctab.h
+++ b/noncore/net/opieirc/irctab.h
@@ -28,20 +28,21 @@
28#include <qlayout.h> 28#include <qlayout.h>
29#include "ircsession.h" 29#include "ircsession.h"
30 30
31/* This is the base class for any tabs which need to be integrated into 31/* This is the base class for any tabs which need to be integrated into
32 the main GUI tab widget */ 32 the main GUI tab widget */
33 33
34class IRCTab : public QWidget { 34class IRCTab : public QWidget {
35 Q_OBJECT 35 Q_OBJECT
36public: 36public:
37 IRCTab(QWidget *parent = 0, const char *name = 0, WFlags f = 0); 37 IRCTab(QWidget *parent = 0, const char *name = 0, WFlags f = 0);
38 virtual QString title() = 0; 38 virtual QString title() = 0;
39 virtual IRCSession *session() = 0; 39 virtual IRCSession *session() = 0;
40 virtual void appendText(QString text) = 0;
40public slots: 41public slots:
41 virtual void remove() = 0; 42 virtual void remove() = 0;
42protected: 43protected:
43 QLabel *m_description; 44 QLabel *m_description;
44 QVBoxLayout *m_layout; 45 QVBoxLayout *m_layout;
45}; 46};
46 47
47#endif /* __IRCTAB_H */ 48#endif /* __IRCTAB_H */
diff --git a/noncore/net/opieirc/ircversion.h b/noncore/net/opieirc/ircversion.h
index 0ef0d2f..f8510e6 100644
--- a/noncore/net/opieirc/ircversion.h
+++ b/noncore/net/opieirc/ircversion.h
@@ -12,16 +12,16 @@
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details. 13 GNU General Public License for more details.
14 14
15 You should have received a copy of the GNU General Public License 15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software 16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 17 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 18
19*/ 19*/
20 20
21#ifndef __IRCVERSION_H 21#ifndef __IRCVERSION_H
22#define __IRCVERSION_H 22#define __IRCVERSION_H
23 23
24#define APP_VERSION "OpieIRC 0.1" 24#define APP_VERSION "OpieIRC 0.2"
25#define APP_COPYSTR "(c) 2002 by Wenzel Jakob" 25#define APP_COPYSTR "(c) 2002 by Wenzel Jakob"
26 26
27#endif /* __IRCVERSION_H */ 27#endif /* __IRCVERSION_H */