summaryrefslogtreecommitdiff
authorzecke <zecke>2004-09-08 21:51:06 (UTC)
committer zecke <zecke>2004-09-08 21:51:06 (UTC)
commitebb830522c9662bda4c4453e532bcc29631c5d60 (patch) (unidiff)
tree5cf95975e91cb2db78be5cdf47c01a340109c1f4
parentf0fdb800d57e9a1d95ba593185e9462300539eea (diff)
downloadopie-ebb830522c9662bda4c4453e532bcc29631c5d60.zip
opie-ebb830522c9662bda4c4453e532bcc29631c5d60.tar.gz
opie-ebb830522c9662bda4c4453e532bcc29631c5d60.tar.bz2
-Close Tab Keyboard Accelerator with delayed deletion of the tab
-Optionally add a TimeStamp to the Tab -Remove not implemented CTCP actions from the Channel PopupMenu -Give Focus to the Edit Line -Some more ping handling patch inspired and copied from zautrix fork
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/net/opieirc/.cvsignore3
-rw-r--r--noncore/net/opieirc/ircchanneltab.cpp22
-rw-r--r--noncore/net/opieirc/ircchanneltab.h2
-rw-r--r--noncore/net/opieirc/ircmessageparser.cpp34
-rw-r--r--noncore/net/opieirc/ircmisc.cpp5
-rw-r--r--noncore/net/opieirc/ircmisc.h3
-rw-r--r--noncore/net/opieirc/ircquerytab.cpp9
-rw-r--r--noncore/net/opieirc/ircserverlist.cpp9
-rw-r--r--noncore/net/opieirc/ircserverlist.h3
-rw-r--r--noncore/net/opieirc/ircservertab.cpp25
-rw-r--r--noncore/net/opieirc/ircsettings.cpp18
-rw-r--r--noncore/net/opieirc/ircsettings.h2
-rw-r--r--noncore/net/opieirc/irctab.cpp16
-rw-r--r--noncore/net/opieirc/irctab.h4
-rw-r--r--noncore/net/opieirc/mainwindow.cpp32
-rw-r--r--noncore/net/opieirc/mainwindow.h7
16 files changed, 155 insertions, 39 deletions
diff --git a/noncore/net/opieirc/.cvsignore b/noncore/net/opieirc/.cvsignore
index d5423d6..0ccbade 100644
--- a/noncore/net/opieirc/.cvsignore
+++ b/noncore/net/opieirc/.cvsignore
@@ -1,4 +1,5 @@
1Makefile 1Makefile
2Makefile.in 2Makefile.in
3moc_*.cpp 3moc_*.cpp
4.moc \ No newline at end of file 4.moc
5*.gch \ No newline at end of file
diff --git a/noncore/net/opieirc/ircchanneltab.cpp b/noncore/net/opieirc/ircchanneltab.cpp
index b6e3954..7610058 100644
--- a/noncore/net/opieirc/ircchanneltab.cpp
+++ b/noncore/net/opieirc/ircchanneltab.cpp
@@ -1,181 +1,189 @@
1#include <qpe/resource.h> 1#include <qpe/resource.h>
2#include <qwhatsthis.h> 2#include <qwhatsthis.h>
3#include <qhbox.h> 3#include <qhbox.h>
4#include "ircchanneltab.h" 4#include "ircchanneltab.h"
5#include "ircservertab.h" 5#include "ircservertab.h"
6 6
7IRCChannelTab::IRCChannelTab(IRCChannel *channel, IRCServerTab *parentTab, MainWindow *mainWindow, QWidget *parent, const char *name, WFlags f) : IRCTab(parent, name, f) { 7IRCChannelTab::IRCChannelTab(IRCChannel *channel, IRCServerTab *parentTab, MainWindow *mainWindow, QWidget *parent, const char *name, WFlags f) : IRCTab(parent, name, f) {
8 m_mainWindow = mainWindow; 8 m_mainWindow = mainWindow;
9 m_parentTab = parentTab; 9 m_parentTab = parentTab;
10 m_channel = channel; 10 m_channel = channel;
11 m_description->setText(tr("Talking on channel") + " <b>" + channel->channelname() + "</b>"); 11 m_description->setText(tr("Talking on channel") + " <b>" + channel->channelname() + "</b>");
12 QHBox *hbox = new QHBox(this); 12 QHBox *hbox = new QHBox(this);
13 m_textview = new QTextView(hbox); 13 m_textview = new QTextView(hbox);
14 m_textview->setHScrollBarMode(QScrollView::AlwaysOff); 14 m_textview->setHScrollBarMode(QScrollView::AlwaysOff);
15 m_textview->setVScrollBarMode(QScrollView::AlwaysOn); 15 m_textview->setVScrollBarMode(QScrollView::AlwaysOn);
16 m_listVisible = TRUE; 16 m_listVisible = TRUE;
17 m_listButton = new QPushButton(">", m_textview); 17 m_listButton = new QPushButton(">", m_textview);
18 m_listButton->setFlat( true );
18 m_textview->setCornerWidget(m_listButton); 19 m_textview->setCornerWidget(m_listButton);
19 m_textview->setTextFormat(RichText); 20 m_textview->setTextFormat(RichText);
20 QWhatsThis::add(m_textview, tr("Channel discussion")); 21 QWhatsThis::add(m_textview, tr("Channel discussion"));
21 connect(m_listButton, SIGNAL(clicked()), this, SLOT(toggleList())); 22 connect(m_listButton, SIGNAL(clicked()), this, SLOT(toggleList()));
22 m_list = new IRCChannelList(m_channel, hbox); 23 m_list = new IRCChannelList(m_channel, hbox);
23 m_list->update(); 24 m_list->update();
24 m_list->setMaximumWidth(LISTWIDTH); 25 m_list->setMaximumWidth(LISTWIDTH);
25 m_field = new IRCHistoryLineEdit(this); 26 m_field = new IRCHistoryLineEdit(this);
26 connect(m_field, SIGNAL(nextTab()), this, SIGNAL(nextTab())); 27 connect(m_field, SIGNAL(nextTab()), this, SIGNAL(nextTab()));
27 connect(m_field, SIGNAL(prevTab()), this, SIGNAL(prevTab())); 28 connect(m_field, SIGNAL(prevTab()), this, SIGNAL(prevTab()));
28 connect(m_field, SIGNAL(closeTab()), this, SIGNAL(closeTab())); 29 connect(m_field, SIGNAL(closeTab()), this, SLOT(remove()));
29 connect(this, SIGNAL(editFocus()), m_field, SLOT(setEditFocus())); 30 connect(this, SIGNAL(editFocus()), m_field, SLOT(setEditFocus()));
30 31
31 QWhatsThis::add(m_field, tr("Type your message here to participate in the channel discussion")); 32 QWhatsThis::add(m_field, tr("Type your message here to participate in the channel discussion"));
32 m_popup = new QPopupMenu(m_list); 33 m_popup = new QPopupMenu(m_list);
33 m_lines = 0; 34 m_lines = 0;
34 /* Required so that embedded-style "right" clicks work */ 35 /* Required so that embedded-style "right" clicks work */
35 QPEApplication::setStylusOperation(m_list->viewport(), QPEApplication::RightOnHold); 36 QPEApplication::setStylusOperation(m_list->viewport(), QPEApplication::RightOnHold);
36 connect(m_list, SIGNAL(mouseButtonPressed(int,QListBoxItem*,const QPoint&)), this, SLOT(mouseButtonPressed(int,QListBoxItem*,const QPoint&))); 37 connect(m_list, SIGNAL(mouseButtonPressed(int,QListBoxItem*,const QPoint&)), this, SLOT(mouseButtonPressed(int,QListBoxItem*,const QPoint&)));
37 /* Construct the popup menu */ 38 /* Construct the popup menu */
38 QPopupMenu *ctcpMenu = new QPopupMenu(m_list); 39 QPopupMenu *ctcpMenu = new QPopupMenu(m_list);
39 m_popup->insertItem(Resource::loadPixmap("opieirc/ctcp"), tr("CTCP"), ctcpMenu);
40 m_popup->insertItem(Resource::loadPixmap("opieirc/query"), tr("Query"), this, SLOT(popupQuery())); 40 m_popup->insertItem(Resource::loadPixmap("opieirc/query"), tr("Query"), this, SLOT(popupQuery()));
41 ctcpMenu->insertItem(Resource::loadPixmap("opieirc/ping"), tr("Ping"), this, SLOT(popupPing())); 41 ctcpMenu->insertItem(Resource::loadPixmap("opieirc/ping"), tr("Ping"), this, SLOT(popupPing()));
42 ctcpMenu->insertItem(Resource::loadPixmap("opieirc/version"), tr("Version"), this, SLOT(popupVersion())); 42 ctcpMenu->insertItem(Resource::loadPixmap("opieirc/version"), tr("Version"), this, SLOT(popupVersion()));
43 ctcpMenu->insertItem(Resource::loadPixmap("opieirc/whois"), tr("Whois"), this, SLOT(popupWhois())); 43 ctcpMenu->insertItem(Resource::loadPixmap("opieirc/whois"), tr("Whois"), this, SLOT(popupWhois()));
44 connect(m_mainWindow, SIGNAL(updateScroll()), this, SLOT(scrolling())); 44 connect(m_mainWindow, SIGNAL(updateScroll()), this, SLOT(scrolling()));
45 m_layout->add(hbox); 45 m_layout->add(hbox);
46 hbox->show(); 46 hbox->show();
47 m_layout->add(m_field); 47 m_layout->add(m_field);
48 m_field->setFocus(); 48 m_field->setFocus();
49 m_field->setActiveWindow(); 49 m_field->setActiveWindow();
50 50
51 connect(m_field, SIGNAL(returnPressed()), this, SLOT(processCommand())); 51 connect(m_field, SIGNAL(returnPressed()), this, SLOT(processCommand()));
52 connect(m_list, SIGNAL(doubleClicked ( QListBoxItem * ) ), this, SLOT(popupQuery( QListBoxItem * ) ));
52 settingsChanged(); 53 settingsChanged();
53} 54}
54 55
55void IRCChannelTab::scrolling(){ 56void IRCChannelTab::scrolling(){
56 m_textview->ensureVisible(0, m_textview->contentsHeight()); 57 m_textview->ensureVisible(0, m_textview->contentsHeight());
57} 58}
58 59
59void IRCChannelTab::appendText(QString text) { 60void IRCChannelTab::appendText(QString text) {
60 /* not using append because it creates layout problems */ 61 /* not using append because it creates layout problems */
61 QString txt = m_textview->text() + text + "\n"; 62 QString txt = m_textview->text() + IRCTab::appendTimestamp( text );
62 if (m_maxLines > 0 && m_lines >= m_maxLines) { 63 if (m_maxLines > 0 && m_lines >= m_maxLines) {
63 int firstBreak = txt.find('\n'); 64 int firstBreak = txt.find('\n');
64 if (firstBreak != -1) { 65 if (firstBreak != -1) {
65 txt = "<qt bgcolor=\"" + m_backgroundColor + "\"/>" + txt.right(txt.length() - (firstBreak + 1)); 66 txt = "<qt bgcolor=\"" + m_backgroundColor + "\"/>" + txt.right(txt.length() - (firstBreak + 1));
66 } 67 }
67 } else { 68 } else {
68 m_lines++; 69 m_lines++;
69 } 70 }
70 m_textview->ensureVisible(0, m_textview->contentsHeight()); 71 m_textview->ensureVisible(0, m_textview->contentsHeight());
71 m_textview->setText(txt); 72 m_textview->setText(txt);
72 m_textview->ensureVisible(0, m_textview->contentsHeight()); 73 m_textview->ensureVisible(0, m_textview->contentsHeight());
73 74
74 int p1, p2; 75 int p1, p2;
75 if ( (p1 = text.find("ping", 0, false) )!= -1 && (p2 = text.find( m_parentTab->server()->nick(), 0,false )) != -1 ) { 76 if ( text.contains( IRCMessageParser::tr("Received a CTCP PING from ") ) )
77 emit ping( title() );
78 else if ( (p1 = text.find("ping", 0, false) )!= -1 && (p2 = text.find( m_parentTab->server()->nick(), 0,false )) != -1 ) {
76 int col = text.findRev("color", -1, false); 79 int col = text.findRev("color", -1, false);
77 if ( col < p2 ) 80 if ( col < p2 )
78 emit ping( title() ); 81 emit ping( title() );
79 82
80 } 83 }
81 84
82 emit changed(this); 85 emit changed(this);
83} 86}
84 87
85IRCChannelTab::~IRCChannelTab() { 88IRCChannelTab::~IRCChannelTab() {
86 m_parentTab->removeChannelTab(this); 89 m_parentTab->removeChannelTab(this);
87} 90}
88 91
89void IRCChannelTab::processCommand() { 92void IRCChannelTab::processCommand() {
90 QString text = m_field->text(); 93 QString text = m_field->text();
91 if (text.length()>0) { 94 if (text.length()>0) {
92 if (session()->isSessionActive()) { 95 if (session()->isSessionActive()) {
93 if (text.startsWith("/") && !text.startsWith("//")) { 96 if (text.startsWith("/") && !text.startsWith("//")) {
94 /* Command mode */ 97 /* Command mode */
95 m_parentTab->executeCommand(this, text);; 98 m_parentTab->executeCommand(this, text);;
96 } else { 99 } else {
97 if (text.startsWith("//")) 100 if (text.startsWith("//"))
98 text = text.right(text.length()-1); 101 text = text.right(text.length()-1);
99 session()->sendMessage(m_channel, m_field->text()); 102 session()->sendMessage(m_channel, m_field->text());
100 appendText("<font color=\"" + m_textColor + "\">&lt;</font><font color=\"" + m_selfColor + "\">"+m_parentTab->server()->nick()+"</font><font color=\"" + m_textColor + "\">&gt; "+IRCOutput::toHTML(m_field->text())+"</font><br>"); 103 appendText("<font color=\"" + m_textColor + "\">&lt;</font><font color=\"" + m_selfColor + "\">"+m_parentTab->server()->nick()+"</font><font color=\"" + m_textColor + "\">&gt; "+IRCOutput::toHTML(m_field->text())+"</font><br>");
101 } 104 }
102 } else { 105 } else {
103 appendText("<font color=\"" + m_errorColor + "\">"+tr("Disconnected")+"</font><br>"); 106 appendText("<font color=\"" + m_errorColor + "\">"+tr("Disconnected")+"</font><br>");
104 } 107 }
105 } 108 }
106 m_field->clear(); 109 m_field->clear();
107} 110}
108 111
109void IRCChannelTab::settingsChanged() { 112void IRCChannelTab::settingsChanged() {
110 m_textview->setText("<qt bgcolor=\"" + m_backgroundColor + "\"/>"); 113 m_textview->setText("<qt bgcolor=\"" + m_backgroundColor + "\"/>");
111 m_lines = 0; 114 m_lines = 0;
112} 115}
113 116
114void IRCChannelTab::toggleList() { 117void IRCChannelTab::toggleList() {
115 if (m_listVisible) { 118 if (m_listVisible) {
116 m_list->setMaximumWidth(0); 119 m_list->setMaximumWidth(0);
117 m_listButton->setText("<"); 120 m_listButton->setText("<");
118 } else { 121 } else {
119 m_list->setMaximumWidth(LISTWIDTH); 122 m_list->setMaximumWidth(LISTWIDTH);
120 m_listButton->setText(">"); 123 m_listButton->setText(">");
121 } 124 }
122 m_listVisible = !m_listVisible; 125 m_listVisible = !m_listVisible;
123} 126}
124 127
125void IRCChannelTab::mouseButtonPressed(int mouse, QListBoxItem *, const QPoint &point) { 128void IRCChannelTab::mouseButtonPressed(int mouse, QListBoxItem *, const QPoint &point) {
126 switch (mouse) { 129 switch (mouse) {
127 case 1: 130 case 1:
128 break; 131 break;
129 case 2: 132 case 2:
130 m_popup->popup(point); 133 m_popup->popup(point);
131 break; 134 break;
132 }; 135 };
133} 136}
134 137
135void IRCChannelTab::popupQuery() { 138void IRCChannelTab::popupQuery( QListBoxItem *item) {
136 if (m_list->currentItem() != -1) { 139 if (item) {
137 IRCPerson *person = session()->getPerson(m_list->item(m_list->currentItem())->text()); 140 IRCPerson *person = session()->getPerson(item->text());
138 if (person) { 141 if (person) {
139 IRCQueryTab *tab = m_parentTab->getTabForQuery(person); 142 IRCQueryTab *tab = m_parentTab->getTabForQuery(person);
140 if (!tab) { 143 if (!tab) {
141 tab = new IRCQueryTab(person, m_parentTab, m_mainWindow, (QWidget *)parent()); 144 tab = new IRCQueryTab(person, m_parentTab, m_mainWindow, (QWidget *)parent());
142 m_parentTab->addQueryTab(tab); 145 m_parentTab->addQueryTab(tab);
143 m_mainWindow->addTab(tab); 146 m_mainWindow->addTab(tab);
144 } 147 }
145 } 148 }
146 } 149 }
147} 150}
148 151
152void IRCChannelTab::popupQuery() {
153 if ( m_list->currentItem() != -1 )
154 popupQuery( m_list->item(m_list->currentItem()));
155}
156
149void IRCChannelTab::popupPing() { 157void IRCChannelTab::popupPing() {
150 //HAHA, no wonder these don't work 158 //HAHA, no wonder these don't work
151} 159}
152 160
153void IRCChannelTab::popupVersion() { 161void IRCChannelTab::popupVersion() {
154} 162}
155 163
156void IRCChannelTab::popupWhois() { 164void IRCChannelTab::popupWhois() {
157} 165}
158 166
159QString IRCChannelTab::title() { 167QString IRCChannelTab::title() {
160 return m_channel->channelname(); 168 return m_channel->channelname();
161} 169}
162 170
163IRCSession *IRCChannelTab::session() { 171IRCSession *IRCChannelTab::session() {
164 return m_parentTab->session(); 172 return m_parentTab->session();
165} 173}
166 174
167void IRCChannelTab::remove() { 175void IRCChannelTab::remove() {
168 if (session()->isSessionActive()) { 176 if (session()->isSessionActive()) {
169 session()->part(m_channel); 177 session()->part(m_channel);
170 } else { 178 } else {
171 m_mainWindow->killTab(this); 179 m_mainWindow->killTab(this);
172 } 180 }
173} 181}
174 182
175IRCChannel *IRCChannelTab::channel() { 183IRCChannel *IRCChannelTab::channel() {
176 return m_channel; 184 return m_channel;
177} 185}
178 186
179IRCChannelList *IRCChannelTab::list() { 187IRCChannelList *IRCChannelTab::list() {
180 return m_list; 188 return m_list;
181} 189}
diff --git a/noncore/net/opieirc/ircchanneltab.h b/noncore/net/opieirc/ircchanneltab.h
index 001c96d..70b212c 100644
--- a/noncore/net/opieirc/ircchanneltab.h
+++ b/noncore/net/opieirc/ircchanneltab.h
@@ -1,73 +1,75 @@
1/* 1/*
2 OpieIRC - An embedded IRC client 2 OpieIRC - An embedded IRC client
3 Copyright (C) 2002 Wenzel Jakob 3 Copyright (C) 2002 Wenzel Jakob
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
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 __IRCCHANNELTAB_H 21#ifndef __IRCCHANNELTAB_H
22#define __IRCCHANNELTAB_H 22#define __IRCCHANNELTAB_H
23 23
24#include <qpopupmenu.h> 24#include <qpopupmenu.h>
25#include <qpushbutton.h> 25#include <qpushbutton.h>
26#include "irctab.h" 26#include "irctab.h"
27#include "ircsession.h" 27#include "ircsession.h"
28#include "ircmisc.h" 28#include "ircmisc.h"
29#include "mainwindow.h" 29#include "mainwindow.h"
30#include "ircchannellist.h" 30#include "ircchannellist.h"
31 31
32#define LISTWIDTH 70 32#define LISTWIDTH 70
33 33
34class IRCServerTab; 34class IRCServerTab;
35class IRCChannelTab : public IRCTab { 35class IRCChannelTab : public IRCTab {
36 Q_OBJECT 36 Q_OBJECT
37public: 37public:
38 /* IRCTab implementation */ 38 /* IRCTab implementation */
39 IRCChannelTab(IRCChannel *channel, IRCServerTab *parentTab, MainWindow *mainWindow, QWidget *parent = 0, const char *name = 0, WFlags f = 0); 39 IRCChannelTab(IRCChannel *channel, IRCServerTab *parentTab, MainWindow *mainWindow, QWidget *parent = 0, const char *name = 0, WFlags f = 0);
40 ~IRCChannelTab(); 40 ~IRCChannelTab();
41 QString title(); 41 QString title();
42 IRCSession *session(); 42 IRCSession *session();
43 IRCChannel *channel(); 43 IRCChannel *channel();
44 IRCChannelList *list(); 44 IRCChannelList *list();
45public: 45public:
46 void appendText(QString text); 46 void appendText(QString text);
47public slots: 47public slots:
48 void remove(); 48 void remove();
49 void settingsChanged(); 49 void settingsChanged();
50 void scrolling(); 50 void scrolling();
51protected slots: 51protected slots:
52 void processCommand(); 52 void processCommand();
53 void toggleList(); 53 void toggleList();
54 void mouseButtonPressed(int mouse, QListBoxItem *item, const QPoint &point); 54 void mouseButtonPressed(int mouse, QListBoxItem *item, const QPoint &point);
55 /* Popup slots */ 55 /* Popup slots */
56 void popupQuery(QListBoxItem*);
56 void popupQuery(); 57 void popupQuery();
58
57 void popupPing(); 59 void popupPing();
58 void popupVersion(); 60 void popupVersion();
59 void popupWhois(); 61 void popupWhois();
60protected: 62protected:
61 IRCServerTab *m_parentTab; 63 IRCServerTab *m_parentTab;
62 IRCChannel *m_channel; 64 IRCChannel *m_channel;
63 IRCChannelList *m_list; 65 IRCChannelList *m_list;
64 QPushButton *m_listButton; 66 QPushButton *m_listButton;
65 MainWindow *m_mainWindow; 67 MainWindow *m_mainWindow;
66 QTextView *m_textview; 68 QTextView *m_textview;
67 IRCHistoryLineEdit *m_field; 69 IRCHistoryLineEdit *m_field;
68 QPopupMenu *m_popup; 70 QPopupMenu *m_popup;
69 bool m_listVisible; 71 bool m_listVisible;
70 int m_lines; 72 int m_lines;
71}; 73};
72 74
73#endif /* __IRCCHANNELTAB_H */ 75#endif /* __IRCCHANNELTAB_H */
diff --git a/noncore/net/opieirc/ircmessageparser.cpp b/noncore/net/opieirc/ircmessageparser.cpp
index 90280d7..ecc7e9a 100644
--- a/noncore/net/opieirc/ircmessageparser.cpp
+++ b/noncore/net/opieirc/ircmessageparser.cpp
@@ -1,536 +1,570 @@
1#include <qtextstream.h> 1#include <qtextstream.h>
2#include "ircmessageparser.h" 2#include "ircmessageparser.h"
3#include "ircversion.h" 3#include "ircversion.h"
4 4
5/* Lookup table for literal commands */ 5/* Lookup table for literal commands */
6IRCLiteralMessageParserStruct IRCMessageParser::literalParserProcTable[] = { 6IRCLiteralMessageParserStruct IRCMessageParser::literalParserProcTable[] = {
7 { "PING", FUNC(parseLiteralPing) }, 7 { "PING", FUNC(parseLiteralPing) },
8 { "NOTICE", FUNC(parseLiteralNotice) }, 8 { "NOTICE", FUNC(parseLiteralNotice) },
9 { "JOIN", FUNC(parseLiteralJoin) }, 9 { "JOIN", FUNC(parseLiteralJoin) },
10 { "PRIVMSG", FUNC(parseLiteralPrivMsg) }, 10 { "PRIVMSG", FUNC(parseLiteralPrivMsg) },
11 { "NICK", FUNC(parseLiteralNick) }, 11 { "NICK", FUNC(parseLiteralNick) },
12 { "PART", FUNC(parseLiteralPart) }, 12 { "PART", FUNC(parseLiteralPart) },
13 { "QUIT", FUNC(parseLiteralQuit) }, 13 { "QUIT", FUNC(parseLiteralQuit) },
14 { "ERROR", FUNC(parseLiteralError) }, 14 { "ERROR", FUNC(parseLiteralError) },
15 { "ERROR:", FUNC(parseLiteralError) }, 15 { "ERROR:", FUNC(parseLiteralError) },
16 { "MODE", FUNC(parseLiteralMode) }, 16 { "MODE", FUNC(parseLiteralMode) },
17 { "KICK", FUNC(parseLiteralKick) }, 17 { "KICK", FUNC(parseLiteralKick) },
18 { "TOPIC", FUNC(parseLiteralTopic) }, 18 { "TOPIC", FUNC(parseLiteralTopic) },
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
30/* Lookup table for numerical commands */ 30/* Lookup table for numerical commands */
31IRCNumericalMessageParserStruct IRCMessageParser::numericalParserProcTable[] = { 31IRCNumericalMessageParserStruct IRCMessageParser::numericalParserProcTable[] = {
32 { 1, FUNC(parseNumerical001) }, // RPL_WELCOME 32 { 1, FUNC(parseNumerical001) }, // RPL_WELCOME
33 { 2, FUNC(parseNumerical002) }, // RPL_YOURHOST 33 { 2, FUNC(parseNumerical002) }, // RPL_YOURHOST
34 { 3, FUNC(parseNumerical003) }, // RPL_CREATED 34 { 3, FUNC(parseNumerical003) }, // RPL_CREATED
35 { 4, FUNC(parseNumerical004) }, // RPL_MYINFO 35 { 4, FUNC(parseNumerical004) }, // RPL_MYINFO
36 { 5, FUNC(parseNumerical005) }, // RPL_BOUNCE, RPL_PROTOCTL 36 { 5, FUNC(parseNumerical005) }, // RPL_BOUNCE, RPL_PROTOCTL
37 { 251, FUNC(parseNumericalStats) }, // RPL_LUSERCLIENT 37 { 251, FUNC(parseNumericalStats) }, // RPL_LUSERCLIENT
38 { 252, FUNC(parseNumericalStats) }, // RPL_LUSEROP 38 { 252, FUNC(parseNumericalStats) }, // RPL_LUSEROP
39 { 265, FUNC(parseNumericalStats) }, // RPL_LOCALUSERS 39 { 265, FUNC(parseNumericalStats) }, // RPL_LOCALUSERS
40 { 266, FUNC(parseNumericalStats) }, // RPL_GLOBALUSERS 40 { 266, FUNC(parseNumericalStats) }, // RPL_GLOBALUSERS
41 { 250, FUNC(parseNumericalStats) }, // RPL_STATSCONN 41 { 250, FUNC(parseNumericalStats) }, // RPL_STATSCONN
42 { 254, FUNC(nullFunc)}, // RPL_LUSERCHANNELS 42 { 254, FUNC(nullFunc)}, // RPL_LUSERCHANNELS
43 { 255, FUNC(parseNumericalStats) }, // RPL_LUSERNAME 43 { 255, FUNC(parseNumericalStats) }, // RPL_LUSERNAME
44 { 332, FUNC(parseNumericalTopic) }, // RPL_TOPIC 44 { 332, FUNC(parseNumericalTopic) }, // RPL_TOPIC
45 { 333, FUNC(parseNumericalTopicWhoTime) }, // RPL_TOPICWHOTIME 45 { 333, FUNC(parseNumericalTopicWhoTime) }, // RPL_TOPICWHOTIME
46 { 353, FUNC(parseNumericalNames) }, // RPL_NAMREPLY 46 { 353, FUNC(parseNumericalNames) }, // RPL_NAMREPLY
47 { 366, FUNC(parseNumericalEndOfNames) }, // RPL_ENDOFNAMES 47 { 366, FUNC(parseNumericalEndOfNames) }, // RPL_ENDOFNAMES
48 { 375, FUNC(parseNumericalStats) }, // RPL_MOTDSTART 48 { 375, FUNC(parseNumericalStats) }, // RPL_MOTDSTART
49 { 372, FUNC(parseNumericalStats) }, // RPL_MOTD 49 { 372, FUNC(parseNumericalStats) }, // RPL_MOTD
50 { 376, FUNC(parseNumericalStats) }, // RPL_ENDOFMOTD 50 { 376, FUNC(parseNumericalStats) }, // RPL_ENDOFMOTD
51 { 377, FUNC(parseNumericalStats) }, // RPL_MOTD2 51 { 377, FUNC(parseNumericalStats) }, // RPL_MOTD2
52 { 378, FUNC(parseNumericalStats) }, // RPL_MOTD3 52 { 378, FUNC(parseNumericalStats) }, // RPL_MOTD3
53 { 401, FUNC(parseNumericalNoSuchNick) }, // ERR_NOSUCHNICK 53 { 401, FUNC(parseNumericalNoSuchNick) }, // ERR_NOSUCHNICK
54 { 406, FUNC(parseNumericalNoSuchNick) }, // ERR_WASNOSUCHNICK 54 { 406, FUNC(parseNumericalNoSuchNick) }, // ERR_WASNOSUCHNICK
55 { 412, FUNC(parseNumericalStats) }, // ERR_NOTEXTTOSEND 55 { 412, FUNC(parseNumericalStats) }, // ERR_NOTEXTTOSEND
56 { 433, FUNC(parseNumericalNicknameInUse) }, // ERR_NICKNAMEINUSE 56 { 433, FUNC(parseNumericalNicknameInUse) }, // ERR_NICKNAMEINUSE
57 { 0, 0 } 57 { 0, 0 }
58}; 58};
59 59
60IRCMessageParser::IRCMessageParser(IRCSession *session) { 60IRCMessageParser::IRCMessageParser(IRCSession *session) {
61 m_session = session; 61 m_session = session;
62} 62}
63 63
64void IRCMessageParser::parse(IRCMessage *message) { 64void IRCMessageParser::parse(IRCMessage *message) {
65 /* Find out what kind of message we have here and call the appropriate handler using 65 /* Find out what kind of message we have here and call the appropriate handler using
66 the parser tables. If no handler can be found, print out an error message */ 66 the parser tables. If no handler can be found, print out an error message */
67 if (message->isNumerical()) { 67 if (message->isNumerical()) {
68 for (int i=0; i<numericalParserProcTable[i].commandNumber; i++) { 68 for (int i=0; i<numericalParserProcTable[i].commandNumber; i++) {
69 if (message->commandNumber() == numericalParserProcTable[i].commandNumber) { 69 if (message->commandNumber() == numericalParserProcTable[i].commandNumber) {
70 (this->*(numericalParserProcTable[i].proc))(message); 70 (this->*(numericalParserProcTable[i].proc))(message);
71 return; 71 return;
72 } 72 }
73 } 73 }
74 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Received unhandled numeric command: %1").arg( QString::number(message->commandNumber()) ))); 74 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Received unhandled numeric command: %1").arg( QString::number(message->commandNumber()) )));
75 } else if (message->isCTCP()) { 75 } else if (message->isCTCP()) {
76 for (int i=0; ctcpParserProcTable[i].commandName; i++) { 76 for (int i=0; ctcpParserProcTable[i].commandName; i++) {
77 if (message->ctcpCommand() == ctcpParserProcTable[i].commandName) { 77 if (message->ctcpCommand() == ctcpParserProcTable[i].commandName) {
78 (this->*(ctcpParserProcTable[i].proc))(message); 78 (this->*(ctcpParserProcTable[i].proc))(message);
79 return; 79 return;
80 } 80 }
81 } 81 }
82 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Received unhandled ctcp command: %1").arg( message->ctcpCommand())) ); 82 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Received unhandled ctcp command: %1").arg( message->ctcpCommand())) );
83 } else { 83 } else {
84 for (int i=0; literalParserProcTable[i].commandName; i++) { 84 for (int i=0; literalParserProcTable[i].commandName; i++) {
85 if (message->command() == literalParserProcTable[i].commandName) { 85 if (message->command() == literalParserProcTable[i].commandName) {
86 (this->*(literalParserProcTable[i].proc))(message); 86 (this->*(literalParserProcTable[i].proc))(message);
87 return; 87 return;
88 } 88 }
89 } 89 }
90 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Received unhandled literal command: %1").arg( message->command()) )); 90 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Received unhandled literal command: %1").arg( message->command()) ));
91 } 91 }
92} 92}
93 93
94void IRCMessageParser::nullFunc(IRCMessage *) { 94void IRCMessageParser::nullFunc(IRCMessage *) {
95 /* Do nothing */ 95 /* Do nothing */
96} 96}
97 97
98void IRCMessageParser::parseLiteralPing(IRCMessage *message) { 98void IRCMessageParser::parseLiteralPing(IRCMessage *message) {
99 m_session->m_connection->sendLine("PONG " + message->allParameters()); 99 m_session->m_connection->sendLine("PONG " + message->allParameters());
100} 100}
101 101
102void IRCMessageParser::parseLiteralNotice(IRCMessage *message) { 102void IRCMessageParser::parseLiteralNotice(IRCMessage *message) {
103 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->allParameters())); 103 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->allParameters()));
104} 104}
105 105
106void IRCMessageParser::parseLiteralJoin(IRCMessage *message) { 106void IRCMessageParser::parseLiteralJoin(IRCMessage *message) {
107 QString channelName = message->param(0).lower(); 107 QString channelName = message->param(0).lower();
108 IRCPerson mask(message->prefix()); 108 IRCPerson mask(message->prefix());
109 IRCChannel *channel = m_session->getChannel(channelName); 109 IRCChannel *channel = m_session->getChannel(channelName);
110 if (!channel) { 110 if (!channel) {
111 /* We joined */ 111 /* We joined */
112 if (mask.nick() == m_session->m_server->nick()) { 112 if (mask.nick() == m_session->m_server->nick()) {
113 channel = new IRCChannel(channelName); 113 channel = new IRCChannel(channelName);
114 m_session->addChannel(channel); 114 m_session->addChannel(channel);
115 } else { 115 } else {
116 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Nonexistant channel join - desynchronized?"))); 116 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Nonexistant channel join - desynchronized?")));
117 } 117 }
118 } else { 118 } else {
119 /* Someone else joined */ 119 /* Someone else joined */
120 if (mask.nick() != m_session->m_server->nick()) { 120 if (mask.nick() != m_session->m_server->nick()) {
121 if (!channel->getPerson(mask.nick())) { 121 if (!channel->getPerson(mask.nick())) {
122 IRCChannelPerson *chanperson = new IRCChannelPerson(); 122 IRCChannelPerson *chanperson = new IRCChannelPerson();
123 IRCPerson *person = m_session->getPerson(mask.nick()); 123 IRCPerson *person = m_session->getPerson(mask.nick());
124 if (!person) { 124 if (!person) {
125 person = new IRCPerson(message->prefix()); 125 person = new IRCPerson(message->prefix());
126 m_session->addPerson(person); 126 m_session->addPerson(person);
127 } 127 }
128 chanperson->flags = 0; 128 chanperson->flags = 0;
129 chanperson->person = person; 129 chanperson->person = person;
130 channel->addPerson(chanperson); 130 channel->addPerson(chanperson);
131 IRCOutput output(OUTPUT_OTHERJOIN ,tr("%1 joined channel %2").arg( mask.nick() ).arg( channelName )); 131 IRCOutput output(OUTPUT_OTHERJOIN ,tr("%1 joined channel %2").arg( mask.nick() ).arg( channelName ));
132 output.addParam(channel); 132 output.addParam(channel);
133 output.addParam(chanperson); 133 output.addParam(chanperson);
134 emit outputReady(output); 134 emit outputReady(output);
135 } else { 135 } else {
136 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Person has already joined the channel - desynchronized?"))); 136 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Person has already joined the channel - desynchronized?")));
137 } 137 }
138 } else { 138 } else {
139 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("You already joined the channel - desynchronized?"))); 139 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("You already joined the channel - desynchronized?")));
140 } 140 }
141 } 141 }
142} 142}
143 143
144void IRCMessageParser::parseLiteralPart(IRCMessage *message) { 144void IRCMessageParser::parseLiteralPart(IRCMessage *message) {
145 QString channelName = message->param(0).lower(); 145 QString channelName = message->param(0).lower();
146 IRCChannel *channel = m_session->getChannel(channelName); 146 IRCChannel *channel = m_session->getChannel(channelName);
147 IRCPerson mask(message->prefix()); 147 IRCPerson mask(message->prefix());
148 if (channel) { 148 if (channel) {
149 if (mask.nick() == m_session->m_server->nick()) { 149 if (mask.nick() == m_session->m_server->nick()) {
150 m_session->removeChannel(channel); 150 m_session->removeChannel(channel);
151 IRCOutput output(OUTPUT_SELFPART, tr("You left channel %1").arg( channelName )); 151 IRCOutput output(OUTPUT_SELFPART, tr("You left channel %1").arg( channelName ));
152 output.addParam(channel); 152 output.addParam(channel);
153 emit outputReady(output); 153 emit outputReady(output);
154 delete channel; 154 delete channel;
155 } else { 155 } else {
156 IRCChannelPerson *person = channel->getPerson(mask.nick()); 156 IRCChannelPerson *person = channel->getPerson(mask.nick());
157 if (person) { 157 if (person) {
158 channel->removePerson(person); 158 channel->removePerson(person);
159 IRCOutput output(OUTPUT_OTHERPART, tr("%1 left channel %2").arg( mask.nick() ).arg( channelName) ); 159 IRCOutput output(OUTPUT_OTHERPART, tr("%1 left channel %2").arg( mask.nick() ).arg( channelName) );
160 output.addParam(channel); 160 output.addParam(channel);
161 output.addParam(person); 161 output.addParam(person);
162 emit outputReady(output); 162 emit outputReady(output);
163 delete person; 163 delete person;
164 } else { 164 } else {
165 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Parting person not found - desynchronized?"))); 165 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Parting person not found - desynchronized?")));
166 } 166 }
167 } 167 }
168 } else { 168 } else {
169 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Channel for part not found - desynchronized?"))); 169 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Channel for part not found - desynchronized?")));
170 } 170 }
171} 171}
172 172
173void IRCMessageParser::parseLiteralPrivMsg(IRCMessage *message) { 173void IRCMessageParser::parseLiteralPrivMsg(IRCMessage *message) {
174 if (m_session->m_server->nick().lower() == message->param(0).lower() ) { 174 if (m_session->m_server->nick().lower() == message->param(0).lower() ) {
175 /* IRC Query message detected, verify sender and display it */ 175 /* IRC Query message detected, verify sender and display it */
176 IRCPerson mask(message->prefix()); 176 IRCPerson mask(message->prefix());
177 IRCPerson *person = m_session->getPerson(mask.nick()); 177 IRCPerson *person = m_session->getPerson(mask.nick());
178 if (!person) { 178 if (!person) {
179 /* Person not yet known, create and add to the current session */ 179 /* Person not yet known, create and add to the current session */
180 person = new IRCPerson(message->prefix()); 180 person = new IRCPerson(message->prefix());
181 m_session->addPerson(person); 181 m_session->addPerson(person);
182 } 182 }
183 IRCOutput output(OUTPUT_QUERYPRIVMSG, message->param(1)); 183 IRCOutput output(OUTPUT_QUERYPRIVMSG, message->param(1));
184 output.addParam(person); 184 output.addParam(person);
185 emit outputReady(output); 185 emit outputReady(output);
186 } else if (message->param(0).at(0) == '#' || message->param(0).at(0) == '+') { 186 } else if (message->param(0).at(0) == '#' || message->param(0).at(0) == '+') {
187 /* IRC Channel message detected, verify sender, channel and display it */ 187 /* IRC Channel message detected, verify sender, channel and display it */
188 IRCChannel *channel = m_session->getChannel(message->param(0).lower()); 188 IRCChannel *channel = m_session->getChannel(message->param(0).lower());
189 if (channel) { 189 if (channel) {
190 IRCPerson mask(message->prefix()); 190 IRCPerson mask(message->prefix());
191 IRCChannelPerson *person = channel->getPerson(mask.nick()); 191 IRCChannelPerson *person = channel->getPerson(mask.nick());
192 if (person) { 192 if (person) {
193 IRCOutput output(OUTPUT_CHANPRIVMSG, message->param(1)); 193 IRCOutput output(OUTPUT_CHANPRIVMSG, message->param(1));
194 output.addParam(channel); 194 output.addParam(channel);
195 output.addParam(person); 195 output.addParam(person);
196 emit outputReady(output); 196 emit outputReady(output);
197 } else { 197 } else {
198 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Channel message with unknown sender"))); 198 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Channel message with unknown sender")));
199 } 199 }
200 } else { 200 } else {
201 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Channel message with unknown channel %1").arg(message->param(0).lower()) )); 201 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Channel message with unknown channel %1").arg(message->param(0).lower()) ));
202 } 202 }
203 } else { 203 } else {
204 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Received PRIVMSG of unknown type"))); 204 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Received PRIVMSG of unknown type")));
205 } 205 }
206} 206}
207 207
208void IRCMessageParser::parseLiteralNick(IRCMessage *message) { 208void IRCMessageParser::parseLiteralNick(IRCMessage *message) {
209 209
210 IRCPerson mask(message->prefix()); 210 IRCPerson mask(message->prefix());
211 /* this way of handling nick changes really sucks */ 211 /* this way of handling nick changes really sucks */
212 if (mask.nick() == m_session->m_server->nick()) { 212 if (mask.nick() == m_session->m_server->nick()) {
213 /* We are changing our nickname */ 213 /* We are changing our nickname */
214 m_session->m_server->setNick(message->param(0)); 214 m_session->m_server->setNick(message->param(0));
215 IRCOutput output(OUTPUT_NICKCHANGE, tr("You are now known as %1").arg( message->param(0))); 215 IRCOutput output(OUTPUT_NICKCHANGE, tr("You are now known as %1").arg( message->param(0)));
216 output.addParam(0); 216 output.addParam(0);
217 emit outputReady(output); 217 emit outputReady(output);
218 } else { 218 } else {
219 /* Someone else is */ 219 /* Someone else is */
220 IRCPerson *person = m_session->getPerson(mask.nick()); 220 IRCPerson *person = m_session->getPerson(mask.nick());
221 if (person) { 221 if (person) {
222 //IRCOutput output(OUTPUT_NICKCHANGE, tr("%1 is now known as %2").arg( mask.nick() ).arg( message->param(0))); 222 //IRCOutput output(OUTPUT_NICKCHANGE, tr("%1 is now known as %2").arg( mask.nick() ).arg( message->param(0)));
223 223
224 /* new code starts here -- this removes the person from all channels */ 224 /* new code starts here -- this removes the person from all channels */
225 QList<IRCChannel> channels; 225 QList<IRCChannel> channels;
226 m_session->getChannelsByPerson(person, channels); 226 m_session->getChannelsByPerson(person, channels);
227 QListIterator<IRCChannel> it(channels); 227 QListIterator<IRCChannel> it(channels);
228 for (;it.current(); ++it) { 228 for (;it.current(); ++it) {
229 IRCChannelPerson *chanperson = it.current()->getPerson(mask.nick()); 229 IRCChannelPerson *chanperson = it.current()->getPerson(mask.nick());
230 it.current()->removePerson(chanperson); 230 it.current()->removePerson(chanperson);
231 chanperson->person->setNick(message->param(0)); 231 chanperson->person->setNick(message->param(0));
232 it.current()->addPerson(chanperson); 232 it.current()->addPerson(chanperson);
233 IRCOutput output(OUTPUT_NICKCHANGE, tr("%1 is now known as %2").arg( mask.nick() ).arg( message->param(0))); 233 IRCOutput output(OUTPUT_NICKCHANGE, tr("%1 is now known as %2").arg( mask.nick() ).arg( message->param(0)));
234 output.addParam(person); 234 output.addParam(person);
235 emit outputReady(output); 235 emit outputReady(output);
236 } 236 }
237 /* new code ends here */ 237 /* new code ends here */
238 } else { 238 } else {
239 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Nickname change of an unknown person"))); 239 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Nickname change of an unknown person")));
240 } 240 }
241 } 241 }
242} 242}
243 243
244void IRCMessageParser::parseLiteralQuit(IRCMessage *message) { 244void IRCMessageParser::parseLiteralQuit(IRCMessage *message) {
245 IRCPerson mask(message->prefix()); 245 IRCPerson mask(message->prefix());
246 IRCPerson *person = m_session->getPerson(mask.nick()); 246 IRCPerson *person = m_session->getPerson(mask.nick());
247 if (person) { 247 if (person) {
248 QList<IRCChannel> channels; 248 QList<IRCChannel> channels;
249 m_session->getChannelsByPerson(person, channels); 249 m_session->getChannelsByPerson(person, channels);
250 QListIterator<IRCChannel> it(channels); 250 QListIterator<IRCChannel> it(channels);
251 for (;it.current(); ++it) { 251 for (;it.current(); ++it) {
252 IRCChannelPerson *chanperson = it.current()->getPerson(mask.nick()); 252 IRCChannelPerson *chanperson = it.current()->getPerson(mask.nick());
253 it.current()->removePerson(chanperson); 253 it.current()->removePerson(chanperson);
254 delete chanperson; 254 delete chanperson;
255 } 255 }
256 m_session->removePerson(person); 256 m_session->removePerson(person);
257 IRCOutput output(OUTPUT_QUIT, tr("%1 has quit (%2)" ).arg( mask.nick() ).arg( message->param(0) )); 257 IRCOutput output(OUTPUT_QUIT, tr("%1 has quit (%2)" ).arg( mask.nick() ).arg( message->param(0) ));
258 output.addParam(person); 258 output.addParam(person);
259 emit outputReady(output); 259 emit outputReady(output);
260 delete person; 260 delete person;
261 } else { 261 } else {
262 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Unknown person quit - desynchronized?"))); 262 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Unknown person quit - desynchronized?")));
263 } 263 }
264} 264}
265 265
266void IRCMessageParser::parseLiteralTopic(IRCMessage *message) { 266void IRCMessageParser::parseLiteralTopic(IRCMessage *message) {
267 IRCPerson mask(message->prefix()); 267 IRCPerson mask(message->prefix());
268 IRCChannel *channel = m_session->getChannel(message->param(0).lower()); 268 IRCChannel *channel = m_session->getChannel(message->param(0).lower());
269 if (channel) { 269 if (channel) {
270 IRCOutput output(OUTPUT_TOPIC, mask.nick() + tr(" changed topic to ") + "\"" + message->param(1) + "\""); 270 IRCOutput output(OUTPUT_TOPIC, mask.nick() + tr(" changed topic to ") + "\"" + message->param(1) + "\"");
271 output.addParam(channel); 271 output.addParam(channel);
272 emit outputReady(output); 272 emit outputReady(output);
273 } else { 273 } else {
274 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Unknown channel topic - desynchronized?"))); 274 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Unknown channel topic - desynchronized?")));
275 } 275 }
276} 276}
277 277
278void IRCMessageParser::parseLiteralError(IRCMessage *message) { 278void IRCMessageParser::parseLiteralError(IRCMessage *message) {
279 emit outputReady(IRCOutput(OUTPUT_ERROR, message->allParameters())); 279 emit outputReady(IRCOutput(OUTPUT_ERROR, message->allParameters()));
280} 280}
281 281
282void IRCMessageParser::parseCTCPPing(IRCMessage *message) { 282void IRCMessageParser::parseCTCPPing(IRCMessage *message) {
283 IRCPerson mask(message->prefix()); 283 IRCPerson mask(message->prefix());
284 m_session->m_connection->sendCTCP(mask.nick(), "PING " + message->allParameters()); 284 m_session->m_connection->sendCTCP(mask.nick(), "PING " + message->allParameters());
285 emit outputReady(IRCOutput(OUTPUT_CTCP, tr("Received a CTCP PING from ")+mask.nick())); 285 emit outputReady(IRCOutput(OUTPUT_CTCP, tr("Received a CTCP PING from ")+mask.nick()));
286
287 //IRCPerson mask(message->prefix());
288 QString dest = message->ctcpDestination();
289 if (dest.startsWith("#")) {
290 IRCChannel *channel = m_session->getChannel(dest.lower());
291 if (channel) {
292 IRCChannelPerson *person = channel->getPerson(mask.nick());
293 if (person) {
294 IRCOutput output(OUTPUT_CHANACTION, tr("Received a CTCP PING from ")+ mask.nick()) ;
295 output.addParam(channel);
296 output.addParam(person);
297 emit outputReady(output);
298 } else {
299 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("CTCP PING with unknown person - Desynchronized?")));
300 }
301 } else {
302 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("CTCP PING with unknown channel - Desynchronized?")));
303 }
304 } else {
305 if (message->ctcpDestination() == m_session->m_server->nick()) {
306 IRCPerson *person = m_session->getPerson(mask.nick());
307 if (!person) {
308 /* Person not yet known, create and add to the current session */
309 person = new IRCPerson(message->prefix());
310 m_session->addPerson(person);
311 }
312 IRCOutput output(OUTPUT_QUERYACTION, tr("Received a CTCP PING from ")+ mask.nick() );
313 output.addParam(person);
314 emit outputReady(output);
315 } else {
316 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("CTCP PING with bad recipient")));
317 }
318 }
319
286} 320}
287 321
288void IRCMessageParser::parseCTCPVersion(IRCMessage *message) { 322void IRCMessageParser::parseCTCPVersion(IRCMessage *message) {
289 IRCPerson mask(message->prefix()); 323 IRCPerson mask(message->prefix());
290 m_session->m_connection->sendCTCP(mask.nick(), APP_VERSION " " APP_COPYSTR); 324 m_session->m_connection->sendCTCP(mask.nick(), APP_VERSION " " APP_COPYSTR);
291 emit outputReady(IRCOutput(OUTPUT_CTCP, tr("Received a CTCP VERSION from ")+mask.nick())); 325 emit outputReady(IRCOutput(OUTPUT_CTCP, tr("Received a CTCP VERSION from ")+mask.nick()));
292} 326}
293 327
294void IRCMessageParser::parseCTCPAction(IRCMessage *message) { 328void IRCMessageParser::parseCTCPAction(IRCMessage *message) {
295 IRCPerson mask(message->prefix()); 329 IRCPerson mask(message->prefix());
296 QString dest = message->ctcpDestination(); 330 QString dest = message->ctcpDestination();
297 if (dest.startsWith("#")) { 331 if (dest.startsWith("#")) {
298 IRCChannel *channel = m_session->getChannel(dest.lower()); 332 IRCChannel *channel = m_session->getChannel(dest.lower());
299 if (channel) { 333 if (channel) {
300 IRCChannelPerson *person = channel->getPerson(mask.nick()); 334 IRCChannelPerson *person = channel->getPerson(mask.nick());
301 if (person) { 335 if (person) {
302 IRCOutput output(OUTPUT_CHANACTION, "*" + mask.nick() + message->param(0)); 336 IRCOutput output(OUTPUT_CHANACTION, "*" + mask.nick() + message->param(0));
303 output.addParam(channel); 337 output.addParam(channel);
304 output.addParam(person); 338 output.addParam(person);
305 emit outputReady(output); 339 emit outputReady(output);
306 } else { 340 } else {
307 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("CTCP ACTION with unknown person - Desynchronized?"))); 341 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("CTCP ACTION with unknown person - Desynchronized?")));
308 } 342 }
309 } else { 343 } else {
310 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("CTCP ACTION with unknown channel - Desynchronized?"))); 344 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("CTCP ACTION with unknown channel - Desynchronized?")));
311 } 345 }
312 } else { 346 } else {
313 if (message->ctcpDestination() == m_session->m_server->nick()) { 347 if (message->ctcpDestination() == m_session->m_server->nick()) {
314 IRCPerson *person = m_session->getPerson(mask.nick()); 348 IRCPerson *person = m_session->getPerson(mask.nick());
315 if (!person) { 349 if (!person) {
316 /* Person not yet known, create and add to the current session */ 350 /* Person not yet known, create and add to the current session */
317 person = new IRCPerson(message->prefix()); 351 person = new IRCPerson(message->prefix());
318 m_session->addPerson(person); 352 m_session->addPerson(person);
319 } 353 }
320 IRCOutput output(OUTPUT_QUERYACTION, "*" + mask.nick() + message->param(0)); 354 IRCOutput output(OUTPUT_QUERYACTION, "*" + mask.nick() + message->param(0));
321 output.addParam(person); 355 output.addParam(person);
322 emit outputReady(output); 356 emit outputReady(output);
323 } else { 357 } else {
324 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("CTCP ACTION with bad recipient"))); 358 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("CTCP ACTION with bad recipient")));
325 } 359 }
326 } 360 }
327} 361}
328 362
329void IRCMessageParser::parseLiteralMode(IRCMessage *message) { 363void IRCMessageParser::parseLiteralMode(IRCMessage *message) {
330 IRCPerson mask(message->prefix()); 364 IRCPerson mask(message->prefix());
331 365
332 if (message->param(0).startsWith("#")) { 366 if (message->param(0).startsWith("#")) {
333 IRCChannel *channel = m_session->getChannel(message->param(0).lower()); 367 IRCChannel *channel = m_session->getChannel(message->param(0).lower());
334 if (channel) { 368 if (channel) {
335 QString temp, parameters = message->allParameters().right(message->allParameters().length() - channel->channelname().length() - 1); 369 QString temp, parameters = message->allParameters().right(message->allParameters().length() - channel->channelname().length() - 1);
336 QTextIStream stream(&parameters); 370 QTextIStream stream(&parameters);
337 bool set = FALSE; 371 bool set = FALSE;
338 while (!stream.atEnd()) { 372 while (!stream.atEnd()) {
339 stream >> temp; 373 stream >> temp;
340 if (temp.startsWith("+")) { 374 if (temp.startsWith("+")) {
341 set = TRUE; 375 set = TRUE;
342 temp = temp.right(1); 376 temp = temp.right(1);
343 } else if (temp.startsWith("-")) { 377 } else if (temp.startsWith("-")) {
344 set = FALSE; 378 set = FALSE;
345 temp = temp.right(1); 379 temp = temp.right(1);
346 } else { 380 } else {
347 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Mode change has unknown type"))); 381 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Mode change has unknown type")));
348 return; 382 return;
349 } 383 }
350 if (temp == "o") { 384 if (temp == "o") {
351 stream >> temp; 385 stream >> temp;
352 IRCChannelPerson *person = channel->getPerson(temp); 386 IRCChannelPerson *person = channel->getPerson(temp);
353 if (person) { 387 if (person) {
354 if (set) { 388 if (set) {
355 person->flags |= PERSON_FLAG_OP; 389 person->flags |= PERSON_FLAG_OP;
356 IRCOutput output(OUTPUT_CHANPERSONMODE, mask.nick() + tr(" gives channel operator status to " + person->person->nick())); 390 IRCOutput output(OUTPUT_CHANPERSONMODE, mask.nick() + tr(" gives channel operator status to " + person->person->nick()));
357 output.addParam(channel); 391 output.addParam(channel);
358 output.addParam(person); 392 output.addParam(person);
359 emit outputReady(output); 393 emit outputReady(output);
360 } else { 394 } else {
361 person->flags &= 0xFFFF - PERSON_FLAG_OP; 395 person->flags &= 0xFFFF - PERSON_FLAG_OP;
362 IRCOutput output(OUTPUT_CHANPERSONMODE, mask.nick() + tr(" removes channel operator status from " + person->person->nick())); 396 IRCOutput output(OUTPUT_CHANPERSONMODE, mask.nick() + tr(" removes channel operator status from " + person->person->nick()));
363 output.addParam(channel); 397 output.addParam(channel);
364 output.addParam(person); 398 output.addParam(person);
365 emit outputReady(output); 399 emit outputReady(output);
366 } 400 }
367 } else { 401 } else {
368 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Mode change with unknown person - Desynchronized?"))); 402 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Mode change with unknown person - Desynchronized?")));
369 } 403 }
370 } else if (temp == "v") { 404 } else if (temp == "v") {
371 stream >> temp; 405 stream >> temp;
372 IRCChannelPerson *person = channel->getPerson(temp); 406 IRCChannelPerson *person = channel->getPerson(temp);
373 if (person) { 407 if (person) {
374 if (set) { 408 if (set) {
375 person->flags |= PERSON_FLAG_VOICE; 409 person->flags |= PERSON_FLAG_VOICE;
376 IRCOutput output(OUTPUT_CHANPERSONMODE, mask.nick() + tr(" gives voice to " + person->person->nick())); 410 IRCOutput output(OUTPUT_CHANPERSONMODE, mask.nick() + tr(" gives voice to " + person->person->nick()));
377 output.addParam(channel); 411 output.addParam(channel);
378 output.addParam(person); 412 output.addParam(person);
379 emit outputReady(output); 413 emit outputReady(output);
380 } else { 414 } else {
381 person->flags &= 0xFFFF - PERSON_FLAG_VOICE; 415 person->flags &= 0xFFFF - PERSON_FLAG_VOICE;
382 IRCOutput output(OUTPUT_CHANPERSONMODE, mask.nick() + tr(" removes voice from " + person->person->nick())); 416 IRCOutput output(OUTPUT_CHANPERSONMODE, mask.nick() + tr(" removes voice from " + person->person->nick()));
383 output.addParam(channel); 417 output.addParam(channel);
384 output.addParam(person); 418 output.addParam(person);
385 emit outputReady(output); 419 emit outputReady(output);
386 } 420 }
387 } else { 421 } else {
388 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Mode change with unknown person - Desynchronized?"))); 422 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Mode change with unknown person - Desynchronized?")));
389 } 423 }
390 } else { 424 } else {
391 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Mode change with unknown flag"))); 425 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Mode change with unknown flag")));
392 } 426 }
393 } 427 }
394 } else { 428 } else {
395 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Mode change with unknown kannel - Desynchronized?"))); 429 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Mode change with unknown kannel - Desynchronized?")));
396 } 430 }
397 } else { 431 } else {
398 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("User modes not supported yet"))); 432 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("User modes not supported yet")));
399 } 433 }
400} 434}
401 435
402void IRCMessageParser::parseLiteralKick(IRCMessage *message) { 436void IRCMessageParser::parseLiteralKick(IRCMessage *message) {
403 IRCPerson mask(message->prefix()); 437 IRCPerson mask(message->prefix());
404 IRCChannel *channel = m_session->getChannel(message->param(0).lower()); 438 IRCChannel *channel = m_session->getChannel(message->param(0).lower());
405 if (channel) { 439 if (channel) {
406 IRCChannelPerson *person = channel->getPerson(message->param(1)); 440 IRCChannelPerson *person = channel->getPerson(message->param(1));
407 if (person) { 441 if (person) {
408 if (person->person->nick() == m_session->m_server->nick()) { 442 if (person->person->nick() == m_session->m_server->nick()) {
409 m_session->removeChannel(channel); 443 m_session->removeChannel(channel);
410 IRCOutput output(OUTPUT_SELFKICK, tr("You were kicked from ") + channel->channelname() + tr(" by ") + mask.nick() + " (" + message->param(2) + ")"); 444 IRCOutput output(OUTPUT_SELFKICK, tr("You were kicked from ") + channel->channelname() + tr(" by ") + mask.nick() + " (" + message->param(2) + ")");
411 output.addParam(channel); 445 output.addParam(channel);
412 emit outputReady(output); 446 emit outputReady(output);
413 } else { 447 } else {
414 /* someone else got kicked */ 448 /* someone else got kicked */
415 channel->removePerson(person); 449 channel->removePerson(person);
416 IRCOutput output(OUTPUT_OTHERKICK, person->person->nick() + tr(" was kicked from ") + channel->channelname() + tr(" by ") + mask.nick()+ " (" + message->param(2) + ")"); 450 IRCOutput output(OUTPUT_OTHERKICK, person->person->nick() + tr(" was kicked from ") + channel->channelname() + tr(" by ") + mask.nick()+ " (" + message->param(2) + ")");
417 output.addParam(channel); 451 output.addParam(channel);
418 output.addParam(person); 452 output.addParam(person);
419 emit outputReady(output); 453 emit outputReady(output);
420 } 454 }
421 } else { 455 } else {
422 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Unknown person kick - desynchronized?"))); 456 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Unknown person kick - desynchronized?")));
423 } 457 }
424 } else { 458 } else {
425 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Unknown channel kick - desynchronized?"))); 459 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Unknown channel kick - desynchronized?")));
426 } 460 }
427} 461}
428 462
429void IRCMessageParser::parseNumerical001(IRCMessage *message) { 463void IRCMessageParser::parseNumerical001(IRCMessage *message) {
430 /* Welcome to IRC message, display */ 464 /* Welcome to IRC message, display */
431 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->param(1))); 465 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->param(1)));
432} 466}
433 467
434void IRCMessageParser::parseNumerical002(IRCMessage *message) { 468void IRCMessageParser::parseNumerical002(IRCMessage *message) {
435 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->param(1))); 469 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->param(1)));
436} 470}
437 471
438void IRCMessageParser::parseNumerical003(IRCMessage *message) { 472void IRCMessageParser::parseNumerical003(IRCMessage *message) {
439 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->param(1))); 473 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->param(1)));
440} 474}
441 475
442void IRCMessageParser::parseNumerical004(IRCMessage *message) { 476void IRCMessageParser::parseNumerical004(IRCMessage *message) {
443 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->allParameters())); 477 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->allParameters()));
444} 478}
445 479
446void IRCMessageParser::parseNumerical005(IRCMessage *message) { 480void IRCMessageParser::parseNumerical005(IRCMessage *message) {
447 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->allParameters())); 481 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->allParameters()));
448} 482}
449 483
450void IRCMessageParser::parseNumericalStats(IRCMessage *message) { 484void IRCMessageParser::parseNumericalStats(IRCMessage *message) {
451 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->param(1))); 485 emit outputReady(IRCOutput(OUTPUT_SERVERMESSAGE, message->param(1)));
452} 486}
453 487
454void IRCMessageParser::parseNumericalNames(IRCMessage *message) { 488void IRCMessageParser::parseNumericalNames(IRCMessage *message) {
455 /* Name list sent when joining a channel */ 489 /* Name list sent when joining a channel */
456 IRCChannel *channel = m_session->getChannel(message->param(2).lower()); 490 IRCChannel *channel = m_session->getChannel(message->param(2).lower());
457 if (channel != 0) { 491 if (channel != 0) {
458 QString people = message->param(3); 492 QString people = message->param(3);
459 QTextIStream stream(&people); 493 QTextIStream stream(&people);
460 QString temp; 494 QString temp;
461 495
462 while (!stream.atEnd()) { 496 while (!stream.atEnd()) {
463 stream >> temp; 497 stream >> temp;
464 498
465 char flagch = temp.at(0).latin1(); 499 char flagch = temp.at(0).latin1();
466 int flag = 0; 500 int flag = 0;
467 QString nick; 501 QString nick;
468 /* Parse person flags */ 502 /* Parse person flags */
469 if (flagch == '@' || flagch == '+' || flagch=='%' || flagch == '*') { 503 if (flagch == '@' || flagch == '+' || flagch=='%' || flagch == '*') {
470 504
471 nick = temp.right(temp.length()-1); 505 nick = temp.right(temp.length()-1);
472 switch (flagch) { 506 switch (flagch) {
473 case '@': flag = PERSON_FLAG_OP; break; 507 case '@': flag = PERSON_FLAG_OP; break;
474 case '+': flag = PERSON_FLAG_VOICE; break; 508 case '+': flag = PERSON_FLAG_VOICE; break;
475 case '%': flag = PERSON_FLAG_HALFOP; break; 509 case '%': flag = PERSON_FLAG_HALFOP; break;
476 default : flag = 0; break; 510 default : flag = 0; break;
477 } 511 }
478 } else { 512 } else {
479 nick = temp; 513 nick = temp;
480 } 514 }
481 515
482 IRCChannelPerson *chan_person = new IRCChannelPerson(); 516 IRCChannelPerson *chan_person = new IRCChannelPerson();
483 IRCPerson *person = m_session->getPerson(nick); 517 IRCPerson *person = m_session->getPerson(nick);
484 if (person == 0) { 518 if (person == 0) {
485 person = new IRCPerson(); 519 person = new IRCPerson();
486 person->setNick(nick); 520 person->setNick(nick);
487 m_session->addPerson(person); 521 m_session->addPerson(person);
488 } 522 }
489 chan_person->person = person; 523 chan_person->person = person;
490 chan_person->flags = flag; 524 chan_person->flags = flag;
491 channel->addPerson(chan_person); 525 channel->addPerson(chan_person);
492 } 526 }
493 } else { 527 } else {
494 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Server message with unknown channel"))); 528 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Server message with unknown channel")));
495 } 529 }
496} 530}
497 531
498void IRCMessageParser::parseNumericalEndOfNames(IRCMessage *message) { 532void IRCMessageParser::parseNumericalEndOfNames(IRCMessage *message) {
499 /* Done syncing to channel */ 533 /* Done syncing to channel */
500 IRCChannel *channel = m_session->getChannel(message->param(1).lower()); 534 IRCChannel *channel = m_session->getChannel(message->param(1).lower());
501 if (channel) { 535 if (channel) {
502 channel->setHasPeople(TRUE); 536 channel->setHasPeople(TRUE);
503 /* Yes, we want the names before anything happens inside the GUI */ 537 /* Yes, we want the names before anything happens inside the GUI */
504 IRCOutput output(OUTPUT_SELFJOIN, tr("You joined channel ") + channel->channelname()); 538 IRCOutput output(OUTPUT_SELFJOIN, tr("You joined channel ") + channel->channelname());
505 output.addParam(channel); 539 output.addParam(channel);
506 emit outputReady(output); 540 emit outputReady(output);
507 } else { 541 } else {
508 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Server message with unknown channel"))); 542 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Server message with unknown channel")));
509 } 543 }
510} 544}
511 545
512 546
513void IRCMessageParser::parseNumericalNicknameInUse(IRCMessage *) { 547void IRCMessageParser::parseNumericalNicknameInUse(IRCMessage *) {
514 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Nickname is in use, please reconnect with a different nickname"))); 548 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("Nickname is in use, please reconnect with a different nickname")));
515 m_session->endSession(); 549 m_session->endSession();
516} 550}
517 551
518void IRCMessageParser::parseNumericalNoSuchNick(IRCMessage *) { 552void IRCMessageParser::parseNumericalNoSuchNick(IRCMessage *) {
519 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("No such nickname"))); 553 emit outputReady(IRCOutput(OUTPUT_ERROR, tr("No such nickname")));
520} 554}
521 555
522void IRCMessageParser::parseNumericalTopic(IRCMessage *message) { 556void IRCMessageParser::parseNumericalTopic(IRCMessage *message) {
523 IRCChannel *channel = m_session->getChannel(message->param(1).lower()); 557 IRCChannel *channel = m_session->getChannel(message->param(1).lower());
524 if (channel) { 558 if (channel) {
525 IRCOutput output(OUTPUT_TOPIC, tr("Topic for channel " + channel->channelname() + " is \"" + message->param(2) + "\"")); 559 IRCOutput output(OUTPUT_TOPIC, tr("Topic for channel " + channel->channelname() + " is \"" + message->param(2) + "\""));
526 output.addParam(channel); 560 output.addParam(channel);
527 emit outputReady(output); 561 emit outputReady(output);
528 } else { 562 } else {
529 IRCOutput output(OUTPUT_TOPIC, tr("Topic for channel " + message->param(1) + " is \"" + message->param(2) + "\"")); 563 IRCOutput output(OUTPUT_TOPIC, tr("Topic for channel " + message->param(1) + " is \"" + message->param(2) + "\""));
530 output.addParam(0); 564 output.addParam(0);
531 emit outputReady(output); 565 emit outputReady(output);
532 } 566 }
533} 567}
534 568
535void IRCMessageParser::parseNumericalTopicWhoTime(IRCMessage *) { 569void IRCMessageParser::parseNumericalTopicWhoTime(IRCMessage *) {
536} 570}
diff --git a/noncore/net/opieirc/ircmisc.cpp b/noncore/net/opieirc/ircmisc.cpp
index 9b9bff8..6fc5ba0 100644
--- a/noncore/net/opieirc/ircmisc.cpp
+++ b/noncore/net/opieirc/ircmisc.cpp
@@ -1,133 +1,138 @@
1#include "ircmisc.h" 1#include "ircmisc.h"
2 2
3/* OPIE */ 3/* OPIE */
4#include <opie2/odebug.h> 4#include <opie2/odebug.h>
5#include <opie2/oconfig.h> 5#include <opie2/oconfig.h>
6#include <opie2/okeyconfigmanager.h> 6#include <opie2/okeyconfigmanager.h>
7using namespace Opie::Core; 7using namespace Opie::Core;
8 8
9 9
10IRCTabBar::IRCTabBar(QWidget *parent, const char *name) : QTabBar(parent, name) { 10IRCTabBar::IRCTabBar(QWidget *parent, const char *name) : QTabBar(parent, name) {
11} 11}
12 12
13int IRCTabBar::insertTab(QTab *tab, int index) { 13int IRCTabBar::insertTab(QTab *tab, int index) {
14 /* FIXME: find some nicer way to do this */ 14 /* FIXME: find some nicer way to do this */
15 QExtTab *ext = new QExtTab(); 15 QExtTab *ext = new QExtTab();
16 ext->color = black; 16 ext->color = black;
17 ext->label = tab->text(); 17 ext->label = tab->text();
18 ext->r = tab->rect(); 18 ext->r = tab->rect();
19 ext->enabled = tab->isEnabled(); 19 ext->enabled = tab->isEnabled();
20 ext->iconset = tab->iconSet(); 20 ext->iconset = tab->iconSet();
21 delete tab; 21 delete tab;
22 return QTabBar::insertTab(ext, index); 22 return QTabBar::insertTab(ext, index);
23} 23}
24 24
25void IRCTabBar::setTabColor(int index, QColor color) { 25void IRCTabBar::setTabColor(int index, QColor color) {
26 ((QExtTab *)tab(index))->color = color; 26 ((QExtTab *)tab(index))->color = color;
27 update(); 27 update();
28} 28}
29 29
30void IRCTabBar::paintLabel(QPainter* p, const QRect& br, QTab* t, bool focus) const { 30void IRCTabBar::paintLabel(QPainter* p, const QRect& br, QTab* t, bool focus) const {
31 QRect r = br; 31 QRect r = br;
32 QTabBar::paintLabel(p, br, t, focus); 32 QTabBar::paintLabel(p, br, t, focus);
33 if (t->id == currentTab()) 33 if (t->id == currentTab())
34 r.setBottom(r.bottom() - style().defaultFrameWidth()); 34 r.setBottom(r.bottom() - style().defaultFrameWidth());
35 p->setPen(((QExtTab *)t)->color); 35 p->setPen(((QExtTab *)t)->color);
36 p->drawText(r, AlignCenter | ShowPrefix, t->label); 36 p->drawText(r, AlignCenter | ShowPrefix, t->label);
37} 37}
38 38
39IRCTabWidget::IRCTabWidget(QWidget *parent, const char *name) : QTabWidget(parent, name) { 39IRCTabWidget::IRCTabWidget(QWidget *parent, const char *name) : QTabWidget(parent, name) {
40 setTabBar(new IRCTabBar(this, "tab control")); 40 setTabBar(new IRCTabBar(this, "tab control"));
41} 41}
42 42
43void IRCTabWidget::setTabColor(int index, QColor color) { 43void IRCTabWidget::setTabColor(int index, QColor color) {
44 ((IRCTabBar *)tabBar())->setTabColor(index, color); 44 ((IRCTabBar *)tabBar())->setTabColor(index, color);
45} 45}
46 46
47 47
48 48
49static OKeyConfigManager* s_manager = 0; 49static OKeyConfigManager* s_manager = 0;
50OKeyConfigManager* IRCHistoryLineEdit::keyConfigInstance() { 50OKeyConfigManager* IRCHistoryLineEdit::keyConfigInstance() {
51 if ( !s_manager ) { 51 if ( !s_manager ) {
52 /* 52 /*
53 * black list with the DeviceButtons as default 53 * black list with the DeviceButtons as default
54 * because we do not grab the keyboard and they 54 * because we do not grab the keyboard and they
55 * wouldn't work 55 * wouldn't work
56 */ 56 */
57 OKeyPair::List blackList = OKeyPair::hardwareKeys(); 57 OKeyPair::List blackList = OKeyPair::hardwareKeys();
58 blackList.append( OKeyPair::returnKey() ); 58 blackList.append( OKeyPair::returnKey() );
59 blackList.append( OKeyPair::leftArrowKey() ); 59 blackList.append( OKeyPair::leftArrowKey() );
60 blackList.append( OKeyPair::upArrowKey() ); 60 blackList.append( OKeyPair::upArrowKey() );
61 blackList.append( OKeyPair::downArrowKey() ); 61 blackList.append( OKeyPair::downArrowKey() );
62 62
63 s_manager = new OKeyConfigManager(new OConfig("opieirc-keys"), 63 s_manager = new OKeyConfigManager(new OConfig("opieirc-keys"),
64 "keys", blackList, 64 "keys", blackList,
65 false, 0, "irc_history_line_keyconfigm" ); 65 false, 0, "irc_history_line_keyconfigm" );
66 s_manager->addKeyConfig( OKeyConfigItem( tr("Next Tab"), "next_tab", QPixmap(), 66 s_manager->addKeyConfig( OKeyConfigItem( tr("Next Tab"), "next_tab", QPixmap(),
67 KeyNextTab, OKeyPair(Qt::Key_N, Qt::ControlButton) )); 67 KeyNextTab, OKeyPair(Qt::Key_N, Qt::ControlButton) ));
68 s_manager->addKeyConfig( OKeyConfigItem( tr("Previous Tab"), "prev_tab", QPixmap(), 68 s_manager->addKeyConfig( OKeyConfigItem( tr("Previous Tab"), "prev_tab", QPixmap(),
69 KeyPrevTab, OKeyPair(Qt::Key_P, Qt::ControlButton) )); 69 KeyPrevTab, OKeyPair(Qt::Key_P, Qt::ControlButton) ));
70 s_manager->addKeyConfig( OKeyConfigItem( tr("Close Tab"), "close_tab",
71 QPixmap(), KeyCloseTab,
72 OKeyPair(Qt::Key_C, Qt::ControlButton) ));
70 s_manager->load(); 73 s_manager->load();
71 } 74 }
72 75
73 return s_manager; 76 return s_manager;
74} 77}
75 78
76 79
77IRCHistoryLineEdit::IRCHistoryLineEdit(QWidget *parent, const char *name) : QLineEdit(parent, name) { 80IRCHistoryLineEdit::IRCHistoryLineEdit(QWidget *parent, const char *name) : QLineEdit(parent, name) {
78 m_index = -1; 81 m_index = -1;
79 installEventFilter(this); 82 installEventFilter(this);
80} 83}
81 84
82void IRCHistoryLineEdit::keyPressEvent(QKeyEvent *event) { 85void IRCHistoryLineEdit::keyPressEvent(QKeyEvent *event) {
83 int key = event->key(); 86 int key = event->key();
84 if (key == Key_Up) { 87 if (key == Key_Up) {
85 if (m_history.count() > 0 && m_index < (signed int)m_history.count()-1) { 88 if (m_history.count() > 0 && m_index < (signed int)m_history.count()-1) {
86 m_index++; 89 m_index++;
87 setText(m_history[m_index]); 90 setText(m_history[m_index]);
88 } 91 }
89 } else if (key == Key_Down) { 92 } else if (key == Key_Down) {
90 if (m_history.count() > 0 && m_index > 0) { 93 if (m_history.count() > 0 && m_index > 0) {
91 m_index--; 94 m_index--;
92 setText(m_history[m_index]); 95 setText(m_history[m_index]);
93 } 96 }
94 if (m_index == 0) { 97 if (m_index == 0) {
95 m_index = -1; 98 m_index = -1;
96 setText(""); 99 setText("");
97 } 100 }
98 } else if (key == Key_Return) { 101 } else if (key == Key_Return) {
99 m_history.prepend(text()); 102 m_history.prepend(text());
100 m_index = -1; 103 m_index = -1;
101 } 104 }
102 105
103 switch( keyConfigInstance()->handleKeyEventId( event ) ) { 106 switch( keyConfigInstance()->handleKeyEventId( event ) ) {
104 case KeyNextTab: 107 case KeyNextTab:
105 emit nextTab(); 108 emit nextTab();
106 return; 109 return;
107 case KeyPrevTab: 110 case KeyPrevTab:
108 emit prevTab(); 111 emit prevTab();
109 return; 112 return;
113 case KeyCloseTab:
114 emit closeTab();
110 default: 115 default:
111 break; 116 break;
112 } 117 }
113 118
114 QLineEdit::keyPressEvent(event); 119 QLineEdit::keyPressEvent(event);
115} 120}
116 121
117bool IRCHistoryLineEdit::eventFilter(QObject *object, QEvent *event) { 122bool IRCHistoryLineEdit::eventFilter(QObject *object, QEvent *event) {
118 if (event->type() == QEvent::KeyPress) { 123 if (event->type() == QEvent::KeyPress) {
119 QKeyEvent *k = (QKeyEvent *) event; 124 QKeyEvent *k = (QKeyEvent *) event;
120 /* Catch tab characters */ 125 /* Catch tab characters */
121 if (k->key() == Key_Tab) { 126 if (k->key() == Key_Tab) {
122 emit nextTab(); 127 emit nextTab();
123 return TRUE; 128 return TRUE;
124 } 129 }
125 } 130 }
126 return QLineEdit::eventFilter(object, event); 131 return QLineEdit::eventFilter(object, event);
127} 132}
128 133
129 134
130void IRCHistoryLineEdit::setEditFocus() { 135void IRCHistoryLineEdit::setEditFocus() {
131 setActiveWindow(); 136 setActiveWindow();
132 setFocus(); 137 setFocus();
133} 138}
diff --git a/noncore/net/opieirc/ircmisc.h b/noncore/net/opieirc/ircmisc.h
index 37eed28..3cf64df 100644
--- a/noncore/net/opieirc/ircmisc.h
+++ b/noncore/net/opieirc/ircmisc.h
@@ -1,93 +1,94 @@
1/* 1/*
2 OpieIRC - An embedded IRC client 2 OpieIRC - An embedded IRC client
3 Copyright (C) 2002 Wenzel Jakob 3 Copyright (C) 2002 Wenzel Jakob
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
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 __IRCMISC_H 21#ifndef __IRCMISC_H
22#define __IRCMISC_H 22#define __IRCMISC_H
23 23
24#include <qtabwidget.h> 24#include <qtabwidget.h>
25#include <qlineedit.h> 25#include <qlineedit.h>
26#include <qtabbar.h> 26#include <qtabbar.h>
27#include <qlabel.h> 27#include <qlabel.h>
28#include <qcolor.h> 28#include <qcolor.h>
29#include <qarray.h> 29#include <qarray.h>
30 30
31namespace Opie { 31namespace Opie {
32namespace Core { 32namespace Core {
33class OKeyConfigManager; 33class OKeyConfigManager;
34} 34}
35} 35}
36 36
37 37
38/* Custom colored QTabWidget */ 38/* Custom colored QTabWidget */
39 39
40class QExtTab : public QTab { 40class QExtTab : public QTab {
41public: 41public:
42 QColor color; 42 QColor color;
43}; 43};
44 44
45class IRCTabWidget : public QTabWidget { 45class IRCTabWidget : public QTabWidget {
46 Q_OBJECT 46 Q_OBJECT
47public: 47public:
48 IRCTabWidget(QWidget *parent = 0, const char *name = 0); 48 IRCTabWidget(QWidget *parent = 0, const char *name = 0);
49 void setTabColor(int index, QColor color); 49 void setTabColor(int index, QColor color);
50}; 50};
51 51
52class IRCTabBar : public QTabBar { 52class IRCTabBar : public QTabBar {
53 Q_OBJECT 53 Q_OBJECT
54public: 54public:
55 IRCTabBar(QWidget *parent = 0, const char *name = 0); 55 IRCTabBar(QWidget *parent = 0, const char *name = 0);
56 void setTabColor(int index, QColor color); 56 void setTabColor(int index, QColor color);
57protected: 57protected:
58 void paintLabel(QPainter*, const QRect&, QTab*, bool) const; 58 void paintLabel(QPainter*, const QRect&, QTab*, bool) const;
59 int insertTab(QTab *, int index = -1); 59 int insertTab(QTab *, int index = -1);
60protected: 60protected:
61 QArray<QColor> m_colors; 61 QArray<QColor> m_colors;
62}; 62};
63 63
64/* A QLineEdit with history functionality and tab completion */ 64/* A QLineEdit with history functionality and tab completion */
65 65
66class IRCHistoryLineEdit : public QLineEdit { 66class IRCHistoryLineEdit : public QLineEdit {
67 Q_OBJECT 67 Q_OBJECT
68public: 68public:
69 enum KeyMode { 69 enum KeyMode {
70 KeyNextTab, 70 KeyNextTab,
71 KeyPrevTab 71 KeyPrevTab,
72 KeyCloseTab
72 }; 73 };
73 74
74 static Opie::Core::OKeyConfigManager* keyConfigInstance(); 75 static Opie::Core::OKeyConfigManager* keyConfigInstance();
75 76
76 IRCHistoryLineEdit(QWidget *parent = 0, const char *name = 0); 77 IRCHistoryLineEdit(QWidget *parent = 0, const char *name = 0);
77 virtual bool eventFilter(QObject *object, QEvent *event); 78 virtual bool eventFilter(QObject *object, QEvent *event);
78public slots: 79public slots:
79 void setEditFocus(); 80 void setEditFocus();
80signals: 81signals:
81 void nextTab(); 82 void nextTab();
82 void prevTab(); 83 void prevTab();
83 void closeTab(); 84 void closeTab();
84 85
85 86
86protected: 87protected:
87 void keyPressEvent(QKeyEvent *); 88 void keyPressEvent(QKeyEvent *);
88protected: 89protected:
89 QStringList m_history; 90 QStringList m_history;
90 int m_index; 91 int m_index;
91}; 92};
92 93
93#endif /* __IRCMISC_H */ 94#endif /* __IRCMISC_H */
diff --git a/noncore/net/opieirc/ircquerytab.cpp b/noncore/net/opieirc/ircquerytab.cpp
index 1fddc6d..53474b9 100644
--- a/noncore/net/opieirc/ircquerytab.cpp
+++ b/noncore/net/opieirc/ircquerytab.cpp
@@ -1,112 +1,115 @@
1#include <qhbox.h> 1#include <qhbox.h>
2#include <qwhatsthis.h> 2#include <qwhatsthis.h>
3#include "ircquerytab.h" 3#include "ircquerytab.h"
4#include "ircservertab.h" 4#include "ircservertab.h"
5 5
6IRCQueryTab::IRCQueryTab(IRCPerson *person, IRCServerTab *parentTab, MainWindow *mainWindow, QWidget *parent, const char *name, WFlags f) : IRCTab(parent, name, f) { 6IRCQueryTab::IRCQueryTab(IRCPerson *person, IRCServerTab *parentTab, MainWindow *mainWindow, QWidget *parent, const char *name, WFlags f) : IRCTab(parent, name, f) {
7 m_mainWindow = mainWindow; 7 m_mainWindow = mainWindow;
8 m_parentTab = parentTab; 8 m_parentTab = parentTab;
9 m_lines = 0; 9 m_lines = 0;
10 m_person = new IRCPerson(*person); /* We need this (the person might sign off and the original IRCPerson gets deleted) */ 10 m_person = new IRCPerson(*person); /* We need this (the person might sign off and the original IRCPerson gets deleted) */
11 m_description->setText(tr("Talking to ") + " <b>" + person->nick() + "</b>"); 11 m_description->setText(tr("Talking to ") + " <b>" + person->nick() + "</b>");
12 QHBox *hbox = new QHBox(this); 12 QHBox *hbox = new QHBox(this);
13 m_textview = new QTextView(hbox); 13 m_textview = new QTextView(hbox);
14 m_textview->setHScrollBarMode(QScrollView::AlwaysOff); 14 m_textview->setHScrollBarMode(QScrollView::AlwaysOff);
15 m_textview->setVScrollBarMode(QScrollView::AlwaysOn); 15 m_textview->setVScrollBarMode(QScrollView::AlwaysOn);
16 m_textview->setTextFormat(RichText); 16 m_textview->setTextFormat(RichText);
17 QWhatsThis::add(m_textview, tr("Private discussion")); 17 QWhatsThis::add(m_textview, tr("Private discussion"));
18 m_field = new IRCHistoryLineEdit(this); 18 m_field = new IRCHistoryLineEdit(this);
19
19 connect(m_field, SIGNAL(nextTab()), this, SIGNAL(nextTab())); 20 connect(m_field, SIGNAL(nextTab()), this, SIGNAL(nextTab()));
20 connect(m_field, SIGNAL(prevTab()), this, SIGNAL(prevTab())); 21 connect(m_field, SIGNAL(prevTab()), this, SIGNAL(prevTab()));
21 connect(m_field, SIGNAL(closeTab()),this, SIGNAL(closeTab())); 22 connect(m_field, SIGNAL(closeTab()),this, SLOT(remove()));
22 23 connect(this, SIGNAL(editFocus()), m_field, SLOT(setEditFocus()));
23 24
24 QWhatsThis::add(m_field, tr("Type your text here in order to send a message to the other person")); 25 QWhatsThis::add(m_field, tr("Type your text here in order to send a message to the other person"));
25 m_layout->add(hbox); 26 m_layout->add(hbox);
26 hbox->show(); 27 hbox->show();
27 m_layout->add(m_field); 28 m_layout->add(m_field);
28 m_field->setFocus(); 29
29 connect(m_field, SIGNAL(returnPressed()), this, SLOT(processCommand())); 30 connect(m_field, SIGNAL(returnPressed()), this, SLOT(processCommand()));
30 connect(m_mainWindow, SIGNAL(updateScroll()), this, SLOT(scrolling())); 31 connect(m_mainWindow, SIGNAL(updateScroll()), this, SLOT(scrolling()));
31 settingsChanged(); 32 settingsChanged();
33 m_field->setFocus();
34 m_field->setActiveWindow();
32} 35}
33 36
34void IRCQueryTab::scrolling(){ 37void IRCQueryTab::scrolling(){
35 m_textview->ensureVisible(0, m_textview->contentsHeight()); 38 m_textview->ensureVisible(0, m_textview->contentsHeight());
36} 39}
37 40
38 41
39void IRCQueryTab::appendText(QString text) { 42void IRCQueryTab::appendText(QString text) {
40 /* not using append because it creates layout problems */ 43 /* not using append because it creates layout problems */
41 QString txt = m_textview->text() + text + "\n"; 44 QString txt = m_textview->text() + text + "\n";
42 if (m_maxLines > 0 && m_lines >= m_maxLines) { 45 if (m_maxLines > 0 && m_lines >= m_maxLines) {
43 int firstBreak = txt.find('\n'); 46 int firstBreak = txt.find('\n');
44 if (firstBreak != -1) { 47 if (firstBreak != -1) {
45 txt = "<qt bgcolor=\"" + m_backgroundColor + "\"/>" + txt.right(txt.length() - (firstBreak + 1)); 48 txt = "<qt bgcolor=\"" + m_backgroundColor + "\"/>" + txt.right(txt.length() - (firstBreak + 1));
46 } 49 }
47 } else { 50 } else {
48 m_lines++; 51 m_lines++;
49 } 52 }
50 m_textview->setText(txt); 53 m_textview->setText(txt);
51 m_textview->ensureVisible(0, m_textview->contentsHeight()); 54 m_textview->ensureVisible(0, m_textview->contentsHeight());
52 55
53 if ( IRCServerTab::containsPing( text, m_parentTab ) ) 56 if ( IRCServerTab::containsPing( text, m_parentTab ) )
54 emit ping( title() ); 57 emit ping( title() );
55 58
56 emit changed(this); 59 emit changed(this);
57} 60}
58 61
59IRCQueryTab::~IRCQueryTab() { 62IRCQueryTab::~IRCQueryTab() {
60 m_parentTab->removeQueryTab(this); 63 m_parentTab->removeQueryTab(this);
61 delete m_person; 64 delete m_person;
62} 65}
63 66
64void IRCQueryTab::processCommand() { 67void IRCQueryTab::processCommand() {
65 QString text = m_field->text(); 68 QString text = m_field->text();
66 if (text.length()>0) { 69 if (text.length()>0) {
67 if (session()->isSessionActive()) { 70 if (session()->isSessionActive()) {
68 if (text.startsWith("/") && !text.startsWith("//")) { 71 if (text.startsWith("/") && !text.startsWith("//")) {
69 /* Command mode */ 72 /* Command mode */
70 m_parentTab->executeCommand(this, text);; 73 m_parentTab->executeCommand(this, text);;
71 } else { 74 } else {
72 if (text.startsWith("//")) 75 if (text.startsWith("//"))
73 text = text.right(text.length()-1); 76 text = text.right(text.length()-1);
74 session()->sendMessage(m_person, m_field->text()); 77 session()->sendMessage(m_person, m_field->text());
75 appendText("<font color=\"" + m_textColor + "\">&lt;</font><font color=\"" + m_selfColor + "\">"+m_parentTab->server()->nick()+"</font><font color=\"" + m_textColor + "\">&gt; "+IRCOutput::toHTML(m_field->text())+"</font><br>"); 78 appendText("<font color=\"" + m_textColor + "\">&lt;</font><font color=\"" + m_selfColor + "\">"+m_parentTab->server()->nick()+"</font><font color=\"" + m_textColor + "\">&gt; "+IRCOutput::toHTML(m_field->text())+"</font><br>");
76 } 79 }
77 } else { 80 } else {
78 appendText("<font color=\"" + m_errorColor + "\">"+tr("Disconnected")+"</font><br>"); 81 appendText("<font color=\"" + m_errorColor + "\">"+tr("Disconnected")+"</font><br>");
79 } 82 }
80 } 83 }
81 m_field->clear(); 84 m_field->clear();
82} 85}
83 86
84void IRCQueryTab::display(IRCOutput output) { 87void IRCQueryTab::display(IRCOutput output) {
85 if (output.type() == OUTPUT_QUERYPRIVMSG) { 88 if (output.type() == OUTPUT_QUERYPRIVMSG) {
86 appendText("<font color=\"" + m_textColor + "\">&lt;</font><font color=\"" + m_otherColor + "\">"+m_person->nick()+"</font><font color=\"" + m_textColor + "\">&gt; " + output.htmlMessage() + "</font><br>"); 89 appendText("<font color=\"" + m_textColor + "\">&lt;</font><font color=\"" + m_otherColor + "\">"+m_person->nick()+"</font><font color=\"" + m_textColor + "\">&gt; " + output.htmlMessage() + "</font><br>");
87 } else if (output.type() == OUTPUT_QUERYACTION) { 90 } else if (output.type() == OUTPUT_QUERYACTION) {
88 appendText("<font color=\"" + m_otherColor + "\">" + output.htmlMessage() + "<br>"); 91 appendText("<font color=\"" + m_otherColor + "\">" + output.htmlMessage() + "<br>");
89 } 92 }
90} 93}
91 94
92void IRCQueryTab::settingsChanged() { 95void IRCQueryTab::settingsChanged() {
93 m_textview->setText("<qt bgcolor=\"" + m_backgroundColor + "\"/>"); 96 m_textview->setText("<qt bgcolor=\"" + m_backgroundColor + "\"/>");
94 m_lines = 0; 97 m_lines = 0;
95} 98}
96 99
97QString IRCQueryTab::title() { 100QString IRCQueryTab::title() {
98 return m_person->nick(); 101 return m_person->nick();
99} 102}
100 103
101IRCSession *IRCQueryTab::session() { 104IRCSession *IRCQueryTab::session() {
102 return m_parentTab->session(); 105 return m_parentTab->session();
103} 106}
104 107
105void IRCQueryTab::remove() { 108void IRCQueryTab::remove() {
106 m_mainWindow->killTab(this); 109 m_mainWindow->killTab(this);
107} 110}
108 111
109IRCPerson *IRCQueryTab::person() { 112IRCPerson *IRCQueryTab::person() {
110 return m_person; 113 return m_person;
111} 114}
112 115
diff --git a/noncore/net/opieirc/ircserverlist.cpp b/noncore/net/opieirc/ircserverlist.cpp
index 62bfc17..3e78469 100644
--- a/noncore/net/opieirc/ircserverlist.cpp
+++ b/noncore/net/opieirc/ircserverlist.cpp
@@ -1,161 +1,170 @@
1 1
2#include "ircserverlist.h" 2#include "ircserverlist.h"
3#include "ircservereditor.h" 3#include "ircservereditor.h"
4 4
5/* OPIE */ 5/* OPIE */
6#include <qpe/qpeapplication.h> 6#include <qpe/qpeapplication.h>
7 7
8/* QT */ 8/* QT */
9#include <qlayout.h> 9#include <qlayout.h>
10#include <qlabel.h> 10#include <qlabel.h>
11#include <qhbox.h> 11#include <qhbox.h>
12#include <qpushbutton.h> 12#include <qpushbutton.h>
13#include <qwhatsthis.h> 13#include <qwhatsthis.h>
14 14
15class IRCListBoxServer : public QListBoxText 15class IRCListBoxServer : public QListBoxText
16{ 16{
17public: 17public:
18 IRCListBoxServer(IRCServer server) : QListBoxText(server.name()) 18 IRCListBoxServer(IRCServer server) : QListBoxText(server.name())
19 { 19 {
20 m_server = server; 20 m_server = server;
21 } 21 }
22 22
23 IRCServer server() 23 IRCServer server()
24 { 24 {
25 return m_server; 25 return m_server;
26 } 26 }
27 27
28 void setServer(IRCServer server) 28 void setServer(IRCServer server)
29 { 29 {
30 m_server = server; 30 m_server = server;
31 setText(m_server.name()); 31 setText(m_server.name());
32 } 32 }
33protected: 33protected:
34 IRCServer m_server; 34 IRCServer m_server;
35}; 35};
36 36
37IRCServerList::IRCServerList(QWidget* parent, const char *name, bool modal, WFlags) : QDialog(parent, name, modal, WStyle_ContextHelp) 37IRCServerList::IRCServerList(QWidget* parent, const char *name, bool modal, WFlags) : QDialog(parent, name, modal, WStyle_ContextHelp)
38{ 38{
39 QVBoxLayout *layout = new QVBoxLayout(this, 5, 5); 39 QVBoxLayout *layout = new QVBoxLayout(this, 5, 5);
40 setCaption(tr("Serverlist Browser")); 40 setCaption(tr("Serverlist Browser"));
41 QLabel *label = new QLabel(tr("Please choose a server profile"), this); 41 QLabel *label = new QLabel(tr("Please choose a server profile"), this);
42 label->setAlignment(AlignHCenter); 42 label->setAlignment(AlignHCenter);
43 layout->addWidget(label); 43 layout->addWidget(label);
44 m_list = new QListBox(this); 44 m_list = new QListBox(this);
45 QWhatsThis::add(m_list, tr("Select a server profile from this list and then tap on OK in the upper-right corner")); 45 QWhatsThis::add(m_list, tr("Select a server profile from this list and then tap on OK in the upper-right corner"));
46 layout->addWidget(m_list); 46 layout->addWidget(m_list);
47 QHBox *buttons = new QHBox(this); 47 QHBox *buttons = new QHBox(this);
48 QPushButton *del = new QPushButton(tr("Delete"), buttons); 48 QPushButton *del = new QPushButton(tr("Delete"), buttons);
49 QPushButton *edit = new QPushButton(tr("Edit"), buttons); 49 QPushButton *edit = new QPushButton(tr("Edit"), buttons);
50 QPushButton *add = new QPushButton(tr("Add"), buttons); 50 QPushButton *add = new QPushButton(tr("Add"), buttons);
51 QWhatsThis::add(del, tr("Delete the currently selected server profile")); 51 QWhatsThis::add(del, tr("Delete the currently selected server profile"));
52 QWhatsThis::add(edit, tr("Edit the currently selected server profile")); 52 QWhatsThis::add(edit, tr("Edit the currently selected server profile"));
53 QWhatsThis::add(add, tr("Add a new server profile")); 53 QWhatsThis::add(add, tr("Add a new server profile"));
54 connect(del, SIGNAL(clicked()), this, SLOT(delServer())); 54 connect(del, SIGNAL(clicked()), this, SLOT(delServer()));
55 connect(edit, SIGNAL(clicked()), this, SLOT(editServer())); 55 connect(edit, SIGNAL(clicked()), this, SLOT(editServer()));
56 connect(add, SIGNAL(clicked()), this, SLOT(addServer())); 56 connect(add, SIGNAL(clicked()), this, SLOT(addServer()));
57 layout->addWidget(buttons); 57 layout->addWidget(buttons);
58 /* Load the configuration file */ 58 /* Load the configuration file */
59 m_config = new Config("OpieIRC"); 59 m_config = new Config("OpieIRC");
60 m_config->setGroup("OpieIRC"); 60 m_config->setGroup("OpieIRC");
61 int count = m_config->readNumEntry("ServerCount", 0); 61 int count = m_config->readNumEntry("ServerCount", 0);
62 if (count) 62 if (count)
63 { 63 {
64 for (int i=0; i<count; i++) 64 for (int i=0; i<count; i++)
65 { 65 {
66 m_config->setGroup("OpieIRC"); 66 m_config->setGroup("OpieIRC");
67 QString name = m_config->readEntry("Server"+QString::number(i)); 67 QString name = m_config->readEntry("Server"+QString::number(i));
68 if (name.length() > 0) 68 if (name.length() > 0)
69 { 69 {
70 IRCServer server; 70 IRCServer server;
71 m_config->setGroup(name); 71 m_config->setGroup(name);
72 server.setName(name); 72 server.setName(name);
73 server.setHostname(m_config->readEntry("Hostname")); 73 server.setHostname(m_config->readEntry("Hostname"));
74 server.setPort(m_config->readNumEntry("Port")); 74 server.setPort(m_config->readNumEntry("Port"));
75 server.setUsername(m_config->readEntry("Username")); 75 server.setUsername(m_config->readEntry("Username"));
76 server.setPassword(m_config->readEntry("Password")); 76 server.setPassword(m_config->readEntry("Password"));
77 server.setNick(m_config->readEntry("Nick")); 77 server.setNick(m_config->readEntry("Nick"));
78 server.setRealname(m_config->readEntry("Realname")); 78 server.setRealname(m_config->readEntry("Realname"));
79 server.setChannels(m_config->readEntry("Channels")); 79 server.setChannels(m_config->readEntry("Channels"));
80 m_list->insertItem(new IRCListBoxServer(server)); 80 m_list->insertItem(new IRCListBoxServer(server));
81 } 81 }
82 } 82 }
83 } 83 }
84 84
85 connect(m_list, SIGNAL(doubleClicked(QListBoxItem*)),
86 this, SLOT(acceptOnClick(QListBoxItem *)));
87 connect(m_list, SIGNAL(returnPressed(QListBoxItem*)),
88 this, SLOT(acceptOnClick(QListBoxItem*)));
89
85 QPEApplication::showDialog( this ); 90 QPEApplication::showDialog( this );
86} 91}
87 92
88void IRCServerList::addServer() 93void IRCServerList::addServer()
89{ 94{
90 IRCServer server; 95 IRCServer server;
91 IRCServerEditor editor(server, this, "ServerEditor", TRUE); 96 IRCServerEditor editor(server, this, "ServerEditor", TRUE);
92 if (editor.exec() == QDialog::Accepted) 97 if (editor.exec() == QDialog::Accepted)
93 { 98 {
94 server = editor.getServer(); 99 server = editor.getServer();
95 /* Gets deleted by QListBox, so this is ok */ 100 /* Gets deleted by QListBox, so this is ok */
96 m_list->insertItem(new IRCListBoxServer(server)); 101 m_list->insertItem(new IRCListBoxServer(server));
97 } 102 }
98} 103}
99 104
100void IRCServerList::delServer() 105void IRCServerList::delServer()
101{ 106{
102 int index = m_list->currentItem(); 107 int index = m_list->currentItem();
103 if (index != -1) 108 if (index != -1)
104 { 109 {
105 m_list->removeItem(index); 110 m_list->removeItem(index);
106 } 111 }
107} 112}
108 113
109void IRCServerList::editServer() 114void IRCServerList::editServer()
110{ 115{
111 int index = m_list->currentItem(); 116 int index = m_list->currentItem();
112 if (index != -1) 117 if (index != -1)
113 { 118 {
114 IRCListBoxServer *item = (IRCListBoxServer *)m_list->item(index); 119 IRCListBoxServer *item = (IRCListBoxServer *)m_list->item(index);
115 IRCServer server = item->server(); 120 IRCServer server = item->server();
116 IRCServerEditor editor(server, this, "ServerEditor", TRUE); 121 IRCServerEditor editor(server, this, "ServerEditor", TRUE);
117 if (editor.exec() == QDialog::Accepted) 122 if (editor.exec() == QDialog::Accepted)
118 { 123 {
119 server = editor.getServer(); 124 server = editor.getServer();
120 item->setServer(server); 125 item->setServer(server);
121 } 126 }
122 } 127 }
123} 128}
124 129
130void IRCServerList::acceptOnClick( QListBoxItem* ) {
131 accept();
132}
133
125int IRCServerList::exec() 134int IRCServerList::exec()
126{ 135{
127 int returncode = QDialog::exec(); 136 int returncode = QDialog::exec();
128 /* Now save the changes */ 137 /* Now save the changes */
129 m_config->setGroup("OpieIRC"); 138 m_config->setGroup("OpieIRC");
130 m_config->writeEntry("ServerCount", QString::number(m_list->count())); 139 m_config->writeEntry("ServerCount", QString::number(m_list->count()));
131 for (unsigned int i=0; i<m_list->count(); i++) 140 for (unsigned int i=0; i<m_list->count(); i++)
132 { 141 {
133 IRCServer server = ((IRCListBoxServer *)m_list->item(i))->server(); 142 IRCServer server = ((IRCListBoxServer *)m_list->item(i))->server();
134 m_config->setGroup("OpieIRC"); 143 m_config->setGroup("OpieIRC");
135 m_config->writeEntry("Server"+QString::number(i), server.name()); 144 m_config->writeEntry("Server"+QString::number(i), server.name());
136 m_config->setGroup(server.name()); 145 m_config->setGroup(server.name());
137 m_config->writeEntry("Hostname", server.hostname()); 146 m_config->writeEntry("Hostname", server.hostname());
138 m_config->writeEntry("Port", QString::number(server.port())); 147 m_config->writeEntry("Port", QString::number(server.port()));
139 m_config->writeEntry("Username", server.username()); 148 m_config->writeEntry("Username", server.username());
140 m_config->writeEntry("Password", server.password()); 149 m_config->writeEntry("Password", server.password());
141 m_config->writeEntry("Nick", server.nick()); 150 m_config->writeEntry("Nick", server.nick());
142 m_config->writeEntry("Realname", server.realname()); 151 m_config->writeEntry("Realname", server.realname());
143 m_config->writeEntry("Channels", server.channels()); 152 m_config->writeEntry("Channels", server.channels());
144 } 153 }
145 return returncode; 154 return returncode;
146} 155}
147 156
148bool IRCServerList::hasServer() 157bool IRCServerList::hasServer()
149{ 158{
150 return (m_list->currentItem() != -1); 159 return (m_list->currentItem() != -1);
151} 160}
152 161
153IRCServer IRCServerList::server() 162IRCServer IRCServerList::server()
154{ 163{
155 return ((IRCListBoxServer *)m_list->item(m_list->currentItem()))->server(); 164 return ((IRCListBoxServer *)m_list->item(m_list->currentItem()))->server();
156} 165}
157 166
158IRCServerList::~IRCServerList() 167IRCServerList::~IRCServerList()
159{ 168{
160 delete m_config; 169 delete m_config;
161} 170}
diff --git a/noncore/net/opieirc/ircserverlist.h b/noncore/net/opieirc/ircserverlist.h
index d61210e..869b26f 100644
--- a/noncore/net/opieirc/ircserverlist.h
+++ b/noncore/net/opieirc/ircserverlist.h
@@ -1,50 +1,51 @@
1/* 1/*
2 OpieIRC - An embedded IRC client 2 OpieIRC - An embedded IRC client
3 Copyright (C) 2002 Wenzel Jakob 3 Copyright (C) 2002 Wenzel Jakob
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
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 __IRCSERVERLIST_H 21#ifndef __IRCSERVERLIST_H
22#define __IRCSERVERLIST_H 22#define __IRCSERVERLIST_H
23 23
24#include <qdialog.h> 24#include <qdialog.h>
25#include <qpe/config.h> 25#include <qpe/config.h>
26#include <qlistbox.h> 26#include <qlistbox.h>
27#include <qlist.h> 27#include <qlist.h>
28#include "ircserver.h" 28#include "ircserver.h"
29 29
30class IRCServerList : public QDialog { 30class IRCServerList : public QDialog {
31 Q_OBJECT 31 Q_OBJECT
32public: 32public:
33 IRCServerList(QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags f = 0); 33 IRCServerList(QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags f = 0);
34 int exec(); 34 int exec();
35 /* Check whether a server was selected */ 35 /* Check whether a server was selected */
36 bool hasServer(); 36 bool hasServer();
37 /* Return the selected server */ 37 /* Return the selected server */
38 IRCServer server(); 38 IRCServer server();
39 39
40 ~IRCServerList(); 40 ~IRCServerList();
41public slots: 41public slots:
42 void addServer(); 42 void addServer();
43 void delServer(); 43 void delServer();
44 void editServer(); 44 void editServer();
45 void acceptOnClick(QListBoxItem*);
45protected: 46protected:
46 Config *m_config; 47 Config *m_config;
47 QListBox *m_list; 48 QListBox *m_list;
48}; 49};
49 50
50#endif /* __IRCSERVERLIST_H */ 51#endif /* __IRCSERVERLIST_H */
diff --git a/noncore/net/opieirc/ircservertab.cpp b/noncore/net/opieirc/ircservertab.cpp
index 2a34c0b..5ca7a29 100644
--- a/noncore/net/opieirc/ircservertab.cpp
+++ b/noncore/net/opieirc/ircservertab.cpp
@@ -1,384 +1,391 @@
1#include <qtextstream.h> 1#include <qtextstream.h>
2#include <qwhatsthis.h> 2#include <qwhatsthis.h>
3#include "ircservertab.h" 3#include "ircservertab.h"
4 4
5 5
6bool IRCServerTab::containsPing( const QString& text, IRCServerTab* tab ) { 6bool IRCServerTab::containsPing( const QString& text, IRCServerTab* tab ) {
7 return (text.find("ping") != -1 && text.find( tab->server()->nick() != -1)); 7 return (text.contains(IRCMessageParser::tr("Received a CTCP PING from "))) ||
8 (text.find("ping") != -1 && text.find( tab->server()->nick() != -1));
8} 9}
9 10
10 11
11IRCServerTab::IRCServerTab(IRCServer server, MainWindow *mainWindow, QWidget *parent, const char *name, WFlags f) : IRCTab(parent, name, f) { 12IRCServerTab::IRCServerTab(IRCServer server, MainWindow *mainWindow, QWidget *parent, const char *name, WFlags f) : IRCTab(parent, name, f) {
12 m_server = server; 13 m_server = server;
13 m_session = new IRCSession(&m_server); 14 m_session = new IRCSession(&m_server);
14 m_mainWindow = mainWindow; 15 m_mainWindow = mainWindow;
15 m_close = FALSE; 16 m_close = FALSE;
16 m_lines = 0; 17 m_lines = 0;
17 m_description->setText(tr("Connection to")+" <b>" + server.hostname() + ":" + QString::number(server.port()) + "</b>"); 18 m_description->setText(tr("Connection to")+" <b>" + server.hostname() + ":" + QString::number(server.port()) + "</b>");
18 m_textview = new QTextView(this); 19 m_textview = new QTextView(this);
19 m_textview->setHScrollBarMode(QScrollView::AlwaysOff); 20 m_textview->setHScrollBarMode(QScrollView::AlwaysOff);
20 m_textview->setVScrollBarMode(QScrollView::AlwaysOn); 21 m_textview->setVScrollBarMode(QScrollView::AlwaysOn);
21 m_textview->setTextFormat(RichText); 22 m_textview->setTextFormat(RichText);
22 QWhatsThis::add(m_textview, tr("Server messages")); 23 QWhatsThis::add(m_textview, tr("Server messages"));
23 m_layout->add(m_textview); 24 m_layout->add(m_textview);
24 m_field = new IRCHistoryLineEdit(this); 25 m_field = new IRCHistoryLineEdit(this);
25 connect(m_field, SIGNAL(nextTab()), this, SIGNAL(nextTab())); 26 connect(m_field, SIGNAL(nextTab()), this, SIGNAL(nextTab()));
26 connect(m_field, SIGNAL(prevTab()), this, SIGNAL(prevTab())); 27 connect(m_field, SIGNAL(prevTab()), this, SIGNAL(prevTab()));
27 connect(m_field, SIGNAL(closeTab()), this, SIGNAL(closeTab())); 28 connect(m_field, SIGNAL(closeTab()), this, SIGNAL(closeTab()));
28 connect(this, SIGNAL(editFocus()), m_field, SLOT(setEditFocus())); 29 connect(this, SIGNAL(editFocus()), m_field, SLOT(setEditFocus()));
29 30
30 QWhatsThis::add(m_field, tr("Type commands here. A list of available commands can be found inside the OpieIRC help")); 31 QWhatsThis::add(m_field, tr("Type commands here. A list of available commands can be found inside the OpieIRC help"));
31 m_layout->add(m_field); 32 m_layout->add(m_field);
32 connect(m_field, SIGNAL(returnPressed()), this, SLOT(processCommand())); 33 connect(m_field, SIGNAL(returnPressed()), this, SLOT(processCommand()));
33 m_field->setFocus();
34 connect(m_session, SIGNAL(outputReady(IRCOutput)), this, SLOT(display(IRCOutput))); 34 connect(m_session, SIGNAL(outputReady(IRCOutput)), this, SLOT(display(IRCOutput)));
35 connect(m_mainWindow, SIGNAL(updateScroll()), this, SLOT(scrolling())); 35 connect(m_mainWindow, SIGNAL(updateScroll()), this, SLOT(scrolling()));
36 settingsChanged(); 36 settingsChanged();
37
38 m_field->setFocus();
39 m_field->setActiveWindow();
40
37} 41}
38 42
39void IRCServerTab::scrolling(){ 43void IRCServerTab::scrolling(){
40 m_textview->ensureVisible(0, m_textview->contentsHeight()); 44 m_textview->ensureVisible(0, m_textview->contentsHeight());
41} 45}
42 46
43 47
44void IRCServerTab::appendText(QString text) { 48void IRCServerTab::appendText(QString text) {
45 /* not using append because it creates layout problems */ 49 /* not using append because it creates layout problems */
46 QString txt = m_textview->text() + text + "\n"; 50 QString txt = m_textview->text() + IRCTab::appendTimestamp( text );
51
52
53
47 if (m_maxLines > 0 && m_lines >= m_maxLines) { 54 if (m_maxLines > 0 && m_lines >= m_maxLines) {
48 int firstBreak = txt.find('\n'); 55 int firstBreak = txt.find('\n');
49 if (firstBreak != -1) { 56 if (firstBreak != -1) {
50 txt = "<qt bgcolor=\"" + m_backgroundColor + "\"/>" + txt.right(txt.length() - (firstBreak + 1)); 57 txt = "<qt bgcolor=\"" + m_backgroundColor + "\"/>" + txt.right(txt.length() - (firstBreak + 1));
51 } 58 }
52 } else { 59 } else {
53 m_lines++; 60 m_lines++;
54 } 61 }
55 m_textview->setText(txt); 62 m_textview->setText(txt);
56 m_textview->ensureVisible(0, m_textview->contentsHeight()); 63 m_textview->ensureVisible(0, m_textview->contentsHeight());
57 emit changed(this); 64 emit changed(this);
58} 65}
59 66
60IRCServerTab::~IRCServerTab() { 67IRCServerTab::~IRCServerTab() {
61 delete m_session; 68 delete m_session;
62} 69}
63 70
64void IRCServerTab::removeChannelTab(IRCChannelTab *tab) { 71void IRCServerTab::removeChannelTab(IRCChannelTab *tab) {
65 m_channelTabs.remove(tab); 72 m_channelTabs.remove(tab);
66} 73}
67 74
68void IRCServerTab::removeQueryTab(IRCQueryTab *tab) { 75void IRCServerTab::removeQueryTab(IRCQueryTab *tab) {
69 m_queryTabs.remove(tab); 76 m_queryTabs.remove(tab);
70} 77}
71 78
72void IRCServerTab::addQueryTab(IRCQueryTab *tab) { 79void IRCServerTab::addQueryTab(IRCQueryTab *tab) {
73 m_queryTabs.append(tab); 80 m_queryTabs.append(tab);
74} 81}
75 82
76QString IRCServerTab::title() { 83QString IRCServerTab::title() {
77 return "Server"; 84 return "Server";
78} 85}
79 86
80IRCSession *IRCServerTab::session() { 87IRCSession *IRCServerTab::session() {
81 return m_session; 88 return m_session;
82} 89}
83/* 90/*
84QString *IRCServerTab::mynick() { 91QString *IRCServerTab::mynick() {
85 return (*m_server->nick()); 92 return (*m_server->nick());
86} */ 93} */
87 94
88IRCServer *IRCServerTab::server() { 95IRCServer *IRCServerTab::server() {
89 return &m_server; 96 return &m_server;
90} 97}
91 98
92void IRCServerTab::settingsChanged() { 99void IRCServerTab::settingsChanged() {
93 m_textview->setText("<qt bgcolor=\"" + m_backgroundColor + "\"/>"); 100 m_textview->setText("<qt bgcolor=\"" + m_backgroundColor + "\"/>");
94 m_lines = 0; 101 m_lines = 0;
95} 102}
96 103
97void IRCServerTab::executeCommand(IRCTab *tab, QString line) { 104void IRCServerTab::executeCommand(IRCTab *tab, QString line) {
98 QTextIStream stream(&line); 105 QTextIStream stream(&line);
99 QString command; 106 QString command;
100 stream >> command; 107 stream >> command;
101 command = command.upper().right(command.length()-1); 108 command = command.upper().right(command.length()-1);
102 109
103 //JOIN 110 //JOIN
104 if (command == "JOIN" || command == "J") { 111 if (command == "JOIN" || command == "J") {
105 QString channel; 112 QString channel;
106 stream >> channel; 113 stream >> channel;
107 if (channel.length() > 0 && (channel.startsWith("#") || channel.startsWith("+"))) { 114 if (channel.length() > 0 && (channel.startsWith("#") || channel.startsWith("+"))) {
108 m_session->join(channel); 115 m_session->join(channel);
109 } else { 116 } else {
110 tab->appendText("<font color=\"" + m_errorColor + "\">Unknown channel format!</font><br>"); 117 tab->appendText("<font color=\"" + m_errorColor + "\">Unknown channel format!</font><br>");
111 } 118 }
112 } 119 }
113 120
114 //KICK 121 //KICK
115 else if (command == "KICK"){ 122 else if (command == "KICK"){
116 QString nickname; 123 QString nickname;
117 stream >> nickname; 124 stream >> nickname;
118 if (nickname.length() > 0) { 125 if (nickname.length() > 0) {
119 if (line.length() > 7 + nickname.length()) { 126 if (line.length() > 7 + nickname.length()) {
120 QString text = line.right(line.length()-nickname.length()-7); 127 QString text = line.right(line.length()-nickname.length()-7);
121 IRCPerson person; 128 IRCPerson person;
122 person.setNick(nickname); 129 person.setNick(nickname);
123 m_session->kick(((IRCChannelTab *)tab)->channel(), &person, text); 130 m_session->kick(((IRCChannelTab *)tab)->channel(), &person, text);
124 } else { 131 } else {
125 IRCPerson person; 132 IRCPerson person;
126 person.setNick(nickname); 133 person.setNick(nickname);
127 m_session->kick(((IRCChannelTab *)tab)->channel(), &person); 134 m_session->kick(((IRCChannelTab *)tab)->channel(), &person);
128 } 135 }
129 } 136 }
130 } 137 }
131 138
132 else if (command == "OP"){ 139 else if (command == "OP"){
133 QString nickname; 140 QString nickname;
134 stream >> nickname; 141 stream >> nickname;
135 if (nickname.length() > 0) { 142 if (nickname.length() > 0) {
136 QString text = line.right(line.length()-nickname.length()-5); 143 QString text = line.right(line.length()-nickname.length()-5);
137 IRCPerson person; 144 IRCPerson person;
138 person.setNick(nickname); 145 person.setNick(nickname);
139 m_session->op(((IRCChannelTab *)tab)->channel(), &person); 146 m_session->op(((IRCChannelTab *)tab)->channel(), &person);
140 } 147 }
141 } 148 }
142 149
143 //SEND MODES 150 //SEND MODES
144 else if (command == "MODE"){ 151 else if (command == "MODE"){
145 QString text = line.right(line.length()-6); 152 QString text = line.right(line.length()-6);
146 if (text.length() > 0) { 153 if (text.length() > 0) {
147 m_session->mode(text); 154 m_session->mode(text);
148 } else { 155 } else {
149 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>"); 156 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>");
150 } 157 }
151 } 158 }
152 //SEND RAW MESSAGE TO SERVER, COMPLETELY UNCHECKED - anything in the RFC...or really anything you want 159 //SEND RAW MESSAGE TO SERVER, COMPLETELY UNCHECKED - anything in the RFC...or really anything you want
153 else if (command == "RAW"){ 160 else if (command == "RAW"){
154 QString text = line.right(line.length()-5); 161 QString text = line.right(line.length()-5);
155 if (text.length() > 0) { 162 if (text.length() > 0) {
156 m_session->raw(text); 163 m_session->raw(text);
157 } 164 }
158 } 165 }
159 else if (command == "SUSPEND"){ 166 else if (command == "SUSPEND"){
160 QString text = line.right(line.length()-9); 167 QString text = line.right(line.length()-9);
161 if (text.upper() == "ON") { 168 if (text.upper() == "ON") {
162 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable; 169 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Enable;
163 } 170 }
164 else if (text.upper() == "OFF"){ 171 else if (text.upper() == "OFF"){
165 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Disable; 172 QCopEnvelope( "QPE/System", "setScreenSaverMode(int)" ) << QPEApplication::Disable;
166 } else { 173 } else {
167 tab->appendText("<font color=\"" + m_errorColor + "\">Line: "+ line +"</font><br>Text: "+text); 174 tab->appendText("<font color=\"" + m_errorColor + "\">Line: "+ line +"</font><br>Text: "+text);
168 } 175 }
169 } 176 }
170 177
171 else if (command == "QUIT"){ 178 else if (command == "QUIT"){
172 QString text = line.right(line.length()-6); 179 QString text = line.right(line.length()-6);
173 if (text.length() > 0) { 180 if (text.length() > 0) {
174 m_session->quit(text); 181 m_session->quit(text);
175 } else { 182 } else {
176 m_session->quit(); 183 m_session->quit();
177 } 184 }
178 } 185 }
179 186
180 //SEND ACTION 187 //SEND ACTION
181 else if (command == "ME") { 188 else if (command == "ME") {
182 QString text = line.right(line.length()-4); 189 QString text = line.right(line.length()-4);
183 if (text.length() > 0) { 190 if (text.length() > 0) {
184 if (tab->isA("IRCChannelTab")) { 191 if (tab->isA("IRCChannelTab")) {
185 tab->appendText("<font color=\"" + m_selfColor + "\">*" + IRCOutput::toHTML(m_server.nick()) + " " + IRCOutput::toHTML(text) + "</font><br>"); 192 tab->appendText("<font color=\"" + m_selfColor + "\">*" + IRCOutput::toHTML(m_server.nick()) + " " + IRCOutput::toHTML(text) + "</font><br>");
186 m_session->sendAction(((IRCChannelTab *)tab)->channel(), text); 193 m_session->sendAction(((IRCChannelTab *)tab)->channel(), text);
187 } else if (tab->isA("IRCQueryTab")) { 194 } else if (tab->isA("IRCQueryTab")) {
188 tab->appendText("<font color=\"" + m_selfColor + "\">*" + IRCOutput::toHTML(m_server.nick()) + " " + IRCOutput::toHTML(text) + "</font><br>"); 195 tab->appendText("<font color=\"" + m_selfColor + "\">*" + IRCOutput::toHTML(m_server.nick()) + " " + IRCOutput::toHTML(text) + "</font><br>");
189 m_session->sendAction(((IRCQueryTab *)tab)->person(), text); 196 m_session->sendAction(((IRCQueryTab *)tab)->person(), text);
190 } else { 197 } else {
191 tab->appendText("<font color=\"" + m_errorColor + "\">Invalid tab for this command</font><br>"); 198 tab->appendText("<font color=\"" + m_errorColor + "\">Invalid tab for this command</font><br>");
192 } 199 }
193 } 200 }
194 } 201 }
195 //SEND PRIVMSG 202 //SEND PRIVMSG
196 else if (command == "MSG") { 203 else if (command == "MSG") {
197 QString nickname; 204 QString nickname;
198 stream >> nickname; 205 stream >> nickname;
199 if (nickname.length() > 0) { 206 if (nickname.length() > 0) {
200 if (line.length() > 6 + nickname.length()) { 207 if (line.length() > 6 + nickname.length()) {
201 QString text = line.right(line.length()-nickname.length()-6); 208 QString text = line.right(line.length()-nickname.length()-6);
202 IRCPerson person; 209 IRCPerson person;
203 person.setNick(nickname); 210 person.setNick(nickname);
204 tab->appendText("<font color=\"" + m_textColor + "\">&gt;</font><font color=\"" + m_otherColor + "\">"+IRCOutput::toHTML(nickname)+"</font><font color=\"" + m_textColor + "\">&lt; "+IRCOutput::toHTML(text)+"</font><br>"); 211 tab->appendText("<font color=\"" + m_textColor + "\">&gt;</font><font color=\"" + m_otherColor + "\">"+IRCOutput::toHTML(nickname)+"</font><font color=\"" + m_textColor + "\">&lt; "+IRCOutput::toHTML(text)+"</font><br>");
205 m_session->sendMessage(&person, text); 212 m_session->sendMessage(&person, text);
206 } 213 }
207 } 214 }
208 } 215 }
209 else { 216 else {
210 tab->appendText("<font color=\"" + m_errorColor + "\">Unknown command</font><br>"); 217 tab->appendText("<font color=\"" + m_errorColor + "\">Unknown command</font><br>");
211 } 218 }
212} 219}
213 220
214void IRCServerTab::processCommand() { 221void IRCServerTab::processCommand() {
215 QString text = m_field->text(); 222 QString text = m_field->text();
216 if (text.startsWith("/") && !text.startsWith("//")) { 223 if (text.startsWith("/") && !text.startsWith("//")) {
217 /* Command mode */ 224 /* Command mode */
218 executeCommand(this, text); 225 executeCommand(this, text);
219 } 226 }
220 m_field->clear(); 227 m_field->clear();
221} 228}
222 229
223void IRCServerTab::doConnect() { 230void IRCServerTab::doConnect() {
224 m_session->beginSession(); 231 m_session->beginSession();
225} 232}
226 233
227void IRCServerTab::remove() { 234void IRCServerTab::remove() {
228 /* Close requested */ 235 /* Close requested */
229 if (m_session->isSessionActive()) { 236 if (m_session->isSessionActive()) {
230 /* While there is a running session */ 237 /* While there is a running session */
231 m_close = TRUE; 238 m_close = TRUE;
232 m_session->endSession(); 239 m_session->endSession();
233 } else { 240 } else {
234 /* Session has previously been closed */ 241 /* Session has previously been closed */
235 m_channelTabs.first(); 242 m_channelTabs.first();
236 while (m_channelTabs.current() != 0) { 243 while (m_channelTabs.current() != 0) {
237 m_mainWindow->killTab(m_channelTabs.current()); 244 m_mainWindow->killTab(m_channelTabs.current(), true);
238 } 245 }
239 m_queryTabs.first(); 246 m_queryTabs.first();
240 while (m_queryTabs.current() != 0) { 247 while (m_queryTabs.current() != 0) {
241 m_mainWindow->killTab(m_queryTabs.current()); 248 m_mainWindow->killTab(m_queryTabs.current(), true);
242 } 249 }
243 m_mainWindow->killTab(this); 250 m_mainWindow->killTab(this);
244 } 251 }
245} 252}
246 253
247IRCChannelTab *IRCServerTab::getTabForChannel(IRCChannel *channel) { 254IRCChannelTab *IRCServerTab::getTabForChannel(IRCChannel *channel) {
248 QListIterator<IRCChannelTab> it(m_channelTabs); 255 QListIterator<IRCChannelTab> it(m_channelTabs);
249 256
250 for (; it.current(); ++it) { 257 for (; it.current(); ++it) {
251 if (it.current()->channel() == channel) 258 if (it.current()->channel() == channel)
252 return it.current(); 259 return it.current();
253 } 260 }
254 return 0; 261 return 0;
255} 262}
256 263
257IRCQueryTab *IRCServerTab::getTabForQuery(IRCPerson *person) { 264IRCQueryTab *IRCServerTab::getTabForQuery(IRCPerson *person) {
258 QListIterator<IRCQueryTab> it(m_queryTabs); 265 QListIterator<IRCQueryTab> it(m_queryTabs);
259 266
260 for (; it.current(); ++it) { 267 for (; it.current(); ++it) {
261 if (it.current()->person()->nick() == person->nick()) 268 if (it.current()->person()->nick() == person->nick())
262 return it.current(); 269 return it.current();
263 } 270 }
264 return 0; 271 return 0;
265} 272}
266 273
267void IRCServerTab::display(IRCOutput output) { 274void IRCServerTab::display(IRCOutput output) {
268 275
269 /* All messages to be displayed inside the GUI get here */ 276 /* All messages to be displayed inside the GUI get here */
270 switch (output.type()) { 277 switch (output.type()) {
271 case OUTPUT_CONNCLOSE: 278 case OUTPUT_CONNCLOSE:
272 if (m_close) { 279 if (m_close) {
273 m_channelTabs.first(); 280 m_channelTabs.first();
274 while (m_channelTabs.current() != 0) { 281 while (m_channelTabs.current() != 0) {
275 m_mainWindow->killTab(m_channelTabs.current()); 282 m_mainWindow->killTab(m_channelTabs.current(), true);
276 } 283 }
277 m_queryTabs.first(); 284 m_queryTabs.first();
278 while (m_queryTabs.current() != 0) { 285 while (m_queryTabs.current() != 0) {
279 m_mainWindow->killTab(m_queryTabs.current()); 286 m_mainWindow->killTab(m_queryTabs.current(), true);
280 } 287 }
281 m_mainWindow->killTab(this); 288 m_mainWindow->killTab(this);
282 } else { 289 } else {
283 appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() +"</font><br>"); 290 appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() +"</font><br>");
284 QListIterator<IRCChannelTab> it(m_channelTabs); 291 QListIterator<IRCChannelTab> it(m_channelTabs);
285 for (; it.current(); ++it) { 292 for (; it.current(); ++it) {
286 it.current()->appendText("<font color=\"" + m_serverColor + "\">" + output.htmlMessage() +"</font><br>"); 293 it.current()->appendText("<font color=\"" + m_serverColor + "\">" + output.htmlMessage() +"</font><br>");
287 } 294 }
288 } 295 }
289 break; 296 break;
290 case OUTPUT_SELFJOIN: { 297 case OUTPUT_SELFJOIN: {
291 IRCChannelTab *channeltab = new IRCChannelTab((IRCChannel *)output.getParam(0), this, m_mainWindow, (QWidget *)parent()); 298 IRCChannelTab *channeltab = new IRCChannelTab((IRCChannel *)output.getParam(0), this, m_mainWindow, (QWidget *)parent());
292 m_channelTabs.append(channeltab); 299 m_channelTabs.append(channeltab);
293 m_mainWindow->addTab(channeltab); 300 m_mainWindow->addTab(channeltab);
294 } 301 }
295 break; 302 break;
296 case OUTPUT_CHANPRIVMSG: { 303 case OUTPUT_CHANPRIVMSG: {
297 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); 304 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0));
298 channelTab->appendText("<font color=\"" + m_textColor + "\">&lt;</font><font color=\"" + m_otherColor + "\">"+IRCOutput::toHTML(((IRCChannelPerson *)output.getParam(1))->person->nick())+"</font><font color=\"" + m_textColor + "\">&gt; " + output.htmlMessage()+"</font><br>"); 305 channelTab->appendText("<font color=\"" + m_textColor + "\">&lt;</font><font color=\"" + m_otherColor + "\">"+IRCOutput::toHTML(((IRCChannelPerson *)output.getParam(1))->person->nick())+"</font><font color=\"" + m_textColor + "\">&gt; " + output.htmlMessage()+"</font><br>");
299 } 306 }
300 break; 307 break;
301 case OUTPUT_QUERYACTION: 308 case OUTPUT_QUERYACTION:
302 case OUTPUT_QUERYPRIVMSG: { 309 case OUTPUT_QUERYPRIVMSG: {
303 IRCQueryTab *queryTab = getTabForQuery((IRCPerson *)output.getParam(0)); 310 IRCQueryTab *queryTab = getTabForQuery((IRCPerson *)output.getParam(0));
304 if (!queryTab) { 311 if (!queryTab) {
305 queryTab = new IRCQueryTab((IRCPerson *)output.getParam(0), this, m_mainWindow, (QWidget *)parent()); 312 queryTab = new IRCQueryTab((IRCPerson *)output.getParam(0), this, m_mainWindow, (QWidget *)parent());
306 m_queryTabs.append(queryTab); 313 m_queryTabs.append(queryTab);
307 m_mainWindow->addTab(queryTab); 314 m_mainWindow->addTab(queryTab);
308 } 315 }
309 queryTab->display(output); 316 queryTab->display(output);
310 } 317 }
311 break; 318 break;
312 case OUTPUT_SELFPART: { 319 case OUTPUT_SELFPART: {
313 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); 320 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0));
314 if (channelTab) 321 if (channelTab)
315 m_mainWindow->killTab(channelTab); 322 m_mainWindow->killTab(channelTab, true);
316 } 323 }
317 break; 324 break;
318 case OUTPUT_SELFKICK: { 325 case OUTPUT_SELFKICK: {
319 appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() + "</font><br>"); 326 appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() + "</font><br>");
320 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); 327 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0));
321 if (channelTab) 328 if (channelTab)
322 m_mainWindow->killTab(channelTab); 329 m_mainWindow->killTab(channelTab, true);
323 } 330 }
324 break; 331 break;
325 case OUTPUT_CHANACTION: { 332 case OUTPUT_CHANACTION: {
326 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); 333 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0));
327 channelTab->appendText("<font color=\"" + m_otherColor + "\">"+output.htmlMessage()+"</font><br>"); 334 channelTab->appendText("<font color=\"" + m_otherColor + "\">"+output.htmlMessage()+"</font><br>");
328 } 335 }
329 break; 336 break;
330 case OUTPUT_TOPIC: { 337 case OUTPUT_TOPIC: {
331 IRCChannel *channel = (IRCChannel *) output.getParam(0); 338 IRCChannel *channel = (IRCChannel *) output.getParam(0);
332 if (channel) { 339 if (channel) {
333 IRCChannelTab *channelTab = getTabForChannel(channel); 340 IRCChannelTab *channelTab = getTabForChannel(channel);
334 if (channelTab) { 341 if (channelTab) {
335 channelTab->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); 342 channelTab->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>");
336 return; 343 return;
337 } 344 }
338 } 345 }
339 appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); 346 appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>");
340 } 347 }
341 break; 348 break;
342 case OUTPUT_QUIT: { 349 case OUTPUT_QUIT: {
343 QString nick = ((IRCPerson *)output.getParam(0))->nick(); 350 QString nick = ((IRCPerson *)output.getParam(0))->nick();
344 QListIterator<IRCChannelTab> it(m_channelTabs); 351 QListIterator<IRCChannelTab> it(m_channelTabs);
345 for (; it.current(); ++it) { 352 for (; it.current(); ++it) {
346 if (it.current()->list()->hasPerson(nick)) { 353 if (it.current()->list()->hasPerson(nick)) {
347 it.current()->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); 354 it.current()->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>");
348 it.current()->list()->update(); 355 it.current()->list()->update();
349 } 356 }
350 } 357 }
351 } 358 }
352 break; 359 break;
353/* case OUTPUT_NICKCHANGE: { 360/* case OUTPUT_NICKCHANGE: {
354 //WAS HERE 361 //WAS HERE
355 QString nick = ((IRCPerson *)output.getParam(0))->nick(); 362 QString nick = ((IRCPerson *)output.getParam(0))->nick();
356 QListIterator<IRCChannelTab> it(m_channelTabs); 363 QListIterator<IRCChannelTab> it(m_channelTabs);
357 for (; it.current(); ++it) { 364 for (; it.current(); ++it) {
358 if (it.current()->list()->hasPerson(nick)) { 365 if (it.current()->list()->hasPerson(nick)) {
359 it.current()->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); 366 it.current()->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>");
360 it.current()->list()->update(); 367 it.current()->list()->update();
361 } 368 }
362 } 369 }
363 } 370 }
364 break; 371 break;
365 */ case OUTPUT_OTHERJOIN: 372 */ case OUTPUT_OTHERJOIN:
366 case OUTPUT_OTHERKICK: 373 case OUTPUT_OTHERKICK:
367 case OUTPUT_CHANPERSONMODE: 374 case OUTPUT_CHANPERSONMODE:
368 case OUTPUT_OTHERPART: { 375 case OUTPUT_OTHERPART: {
369 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0)); 376 IRCChannelTab *channelTab = getTabForChannel((IRCChannel *)output.getParam(0));
370 channelTab->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>"); 377 channelTab->appendText("<font color=\"" + m_notificationColor + "\">"+output.htmlMessage()+"</font><br>");
371 channelTab->list()->update(); 378 channelTab->list()->update();
372 } 379 }
373 break; 380 break;
374 case OUTPUT_CTCP: 381 case OUTPUT_CTCP:
375 appendText("<font color=\"" + m_notificationColor + "\">" + output.htmlMessage() + "</font><br>"); 382 appendText("<font color=\"" + m_notificationColor + "\">" + output.htmlMessage() + "</font><br>");
376 break; 383 break;
377 case OUTPUT_ERROR: 384 case OUTPUT_ERROR:
378 appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() + "</font><br>"); 385 appendText("<font color=\"" + m_errorColor + "\">" + output.htmlMessage() + "</font><br>");
379 break; 386 break;
380 default: 387 default:
381 appendText("<font color=\"" + m_serverColor + "\">" + output.htmlMessage() + "</font><br>"); 388 appendText("<font color=\"" + m_serverColor + "\">" + output.htmlMessage() + "</font><br>");
382 break; 389 break;
383 } 390 }
384} 391}
diff --git a/noncore/net/opieirc/ircsettings.cpp b/noncore/net/opieirc/ircsettings.cpp
index 1fba030..7a1dd6c 100644
--- a/noncore/net/opieirc/ircsettings.cpp
+++ b/noncore/net/opieirc/ircsettings.cpp
@@ -1,128 +1,144 @@
1 1
2#include "ircsettings.h" 2#include "ircsettings.h"
3#include "irctab.h" 3#include "irctab.h"
4#include "ircmisc.h" 4#include "ircmisc.h"
5 5
6/* OPIE */ 6/* OPIE */
7#include <opie2/ocolorbutton.h> 7#include <opie2/ocolorbutton.h>
8#include <opie2/otabwidget.h> 8#include <opie2/otabwidget.h>
9#include <opie2/okeyconfigwidget.h> 9#include <opie2/okeyconfigwidget.h>
10#include <qpe/qpeapplication.h> 10#include <qpe/qpeapplication.h>
11 11
12/* QT */ 12/* QT */
13#include <qvalidator.h> 13#include <qvalidator.h>
14#include <qwhatsthis.h> 14#include <qwhatsthis.h>
15#include <qcheckbox.h>
15 16
16using namespace Opie; 17using namespace Opie;
17using namespace Opie::Ui; 18using namespace Opie::Ui;
18IRCSettings::IRCSettings(QWidget* parent, const char* name, bool modal, WFlags) : QDialog(parent, name, modal, WStyle_ContextHelp) 19IRCSettings::IRCSettings(QWidget* parent, const char* name, bool modal, WFlags) : QDialog(parent, name, modal, WStyle_ContextHelp)
19{ 20{
20 setCaption(tr("Settings") ); 21 setCaption(tr("Settings") );
21 m_config = new Config("OpieIRC"); 22 m_config = new Config("OpieIRC");
22 m_config->setGroup("OpieIRC"); 23 m_config->setGroup("OpieIRC");
23 QHBoxLayout *l = new QHBoxLayout(this, 2, 2); 24 QHBoxLayout *l = new QHBoxLayout(this, 2, 2);
24 OTabWidget *tw = new OTabWidget(this); 25 OTabWidget *tw = new OTabWidget(this);
25 l->addWidget(tw); 26 l->addWidget(tw);
26 /* General Configuration */ 27 /* General Configuration */
27 QWidget *genwidget = new QWidget(tw); 28 QWidget *genwidget = new QWidget(tw);
28 QGridLayout *layout = new QGridLayout(genwidget, 1, 2, 5, 0); 29 QGridLayout *layout = new QGridLayout(genwidget, 1, 4, 5, 0);
29 QLabel *label = new QLabel(tr("Lines displayed :"), genwidget); 30 QLabel *label = new QLabel(tr("Lines displayed :"), genwidget);
30 layout->addWidget(label, 0, 0); 31 layout->addWidget(label, 0, 0);
31 m_lines = new QLineEdit(m_config->readEntry("Lines", "100"), genwidget); 32 m_lines = new QLineEdit(m_config->readEntry("Lines", "100"), genwidget);
32 QWhatsThis::add(m_lines, tr("Amount of lines to be displayed in chats before old lines get deleted - this is necessary to restrain memory consumption. Set to 0 if you don't need this")); 33 QWhatsThis::add(m_lines, tr("Amount of lines to be displayed in chats before old lines get deleted - this is necessary to restrain memory consumption. Set to 0 if you don't need this"));
33 QIntValidator *validator = new QIntValidator(this); 34 QIntValidator *validator = new QIntValidator(this);
34 validator->setTop(10000); 35 validator->setTop(10000);
35 validator->setBottom(0); 36 validator->setBottom(0);
36 m_lines->setValidator(validator); 37 m_lines->setValidator(validator);
37 layout->addWidget(m_lines, 0, 1); 38 layout->addWidget(m_lines, 0, 1);
39
40 /*
41 * include timestamp
42 */
43 m_displayTime = new QCheckBox( tr("Display time in chat log"), genwidget );
44 m_displayTime->setChecked( m_config->readBoolEntry("DisplayTime", false) );
45 layout->addMultiCellWidget(m_displayTime, 1, 1, 0, 4 );
46
47 // add a spacer
48 layout->addItem( new QSpacerItem(1,1, QSizePolicy::Minimum,
49 QSizePolicy::MinimumExpanding),
50 2, 0 );
51
38 tw->addTab(genwidget, "opieirc/settings", tr("General")); 52 tw->addTab(genwidget, "opieirc/settings", tr("General"));
39 53
40 /* Color configuration */ 54 /* Color configuration */
41 QScrollView *view = new QScrollView(this); 55 QScrollView *view = new QScrollView(this);
42 view->setResizePolicy(QScrollView::AutoOneFit); 56 view->setResizePolicy(QScrollView::AutoOneFit);
43 view->setFrameStyle( QFrame::NoFrame ); 57 view->setFrameStyle( QFrame::NoFrame );
44 QWidget *widget = new QWidget(view->viewport()); 58 QWidget *widget = new QWidget(view->viewport());
45 view->addChild(widget); 59 view->addChild(widget);
46 layout = new QGridLayout(widget, 7, 2, 5, 0); 60 layout = new QGridLayout(widget, 7, 2, 5, 0);
47 label = new QLabel(tr("Background color :"), widget); 61 label = new QLabel(tr("Background color :"), widget);
48 layout->addWidget(label, 0, 0); 62 layout->addWidget(label, 0, 0);
49 m_background = new OColorButton(widget, m_config->readEntry("BackgroundColor", "#FFFFFF")); 63 m_background = new OColorButton(widget, m_config->readEntry("BackgroundColor", "#FFFFFF"));
50 QWhatsThis::add(m_background, tr("Background color to be used in chats")); 64 QWhatsThis::add(m_background, tr("Background color to be used in chats"));
51 layout->addWidget(m_background, 0, 1); 65 layout->addWidget(m_background, 0, 1);
52 label = new QLabel(tr("Normal text color :"), widget); 66 label = new QLabel(tr("Normal text color :"), widget);
53 layout->addWidget(label, 1, 0); 67 layout->addWidget(label, 1, 0);
54 m_text = new OColorButton(widget, m_config->readEntry("TextColor", "#000000")); 68 m_text = new OColorButton(widget, m_config->readEntry("TextColor", "#000000"));
55 QWhatsThis::add(m_text, tr("Text color to be used in chats")); 69 QWhatsThis::add(m_text, tr("Text color to be used in chats"));
56 layout->addWidget(m_text, 1, 1); 70 layout->addWidget(m_text, 1, 1);
57 label = new QLabel(tr("Error color :"), widget); 71 label = new QLabel(tr("Error color :"), widget);
58 layout->addWidget(label, 2, 0); 72 layout->addWidget(label, 2, 0);
59 m_error = new OColorButton(widget, m_config->readEntry("ErrorColor", "#FF0000")); 73 m_error = new OColorButton(widget, m_config->readEntry("ErrorColor", "#FF0000"));
60 QWhatsThis::add(m_error, tr("Text color to be used to display errors")); 74 QWhatsThis::add(m_error, tr("Text color to be used to display errors"));
61 layout->addWidget(m_error, 2, 1); 75 layout->addWidget(m_error, 2, 1);
62 label = new QLabel(tr("Text written by yourself :"), widget); 76 label = new QLabel(tr("Text written by yourself :"), widget);
63 layout->addWidget(label, 3, 0); 77 layout->addWidget(label, 3, 0);
64 m_self = new OColorButton(widget, m_config->readEntry("SelfColor", "#CC0000")); 78 m_self = new OColorButton(widget, m_config->readEntry("SelfColor", "#CC0000"));
65 QWhatsThis::add(m_self, tr("Text color to be used to identify text written by yourself")); 79 QWhatsThis::add(m_self, tr("Text color to be used to identify text written by yourself"));
66 layout->addWidget(m_self, 3, 1); 80 layout->addWidget(m_self, 3, 1);
67 label = new QLabel(tr("Text written by others :"), widget); 81 label = new QLabel(tr("Text written by others :"), widget);
68 layout->addWidget(label, 4, 0); 82 layout->addWidget(label, 4, 0);
69 m_other = new OColorButton(widget, m_config->readEntry("OtherColor", "#0000BB")); 83 m_other = new OColorButton(widget, m_config->readEntry("OtherColor", "#0000BB"));
70 QWhatsThis::add(m_other, tr("Text color to be used to identify text written by others")); 84 QWhatsThis::add(m_other, tr("Text color to be used to identify text written by others"));
71 layout->addWidget(m_other, 4, 1); 85 layout->addWidget(m_other, 4, 1);
72 label = new QLabel(tr("Text written by the server :"), widget); 86 label = new QLabel(tr("Text written by the server :"), widget);
73 layout->addWidget(label, 5, 0); 87 layout->addWidget(label, 5, 0);
74 m_server = new OColorButton(widget, m_config->readEntry("ServerColor", "#0000FF")); 88 m_server = new OColorButton(widget, m_config->readEntry("ServerColor", "#0000FF"));
75 QWhatsThis::add(m_server, tr("Text color to be used to identify text written by the server")); 89 QWhatsThis::add(m_server, tr("Text color to be used to identify text written by the server"));
76 layout->addWidget(m_server, 5, 1); 90 layout->addWidget(m_server, 5, 1);
77 label = new QLabel(tr("Notifications :"), widget); 91 label = new QLabel(tr("Notifications :"), widget);
78 layout->addWidget(label, 6, 0); 92 layout->addWidget(label, 6, 0);
79 m_notification = new OColorButton(widget, m_config->readEntry("NotificationColor", "#AAE300")); 93 m_notification = new OColorButton(widget, m_config->readEntry("NotificationColor", "#AAE300"));
80 QWhatsThis::add(m_notification, tr("Text color to be used to display notifications")); 94 QWhatsThis::add(m_notification, tr("Text color to be used to display notifications"));
81 layout->addWidget(m_notification, 6, 1); 95 layout->addWidget(m_notification, 6, 1);
82 tw->addTab(view, "opieirc/colors", tr("Colors")); 96 tw->addTab(view, "opieirc/colors", tr("Colors"));
83 97
84 98
85 /* 99 /*
86 * IRC EditLine KeyConfiguration 100 * IRC EditLine KeyConfiguration
87 */ 101 */
88 m_keyConf = new Opie::Ui::OKeyConfigWidget(tw, "KEyConfig GUI" ); 102 m_keyConf = new Opie::Ui::OKeyConfigWidget(tw, "KEyConfig GUI" );
89 m_keyConf->setChangeMode( OKeyConfigWidget::Queue ); 103 m_keyConf->setChangeMode( OKeyConfigWidget::Queue );
90 m_keyConf->insert( tr("Keyboard Shortcuts"), 104 m_keyConf->insert( tr("Keyboard Shortcuts"),
91 IRCHistoryLineEdit::keyConfigInstance() ); 105 IRCHistoryLineEdit::keyConfigInstance() );
92 m_keyConf->load(); 106 m_keyConf->load();
93 tw->addTab(m_keyConf, "SettingsIcon", tr("Keyboard Shortcuts") ); 107 tw->addTab(m_keyConf, "SettingsIcon", tr("Keyboard Shortcuts") );
94 108
95 tw->setCurrentTab( genwidget ); 109 tw->setCurrentTab( genwidget );
96 QPEApplication::showDialog( this ); 110 QPEApplication::showDialog( this );
97} 111}
98 112
99void IRCSettings::accept() 113void IRCSettings::accept()
100{ 114{
101 IRCTab::m_backgroundColor = m_background->color().name(); 115 IRCTab::m_backgroundColor = m_background->color().name();
102 IRCTab::m_textColor = m_text->color().name(); 116 IRCTab::m_textColor = m_text->color().name();
103 IRCTab::m_errorColor = m_error->color().name(); 117 IRCTab::m_errorColor = m_error->color().name();
104 IRCTab::m_selfColor = m_self->color().name(); 118 IRCTab::m_selfColor = m_self->color().name();
105 IRCTab::m_otherColor = m_other->color().name(); 119 IRCTab::m_otherColor = m_other->color().name();
106 IRCTab::m_serverColor = m_server->color().name(); 120 IRCTab::m_serverColor = m_server->color().name();
107 IRCTab::m_notificationColor = m_notification->color().name(); 121 IRCTab::m_notificationColor = m_notification->color().name();
108 IRCTab::m_maxLines = m_lines->text().toInt(); 122 IRCTab::m_maxLines = m_lines->text().toInt();
109 m_keyConf->save(); 123 m_keyConf->save();
110 124
111 125
112 m_config->writeEntry("BackgroundColor", IRCTab::m_backgroundColor); 126 m_config->writeEntry("BackgroundColor", IRCTab::m_backgroundColor);
113 m_config->writeEntry("TextColor", IRCTab::m_textColor); 127 m_config->writeEntry("TextColor", IRCTab::m_textColor);
114 m_config->writeEntry("ErrorColor", IRCTab::m_errorColor); 128 m_config->writeEntry("ErrorColor", IRCTab::m_errorColor);
115 m_config->writeEntry("SelfColor", IRCTab::m_selfColor); 129 m_config->writeEntry("SelfColor", IRCTab::m_selfColor);
116 m_config->writeEntry("OtherColor", IRCTab::m_otherColor); 130 m_config->writeEntry("OtherColor", IRCTab::m_otherColor);
117 m_config->writeEntry("ServerColor", IRCTab::m_serverColor); 131 m_config->writeEntry("ServerColor", IRCTab::m_serverColor);
118 m_config->writeEntry("NotificationColor", IRCTab::m_notificationColor); 132 m_config->writeEntry("NotificationColor", IRCTab::m_notificationColor);
119 m_config->writeEntry("Lines", m_lines->text()); 133 m_config->writeEntry("Lines", m_lines->text());
134 m_config->writeEntry("DisplayTime", m_displayTime->isChecked() );
135 IRCTab::setUseTimeStamps(m_displayTime->isChecked());
120 IRCHistoryLineEdit::keyConfigInstance()->save(); 136 IRCHistoryLineEdit::keyConfigInstance()->save();
121 137
122 QDialog::accept(); 138 QDialog::accept();
123} 139}
124 140
125IRCSettings::~IRCSettings() 141IRCSettings::~IRCSettings()
126{ 142{
127 delete m_config; 143 delete m_config;
128} 144}
diff --git a/noncore/net/opieirc/ircsettings.h b/noncore/net/opieirc/ircsettings.h
index a032aff..b51d535 100644
--- a/noncore/net/opieirc/ircsettings.h
+++ b/noncore/net/opieirc/ircsettings.h
@@ -1,55 +1,57 @@
1/* 1/*
2 OpieIRC - An embedded IRC client 2 OpieIRC - An embedded IRC client
3 Copyright (C) 2002 Wenzel Jakob 3 Copyright (C) 2002 Wenzel Jakob
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
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 __IRCSETTINGS_H 21#ifndef __IRCSETTINGS_H
22#define __IRCSETTINGS_H 22#define __IRCSETTINGS_H
23 23
24#include <qpe/config.h> 24#include <qpe/config.h>
25#include <qdialog.h> 25#include <qdialog.h>
26#include <qlineedit.h> 26#include <qlineedit.h>
27 27
28namespace Opie { 28namespace Opie {
29class OColorButton; 29class OColorButton;
30namespace Ui { 30namespace Ui {
31class OKeyConfigWidget; 31class OKeyConfigWidget;
32} 32}
33} 33}
34 34
35class QCheckBox;
35class IRCSettings : public QDialog { 36class IRCSettings : public QDialog {
36 Q_OBJECT 37 Q_OBJECT
37public: 38public:
38 IRCSettings(QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags f = 0); 39 IRCSettings(QWidget* parent = 0, const char* name = 0, bool modal = FALSE, WFlags f = 0);
39 ~IRCSettings(); 40 ~IRCSettings();
40protected slots: 41protected slots:
41 void accept(); 42 void accept();
42protected: 43protected:
43 Config *m_config; 44 Config *m_config;
44 Opie::OColorButton *m_background; 45 Opie::OColorButton *m_background;
45 Opie::OColorButton *m_text; 46 Opie::OColorButton *m_text;
46 Opie::OColorButton *m_error; 47 Opie::OColorButton *m_error;
47 Opie::OColorButton *m_self; 48 Opie::OColorButton *m_self;
48 Opie::OColorButton *m_server; 49 Opie::OColorButton *m_server;
49 Opie::OColorButton *m_other; 50 Opie::OColorButton *m_other;
50 Opie::OColorButton *m_notification; 51 Opie::OColorButton *m_notification;
51 Opie::Ui::OKeyConfigWidget *m_keyConf; 52 Opie::Ui::OKeyConfigWidget *m_keyConf;
52 QLineEdit *m_lines; 53 QLineEdit *m_lines;
54 QCheckBox *m_displayTime;
53}; 55};
54 56
55#endif /* __IRCSETTINGS_H */ 57#endif /* __IRCSETTINGS_H */
diff --git a/noncore/net/opieirc/irctab.cpp b/noncore/net/opieirc/irctab.cpp
index 2b3ecd4..fbbf303 100644
--- a/noncore/net/opieirc/irctab.cpp
+++ b/noncore/net/opieirc/irctab.cpp
@@ -1,50 +1,66 @@
1#include "irctab.h" 1#include "irctab.h"
2#include "mainwindow.h" 2#include "mainwindow.h"
3 3
4#include <opie2/okeyconfigmanager.h> 4#include <opie2/okeyconfigmanager.h>
5#include <qpe/resource.h> 5#include <qpe/resource.h>
6 6
7 7
8#include <qpushbutton.h> 8#include <qpushbutton.h>
9#include <qwhatsthis.h> 9#include <qwhatsthis.h>
10 10
11 11
12QString IRCTab::m_errorColor; 12QString IRCTab::m_errorColor;
13QString IRCTab::m_serverColor; 13QString IRCTab::m_serverColor;
14QString IRCTab::m_textColor; 14QString IRCTab::m_textColor;
15QString IRCTab::m_backgroundColor; 15QString IRCTab::m_backgroundColor;
16QString IRCTab::m_selfColor; 16QString IRCTab::m_selfColor;
17QString IRCTab::m_otherColor; 17QString IRCTab::m_otherColor;
18QString IRCTab::m_notificationColor; 18QString IRCTab::m_notificationColor;
19int IRCTab::m_maxLines; 19int IRCTab::m_maxLines;
20 20
21
22static bool g_useTime = false;
23
24void IRCTab::setUseTimeStamps( bool b ) {
25 g_useTime = b;
26}
27
28// ## FIXME use TimeString later for AM/PM Setting
29QString IRCTab::appendTimestamp( const QString& text ) {
30 return g_useTime ?
31 "[" +QTime::currentTime().toString()+"]" + text + "\n" :
32 text + "\n";
33
34}
35
36
21IRCTab::IRCTab(QWidget *parent, const char *name, WFlags f) : QWidget(parent, name, f) { 37IRCTab::IRCTab(QWidget *parent, const char *name, WFlags f) : QWidget(parent, name, f) {
22 m_layout = new QVBoxLayout(this); 38 m_layout = new QVBoxLayout(this);
23 QHBoxLayout *descLayout = new QHBoxLayout(m_layout); 39 QHBoxLayout *descLayout = new QHBoxLayout(m_layout);
24 descLayout->setMargin(5); 40 descLayout->setMargin(5);
25 m_description = new QLabel(tr("Missing description"), this); 41 m_description = new QLabel(tr("Missing description"), this);
26 QWhatsThis::add(m_description, tr("Description of the tab's content")); 42 QWhatsThis::add(m_description, tr("Description of the tab's content"));
27 descLayout->addWidget(m_description); 43 descLayout->addWidget(m_description);
28 descLayout->setStretchFactor(m_description, 5); 44 descLayout->setStretchFactor(m_description, 5);
29 QPushButton *close = new QPushButton(this); 45 QPushButton *close = new QPushButton(this);
30 QWhatsThis::add(close, tr("Close this tab")); 46 QWhatsThis::add(close, tr("Close this tab"));
31 close->setPixmap(Resource::loadPixmap("close")); 47 close->setPixmap(Resource::loadPixmap("close"));
32 connect(close, SIGNAL(clicked()), this, SLOT(remove())); 48 connect(close, SIGNAL(clicked()), this, SLOT(remove()));
33 descLayout->addWidget(close); 49 descLayout->addWidget(close);
34 descLayout->setStretchFactor(m_description, 1); 50 descLayout->setStretchFactor(m_description, 1);
35} 51}
36 52
37 53
38void IRCTab::setID(int id) { 54void IRCTab::setID(int id) {
39 m_id = id; 55 m_id = id;
40} 56}
41 57
42int IRCTab::id() { 58int IRCTab::id() {
43 return m_id; 59 return m_id;
44} 60}
45 61
46void IRCTab::showEvent( QShowEvent *ev ) { 62void IRCTab::showEvent( QShowEvent *ev ) {
47 topLevelWidget()->setCaption( MainWindow::appCaption() + " " + title() ); 63 topLevelWidget()->setCaption( MainWindow::appCaption() + " " + title() );
48 QWidget::showEvent( ev ); 64 QWidget::showEvent( ev );
49 emit editFocus(); 65 emit editFocus();
50} 66}
diff --git a/noncore/net/opieirc/irctab.h b/noncore/net/opieirc/irctab.h
index 6c29ea5..d17c530 100644
--- a/noncore/net/opieirc/irctab.h
+++ b/noncore/net/opieirc/irctab.h
@@ -1,76 +1,80 @@
1/* 1/*
2 OpieIRC - An embedded IRC client 2 OpieIRC - An embedded IRC client
3 Copyright (C) 2002 Wenzel Jakob 3 Copyright (C) 2002 Wenzel Jakob
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
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 __IRCTAB_H 21#ifndef __IRCTAB_H
22#define __IRCTAB_H 22#define __IRCTAB_H
23 23
24#include <qwidget.h> 24#include <qwidget.h>
25#include <qtextview.h> 25#include <qtextview.h>
26#include <qlineedit.h> 26#include <qlineedit.h>
27#include <qlabel.h> 27#include <qlabel.h>
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 /* The ID is required to store the position of this IRCTab inside the IRCTabWidget */ 38 /* The ID is required to store the position of this IRCTab inside the IRCTabWidget */
39 void setID(int id); 39 void setID(int id);
40 int id(); 40 int id();
41
42 static void setUseTimeStamps(bool b);
43 static QString appendTimestamp(const QString& tex);
44
41 virtual QString title() = 0; 45 virtual QString title() = 0;
42 virtual IRCSession *session() = 0; 46 virtual IRCSession *session() = 0;
43 virtual void appendText(QString text) = 0; 47 virtual void appendText(QString text) = 0;
44signals: 48signals:
45 void changed(IRCTab *); 49 void changed(IRCTab *);
46 void ping(const QString& ); 50 void ping(const QString& );
47 void nextTab(); 51 void nextTab();
48 void prevTab(); 52 void prevTab();
49 void closeTab(); 53 void closeTab();
50 void editFocus(); 54 void editFocus();
51 55
52public slots: 56public slots:
53 virtual void remove() = 0; 57 virtual void remove() = 0;
54 virtual void settingsChanged() = 0; 58 virtual void settingsChanged() = 0;
55 59
56protected: 60protected:
57 void showEvent( QShowEvent* ); 61 void showEvent( QShowEvent* );
58 62
59protected: 63protected:
60 QLabel *m_description; 64 QLabel *m_description;
61 QVBoxLayout *m_layout; 65 QVBoxLayout *m_layout;
62 int m_id; 66 int m_id;
63public: 67public:
64 /* Configuration shared accross all instances - contains HTML style colors (#rrggbb) */ 68 /* Configuration shared accross all instances - contains HTML style colors (#rrggbb) */
65 static QString m_errorColor; 69 static QString m_errorColor;
66 static QString m_serverColor; 70 static QString m_serverColor;
67 static QString m_textColor; 71 static QString m_textColor;
68 static QString m_backgroundColor; 72 static QString m_backgroundColor;
69 static QString m_selfColor; 73 static QString m_selfColor;
70 static QString m_otherColor; 74 static QString m_otherColor;
71 static QString m_notificationColor; 75 static QString m_notificationColor;
72 /* Max number of lines to be displayed */ 76 /* Max number of lines to be displayed */
73 static int m_maxLines; 77 static int m_maxLines;
74}; 78};
75 79
76#endif /* __IRCTAB_H */ 80#endif /* __IRCTAB_H */
diff --git a/noncore/net/opieirc/mainwindow.cpp b/noncore/net/opieirc/mainwindow.cpp
index 2e674c5..2562f33 100644
--- a/noncore/net/opieirc/mainwindow.cpp
+++ b/noncore/net/opieirc/mainwindow.cpp
@@ -1,129 +1,135 @@
1#include <qmenubar.h> 1#include <qmenubar.h>
2#include <qpe/resource.h> 2#include <qpe/resource.h>
3#include <qwhatsthis.h> 3#include <qwhatsthis.h>
4 4
5#include "mainwindow.h" 5#include "mainwindow.h"
6#include "ircservertab.h" 6#include "ircservertab.h"
7#include "ircserverlist.h" 7#include "ircserverlist.h"
8#include "ircsettings.h" 8#include "ircsettings.h"
9 9
10QString MainWindow::appCaption() { 10QString MainWindow::appCaption() {
11 return QObject::tr("Opie IRC"); 11 return QObject::tr("Opie IRC");
12} 12}
13 13
14 14
15MainWindow::MainWindow(QWidget *parent, const char *name, WFlags) : QMainWindow(parent, name, WStyle_ContextHelp) { 15MainWindow::MainWindow(QWidget *parent, const char *name, WFlags) : QMainWindow(parent, name, WStyle_ContextHelp) {
16 setCaption(tr("IRC Client")); 16 setCaption(tr("IRC Client"));
17 m_tabWidget = new IRCTabWidget(this); 17 m_tabWidget = new IRCTabWidget(this);
18 QWhatsThis::add(m_tabWidget, tr("Server connections, channels, queries and other things will be placed here")); 18 QWhatsThis::add(m_tabWidget, tr("Server connections, channels, queries and other things will be placed here"));
19 connect(m_tabWidget, SIGNAL(currentChanged(QWidget*)), this, SLOT(selected(QWidget*))); 19 connect(m_tabWidget, SIGNAL(currentChanged(QWidget*)), this, SLOT(selected(QWidget*)));
20 setCentralWidget(m_tabWidget); 20 setCentralWidget(m_tabWidget);
21 setToolBarsMovable(FALSE); 21 setToolBarsMovable(FALSE);
22 QMenuBar *menuBar = new QMenuBar(this); 22 QMenuBar *menuBar = new QMenuBar(this);
23 QPopupMenu *irc = new QPopupMenu(this); 23 QPopupMenu *irc = new QPopupMenu(this);
24 menuBar->insertItem(tr("IRC"), irc); 24 menuBar->insertItem(tr("IRC"), irc);
25 QAction *a = new QAction(tr("New connection"), Resource::loadPixmap("pass"), QString::null, 0, this, 0); 25 QAction *a = new QAction(tr("New connection"), Resource::loadPixmap("pass"), QString::null, 0, this, 0);
26 connect(a, SIGNAL(activated()), this, SLOT(newConnection())); 26 connect(a, SIGNAL(activated()), this, SLOT(newConnection()));
27 a->setWhatsThis(tr("Create a new connection to an IRC server")); 27 a->setWhatsThis(tr("Create a new connection to an IRC server"));
28 a->addTo(irc); 28 a->addTo(irc);
29 a = new QAction(tr("Settings"), Resource::loadPixmap("SettingsIcon"), QString::null, 0, this, 0); 29 a = new QAction(tr("Settings"), Resource::loadPixmap("SettingsIcon"), QString::null, 0, this, 0);
30 a->setWhatsThis(tr("Configure OpieIRC's behavior and appearance")); 30 a->setWhatsThis(tr("Configure OpieIRC's behavior and appearance"));
31 connect(a, SIGNAL(activated()), this, SLOT(settings())); 31 connect(a, SIGNAL(activated()), this, SLOT(settings()));
32 a->addTo(irc); 32 a->addTo(irc);
33 loadSettings(); 33 loadSettings();
34} 34}
35 35
36/*IRCTabWidget MainWindow::getTabWidget(){ 36/*IRCTabWidget MainWindow::getTabWidget(){
37 return m_tabWidget; 37 return m_tabWidget;
38} */ 38} */
39 39
40void MainWindow::loadSettings() { 40void MainWindow::loadSettings() {
41 Config config("OpieIRC"); 41 Config config("OpieIRC");
42 config.setGroup("OpieIRC"); 42 config.setGroup("OpieIRC");
43 IRCTab::m_backgroundColor = config.readEntry("BackgroundColor", "#FFFFFF"); 43 IRCTab::m_backgroundColor = config.readEntry("BackgroundColor", "#FFFFFF");
44 IRCTab::m_textColor = config.readEntry("TextColor", "#000000"); 44 IRCTab::m_textColor = config.readEntry("TextColor", "#000000");
45 IRCTab::m_errorColor = config.readEntry("ErrorColor", "#FF0000"); 45 IRCTab::m_errorColor = config.readEntry("ErrorColor", "#FF0000");
46 IRCTab::m_selfColor = config.readEntry("SelfColor", "#CC0000"); 46 IRCTab::m_selfColor = config.readEntry("SelfColor", "#CC0000");
47 IRCTab::m_otherColor = config.readEntry("OtherColor", "#0000BB"); 47 IRCTab::m_otherColor = config.readEntry("OtherColor", "#0000BB");
48 IRCTab::m_serverColor = config.readEntry("ServerColor", "#0000FF"); 48 IRCTab::m_serverColor = config.readEntry("ServerColor", "#0000FF");
49 IRCTab::m_notificationColor = config.readEntry("NotificationColor", "#AA3300"); 49 IRCTab::m_notificationColor = config.readEntry("NotificationColor", "#AA3300");
50 IRCTab::m_maxLines = config.readNumEntry("Lines", 100); 50 IRCTab::m_maxLines = config.readNumEntry("Lines", 100);
51 IRCTab::setUseTimeStamps( config.readBoolEntry("DisplayTime", false ) );
51} 52}
52 53
53void MainWindow::selected(QWidget *) { 54void MainWindow::selected(QWidget *) {
54 m_tabWidget->setTabColor(m_tabWidget->currentPageIndex(), black); 55 m_tabWidget->setTabColor(m_tabWidget->currentPageIndex(), black);
55 emit updateScroll(); 56 emit updateScroll();
56} 57}
57 58
58void MainWindow::addTab(IRCTab *tab) { 59void MainWindow::addTab(IRCTab *tab) {
59 connect(tab, SIGNAL(changed(IRCTab*)), this, SLOT(changeEvent(IRCTab*))); 60 connect(tab, SIGNAL(changed(IRCTab*)), this, SLOT(changeEvent(IRCTab*)));
60 connect(tab, SIGNAL(ping (const QString&)), this, SLOT(slotPing(const QString&))); 61 connect(tab, SIGNAL(ping (const QString&)), this, SLOT(slotPing(const QString&)));
61 connect(tab, SIGNAL(nextTab()), this, SLOT(slotNextTab())); 62 connect(tab, SIGNAL(nextTab()), this, SLOT(slotNextTab()));
62 connect(tab, SIGNAL(prevTab()), this, SLOT(slotPrevTab())); 63 connect(tab, SIGNAL(prevTab()), this, SLOT(slotPrevTab()));
63 connect(tab, SIGNAL(closeTab()), this, SLOT(slotCloseTab()));
64 64
65 m_tabWidget->addTab(tab, tab->title()); 65 m_tabWidget->addTab(tab, tab->title());
66 m_tabWidget->showPage(tab); 66 m_tabWidget->showPage(tab);
67 tab->setID(m_tabWidget->currentPageIndex()); 67 tab->setID(m_tabWidget->currentPageIndex());
68 m_tabs.append(tab); 68 m_tabs.append(tab);
69} 69}
70 70
71void MainWindow::changeEvent(IRCTab *tab) { 71void MainWindow::changeEvent(IRCTab *tab) {
72 if (tab->id() != m_tabWidget->currentPageIndex()) 72 if (tab->id() != m_tabWidget->currentPageIndex())
73 m_tabWidget->setTabColor(tab->id(), blue); 73 m_tabWidget->setTabColor(tab->id(), blue);
74} 74}
75 75
76void MainWindow::killTab(IRCTab *tab) { 76void MainWindow::killTab(IRCTab *tab, bool imediate) {
77 m_tabWidget->removePage(tab); 77 m_toDelete.append( tab );
78 m_tabs.remove(tab);
79 78
80 /* there might be nicer ways to do this .. */ 79 if ( imediate )
81 delete tab; 80 slotKillTabsLater();
81 else
82 QTimer::singleShot(0, this, SLOT(slotKillTabsLater()) );
83}
84
85void MainWindow::slotKillTabsLater() {
86 for ( QListIterator<IRCTab> it(m_toDelete); it.current(); ++it ) {
87 m_tabWidget->removePage( it.current() );
88 m_tabs.remove( it.current() );
89 }
90
91 m_toDelete.setAutoDelete( true );
92 m_toDelete.clear();
93 m_toDelete.setAutoDelete( false );
82} 94}
83 95
84void MainWindow::newConnection() { 96void MainWindow::newConnection() {
85 IRCServerList list(this, "ServerList", TRUE); 97 IRCServerList list(this, "ServerList", TRUE);
86 if (list.exec() == QDialog::Accepted && list.hasServer()) { 98 if (list.exec() == QDialog::Accepted && list.hasServer()) {
87 IRCServerTab *serverTab = new IRCServerTab(list.server(), this, m_tabWidget); 99 IRCServerTab *serverTab = new IRCServerTab(list.server(), this, m_tabWidget);
88 addTab(serverTab); 100 addTab(serverTab);
89 serverTab->doConnect(); 101 serverTab->doConnect();
90 } 102 }
91} 103}
92 104
93void MainWindow::settings() { 105void MainWindow::settings() {
94 IRCSettings settings(this, "Settings", TRUE); 106 IRCSettings settings(this, "Settings", TRUE);
95 if (settings.exec() == QDialog::Accepted) { 107 if (settings.exec() == QDialog::Accepted) {
96 QListIterator<IRCTab> it(m_tabs); 108 QListIterator<IRCTab> it(m_tabs);
97 for (; it.current(); ++it) { 109 for (; it.current(); ++it) {
98 /* Inform all tabs about the new settings */ 110 /* Inform all tabs about the new settings */
99 it.current()->settingsChanged(); 111 it.current()->settingsChanged();
100 } 112 }
101 } 113 }
102} 114}
103 115
104 116
105void MainWindow::slotNextTab() { 117void MainWindow::slotNextTab() {
106 int i = m_tabWidget->currentPageIndex (); 118 int i = m_tabWidget->currentPageIndex ();
107 m_tabWidget->setCurrentPage ( i+1 ); 119 m_tabWidget->setCurrentPage ( i+1 );
108 120
109 int j = m_tabWidget->currentPageIndex (); 121 int j = m_tabWidget->currentPageIndex ();
110 if ( i == j ) 122 if ( i == j )
111 m_tabWidget->setCurrentPage ( 1 ); 123 m_tabWidget->setCurrentPage ( 1 );
112} 124}
113 125
114void MainWindow::slotPrevTab() { 126void MainWindow::slotPrevTab() {
115 int i = m_tabWidget->currentPageIndex (); 127 int i = m_tabWidget->currentPageIndex ();
116 if ( i > 1 ) 128 if ( i > 1 )
117 m_tabWidget->setCurrentPage ( i-1 ); 129 m_tabWidget->setCurrentPage ( i-1 );
118} 130}
119 131
120void MainWindow::slotCloseTab() { 132void MainWindow::slotPing( const QString& /*channel*/ ) {
121 IRCTab *tab = (IRCTab *) m_tabWidget->currentPage ();
122 if ( tab )
123 killTab ( tab );
124}
125
126void MainWindow::slotPing( const QString& channel ) {
127 raise(); 133 raise();
128} 134}
129 135
diff --git a/noncore/net/opieirc/mainwindow.h b/noncore/net/opieirc/mainwindow.h
index 945fc71..abf205d 100644
--- a/noncore/net/opieirc/mainwindow.h
+++ b/noncore/net/opieirc/mainwindow.h
@@ -1,60 +1,61 @@
1/* 1/*
2 OpieIRC - An embedded IRC client 2 OpieIRC - An embedded IRC client
3 Copyright (C) 2002 Wenzel Jakob 3 Copyright (C) 2002 Wenzel Jakob
4 4
5 This program is free software; you can redistribute it and/or modify 5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by 6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or 7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version. 8 (at your option) any later version.
9 9
10 This program is distributed in the hope that it will be useful, 10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
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 __MAINWINDOW_H 21#ifndef __MAINWINDOW_H
22#define __MAINWINDOW_H 22#define __MAINWINDOW_H
23 23
24#include <qmainwindow.h> 24#include <qmainwindow.h>
25#include <qaction.h> 25#include <qaction.h>
26#include <qlist.h> 26#include <qlist.h>
27#include "mainwindow.h" 27#include "mainwindow.h"
28#include "ircmisc.h" 28#include "ircmisc.h"
29#include "irctab.h" 29#include "irctab.h"
30 30
31class MainWindow : public QMainWindow { 31class MainWindow : public QMainWindow {
32 Q_OBJECT 32 Q_OBJECT
33public: 33public:
34 MainWindow(QWidget *parent = 0, const char *name = 0, WFlags f = 0); 34 MainWindow(QWidget *parent = 0, const char *name = 0, WFlags f = 0);
35// IRCTabWidget getTabWidget(); 35// IRCTabWidget getTabWidget();
36 void addTab(IRCTab *tab); 36 void addTab(IRCTab *tab);
37 void killTab(IRCTab *tab); 37 void killTab(IRCTab *tab, bool now = false);
38 static QString appName() { return QString::fromLatin1("opieirc"); } 38 static QString appName() { return QString::fromLatin1("opieirc"); }
39 static QString appCaption(); 39 static QString appCaption();
40signals: 40signals:
41 void updateScroll(); 41 void updateScroll();
42protected slots: 42protected slots:
43 void newConnection(); 43 void newConnection();
44 void settings(); 44 void settings();
45 void selected(QWidget *); 45 void selected(QWidget *);
46 void changeEvent(IRCTab *); 46 void changeEvent(IRCTab *);
47 47
48 void slotNextTab(); 48 void slotNextTab();
49 void slotPrevTab(); 49 void slotPrevTab();
50 void slotCloseTab();
51 void slotPing(const QString&); 50 void slotPing(const QString&);
51 void slotKillTabsLater();
52 52
53protected: 53protected:
54 void loadSettings(); 54 void loadSettings();
55protected: 55protected:
56 IRCTabWidget *m_tabWidget; 56 IRCTabWidget *m_tabWidget;
57 QList<IRCTab> m_tabs; 57 QList<IRCTab> m_tabs;
58 QList<IRCTab> m_toDelete;
58}; 59};
59 60
60#endif /* __MAINWINDOW_H */ 61#endif /* __MAINWINDOW_H */