summaryrefslogtreecommitdiffstats
path: root/ksirc/ksopts.cpp
diff options
context:
space:
mode:
authortoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
committertoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
commitbcb704366cb5e333a626c18c308c7e0448a8e69f (patch)
treef0d6ab7d78ecdd9207cf46536376b44b91a1ca71 /ksirc/ksopts.cpp
downloadtdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.tar.gz
tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.zip
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdenetwork@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'ksirc/ksopts.cpp')
-rw-r--r--ksirc/ksopts.cpp542
1 files changed, 542 insertions, 0 deletions
diff --git a/ksirc/ksopts.cpp b/ksirc/ksopts.cpp
new file mode 100644
index 00000000..11b25ad8
--- /dev/null
+++ b/ksirc/ksopts.cpp
@@ -0,0 +1,542 @@
+
+#include <kapplication.h>
+#include <kconfig.h>
+
+#if KDE_IS_VERSION(3,1,92)
+#include <kuser.h>
+#else
+#include <unistd.h>
+#include <pwd.h>
+#endif
+
+#include <kdebug.h>
+
+#include "ksopts.h"
+
+
+KSOptions *KSOptions::s_options = 0;
+bool KSOChannel::applyGlobally = false;
+
+KSOGeneral::KSOGeneral()
+{
+ displayMode = MDI;
+ autoCreateWin = true;
+ autoCreateWinForNotice = false;
+ nickCompletion = true;
+ displayTopic = true;
+ oneLineEntry = true;
+ runDocked = false;
+// timeStamp = true;
+// beepNotify = true;
+ colorPicker = true;
+ autoRejoin = false;
+ windowLength = 200;
+// logging = false;
+// beepOnMsg = false;
+ publicAway = true;
+ // topicShow = true;
+ useColourNickList = false;
+ dockPopups = true;
+ autoSaveHistory = true;
+
+}
+
+QPixmap KSOGeneral::backgroundPixmap()
+{
+ if ( m_backgroundPixmap.isNull() && !backgroundFile.isEmpty() )
+ m_backgroundPixmap = QPixmap( backgroundFile );
+ return m_backgroundPixmap;
+}
+
+KSOStartup::KSOStartup()
+{
+}
+
+KSOServer::KSOServer()
+{
+#if KDE_IS_VERSION(3,1,92)
+ KUser user;
+ nick = user.loginName();
+ userID = user.loginName();
+ realName = user.fullName();
+#else
+ struct passwd *pw = getpwuid( getuid() );
+ if ( pw )
+ {
+ nick = QString::fromLocal8Bit( pw->pw_name );
+ userID = QString::fromLocal8Bit( pw->pw_name );
+ realName = QString::fromLocal8Bit( pw->pw_gecos ).section( ',', 0, 0 );
+ }
+#endif
+}
+
+
+KSOColors::KSOColors()
+{
+ textColor = Qt::black;
+ linkColor = Qt::blue;
+ infoColor = Qt::blue;
+ channelColor = Qt::green;
+ errorColor = Qt::red;
+
+ ksircColors = true;
+ mircColors = false;
+ nickColourization = false;
+ ownNickBold = false;
+ ownNickUl = true;
+ ownNickRev = false;
+
+ msg1Regex = false;
+ msg2Regex = false;
+
+ backgroundColor = kapp->palette().color( QPalette::Active, QColorGroup::Mid );
+ selBackgroundColor = kapp->palette().color( QPalette::Active, QColorGroup::Highlight );
+ selForegroundColor = kapp->palette().color( QPalette::Active, QColorGroup::HighlightedText );
+
+ ircColors[0] = Qt::white;
+ ircColors[1] = Qt::black;
+ ircColors[2] = Qt::darkBlue;
+ ircColors[3] = Qt::darkGreen;
+ ircColors[4] = Qt::red;
+ ircColors[5] = QColor ( 165, 42, 42 );
+ ircColors[6] = Qt::darkMagenta;
+ ircColors[7] = QColor( 255, 0x7b, 00 );
+ ircColors[8] = Qt::yellow;
+ ircColors[9] = Qt::green;
+ ircColors[10] = Qt::darkCyan;
+ ircColors[11] = Qt::cyan;
+ ircColors[12] = Qt::blue;
+ ircColors[13] = QColor( 255, 0, 255 );
+ ircColors[14] = Qt::gray;
+ ircColors[15] = Qt::lightGray;
+
+ uint i;
+ for(i = 0; i < numColors; i++){
+ nickHighlight[i] = true;
+ }
+
+ colourTheme = "Custom";
+}
+
+KSORMBMenu::KSORMBMenu()
+{
+}
+
+KSOServChan::KSOServChan()
+{
+}
+
+KSOChannel::KSOChannel()
+{
+ timeStamp = false;
+ beepNotify = false;
+ beepOnMsg = false;
+ logging = false;
+ topicShow = true;
+ filterJoinPart = false;
+ applyGlobally = false;
+ encoding = "Default";
+}
+
+void KSOptions::load( int sections )
+{
+ KConfig *conf = kapp->config();
+ conf->setGroup( "ServerController" );
+ geometry = conf->readRectEntry( "Size" );
+
+ // Using the fields itself as default values as they are already
+ // set to the defaults.
+ if ( sections & General )
+ {
+ conf->setGroup( "General" );
+ int mode = conf->readNumEntry( "DisplayMode", static_cast<int>(displayMode) );
+ if (mode == 0)
+ displayMode = SDI;
+ else
+ displayMode = MDI;
+
+ autoCreateWin = conf->readBoolEntry( "AutoCreateWin", autoCreateWin );
+ autoCreateWinForNotice = conf->readBoolEntry( "AutoCreateWinForNotice", autoCreateWinForNotice );
+ nickCompletion = conf->readBoolEntry( "NickCompletion", nickCompletion );
+ displayTopic = conf->readBoolEntry( "DisplayTopic", displayTopic );
+ oneLineEntry = conf->readBoolEntry( "OneLineEntry", oneLineEntry );
+ runDocked = conf->readBoolEntry( "runDocked", runDocked );
+// timeStamp = conf->readBoolEntry( "TimeStamp", timeStamp );
+// beepNotify = conf->readBoolEntry( "BeepNotify", beepNotify );
+ colorPicker = conf->readBoolEntry( "ColourPicker", colorPicker );
+ autoRejoin = conf->readBoolEntry( "AutoRejoin", autoRejoin );
+ windowLength = conf->readNumEntry( "WindowLength", windowLength );
+ backgroundFile = conf->readPathEntry( "BackgroundFile", backgroundFile );
+// logging = conf->readBoolEntry( "Logging", logging );
+// beepOnMsg = conf->readBoolEntry( "BeepOnMessage", false );
+ publicAway = conf->readBoolEntry( "PublicAway", publicAway );
+ // topicShow = conf->readBoolEntry("TopicShow", topicShow);
+ useColourNickList = conf->readBoolEntry("ColourNickList", useColourNickList);
+ dockPopups = conf->readBoolEntry("dockPopups", dockPopups);
+ autoSaveHistory = conf->readBoolEntry("autoSaveHistory", autoSaveHistory);
+ }
+
+ if ( sections & Startup )
+ {
+ conf->setGroup( "StartUp" );
+ }
+
+
+ if ( sections & Colors )
+ {
+ if ( !conf->hasGroup( "ColorScheme" ) && conf->hasGroup( "Colours" ) )
+ {
+ conf->setGroup( "Colours" );
+ textColor = conf->readColorEntry( "text", &textColor );
+ infoColor = conf->readColorEntry( "info", &infoColor );
+ channelColor = conf->readColorEntry( "chan", &channelColor );
+ errorColor = conf->readColorEntry( "error", &errorColor );
+ int c = conf->readNumEntry( "uscolour", -1 );
+ if ( c >= 0 && c < 16 )
+ ownNickColor = ircColors[c];
+ c = conf->readNumEntry( "nickfcolour", -1 );
+ if ( c >= 0 && c < 16 )
+ nickForeground = ircColors[c];
+ c = conf->readNumEntry( "nickbcolour", -1 );
+ if ( c >= 0 && c < 16 )
+ nickBackground = ircColors[c];
+ backgroundColor = conf->readColorEntry( "Background", &backgroundColor );
+ }
+ else
+ {
+ conf->setGroup( "ColorScheme" );
+ textColor = conf->readColorEntry( "Text", &textColor );
+ linkColor = conf->readColorEntry( "Link", &linkColor );
+ infoColor = conf->readColorEntry( "Info", &infoColor );
+ channelColor = conf->readColorEntry( "Channel", &channelColor );
+ errorColor = conf->readColorEntry( "Error", &errorColor );
+ ownNickColor = conf->readColorEntry( "OwnNick", &ownNickColor );
+ ownNickBold = conf->readBoolEntry( "OwnNickBold", ownNickBold );
+ ownNickUl = conf->readBoolEntry( "OwnNickUnderline", ownNickUl );
+ ownNickRev = conf->readBoolEntry( "OwnNickReverse", ownNickRev );
+ msgContainNick = conf->readColorEntry( "msgContainNick", &ownNickColor ); // default to the ownNick colour
+ msg1Contain = conf->readColorEntry( "msg1Contain", &msg1Contain );
+ msg1String = conf->readEntry( "msg1String", msg1String );
+ msg1Regex = conf->readBoolEntry( "msg1Regex", msg1Regex );
+ msg2Contain = conf->readColorEntry( "msg2Contain", &msg2Contain );
+ msg2String = conf->readEntry( "msg2String", msg2String );
+ msg2Regex = conf->readBoolEntry( "msg2Regex", msg2Regex );
+ nickForeground = conf->readColorEntry( "NickForeground", &nickForeground );
+ nickBackground = conf->readColorEntry( "NickBackground", &nickBackground );
+ backgroundColor = conf->readColorEntry( "Background", &backgroundColor );
+ selBackgroundColor = conf->readColorEntry( "SelBackground", &selBackgroundColor );
+ selForegroundColor = conf->readColorEntry( "SelForeground", &selForegroundColor );
+ ksircColors = conf->readBoolEntry( "ksircColors", ksircColors );
+ mircColors = conf->readBoolEntry( "mircColors", mircColors );
+ nickColourization = conf->readBoolEntry( "nickColourization", mircColors );
+ colourTheme = conf->readEntry("ColourTheme", colourTheme );
+ for ( int i = 0; i < 16; ++i ) {
+ ircColors[i] =
+ conf->readColorEntry(QString::fromLatin1( "IRC-%1" ).arg( i ),
+ &ircColors[i] );
+ nickHighlight[i] =
+ conf->readBoolEntry(QString::fromLatin1( "nickHighlight-%1" ).arg( i ),
+ &nickHighlight[i] );
+ }
+ }
+ conf->setGroup( "GlobalOptions" );
+ QFont df = kapp->font(0);
+ defaultFont = conf->readFontEntry( "MainFont", &df);
+ QApplication::setFont( defaultFont, true, "KSirc::TextView" );
+ }
+ if ( sections & Channels )
+ {
+ conf->setGroup( "Channel" );
+
+ /*
+ * do global first
+ */
+ if(channel.contains("global") == FALSE){
+ KSOChannel global;
+ ChannelOpMap coMap;
+ channel.insert(QString("global"), coMap);
+ channel["global"].insert("global", global);
+ channel["global"]["global"].server = "global";
+ channel["global"]["global"].channel = "global";
+ channel["global"]["global"].timeStamp = conf->readBoolEntry("globalglobalTimeStamp", false);
+ channel["global"]["global"].beepNotify = conf->readBoolEntry("globalglobalBeepNotify", false);
+ channel["global"]["global"].beepOnMsg = conf->readBoolEntry("globalglobalBeepOnMsg", false);
+ channel["global"]["global"].logging = conf->readBoolEntry("globalglobalLogging", false);
+ channel["global"]["global"].topicShow = conf->readBoolEntry("globalglobalTopicShow", true);
+ channel["global"]["global"].filterJoinPart = conf->readBoolEntry("globalglobalFilterJoinPart", false);
+ channel["global"]["global"].applyGlobally = conf->readBoolEntry("globalglobalApplyGlobally", false);
+ channel["global"]["global"].encoding = conf->readEntry("globalglobalEncoding", "Default");
+ }
+
+ QDateTime now(QDateTime::currentDateTime());
+ QStringList servers = conf->readListEntry("Servers");
+ QStringList::ConstIterator ser = servers.begin();
+ for( ; ser != servers.end(); ser++){
+ ChannelOpMap coMap;
+ channel.insert(*ser, coMap);
+ QStringList channels = conf->readListEntry(*ser);
+ QStringList::ConstIterator chan = channels.begin();
+ for( ; chan != channels.end(); chan++){
+ QDateTime lastUsed = conf->readDateTimeEntry(*ser + *chan + "lastUsed", &now);
+ if((lastUsed.daysTo(now) < 30 )||
+ (*chan == "global" && *ser == "global"))
+ {
+ KSOChannel ksoc;
+ ksoc = channel["global"]["global"];
+ ksoc.server = *ser;
+ ksoc.channel = *chan;
+ ksoc.timeStamp = conf->readBoolEntry(*ser + *chan + "TimeStamp", ksoc.timeStamp);
+ ksoc.beepNotify = conf->readBoolEntry(*ser + *chan + "BeepNotify", ksoc.beepNotify);
+ ksoc.beepOnMsg = conf->readBoolEntry(*ser + *chan + "BeepOnMsg", ksoc.beepOnMsg);
+ ksoc.logging = conf->readBoolEntry(*ser + *chan + "Logging", ksoc.logging);
+ ksoc.topicShow = conf->readBoolEntry(*ser + *chan + "TopicShow", ksoc.topicShow);
+ ksoc.encoding = conf->readEntry(*ser + *chan + "Encoding", ksoc.encoding);
+ ksoc.filterJoinPart = conf->readBoolEntry(*ser + *chan + "FilterJoinPart", ksoc.filterJoinPart);
+ ksoc.lastUsed = lastUsed;
+ channel[*ser].insert(*chan, ksoc);
+ }
+ else { /* expire junk */
+ conf->deleteEntry(*ser + *chan + "TimeStamp");
+ conf->deleteEntry(*ser + *chan + "BeepNotify");
+ conf->deleteEntry(*ser + *chan + "BeepOnMsg");
+ conf->deleteEntry(*ser + *chan + "Logging");
+ conf->deleteEntry(*ser + *chan + "TopicShow");
+ conf->deleteEntry(*ser + *chan + "Encoding");
+ conf->deleteEntry(*ser + *chan + "FilterJoinPart");
+ conf->deleteEntry(*ser + *chan + "lastUsed");
+ }
+ }
+ }
+ }
+ if ( sections & Servers )
+ {
+ conf->setGroup( "Server" );
+
+ /*
+ * do global first
+ */
+ if(server.contains("global") == FALSE){
+ KSOServer global;
+ server.insert(QString("global"), global);
+ server["global"].server = "global";
+ server["global"].globalCopy = false;
+
+ conf->setGroup( "StartUp" );
+ server["global"].nick = conf->readEntry("Nick");
+ server["global"].altNick = conf->readEntry("altNick");
+ server["global"].realName = conf->readEntry("RealName");
+ server["global"].userID = conf->readEntry("userID");
+ server["global"].notifyList = conf->readListEntry("NotifyList");
+
+ conf->setGroup( "Server" );
+ }
+
+ kdDebug(5008) << "Load: in Server" << endl;
+
+ QStringList servers = conf->readListEntry("Servers");
+
+ QStringList::ConstIterator ser = servers.begin();
+ for( ; ser != servers.end(); ser++){
+ KSOServer ksos;
+ ksos = server["global"];
+ ksos.server = *ser;
+ ksos.globalCopy = false;
+ ksos.nick = conf->readEntry(*ser + "nick");
+ ksos.altNick = conf->readEntry(*ser + "altNick");
+ ksos.realName = conf->readEntry(*ser + "realName");
+ ksos.userID = conf->readEntry(*ser + "userID");
+ ksos.notifyList = conf->readListEntry(*ser + "notifyList");
+ kdDebug(5008) << *ser << ": nick: " << ksos.nick << " altNick: " << ksos.altNick << endl;
+ server.insert(*ser, ksos);
+ }
+ }
+ kdDebug(5008) << "Done full load" << endl;
+}
+
+void KSOptions::save( int sections )
+{
+ KConfig *conf = kapp->config();
+
+ if ( sections & General )
+ {
+ conf->setGroup( "General" );
+ conf->writeEntry( "DisplayMode", static_cast<int>(displayMode) );
+ conf->writeEntry( "AutoCreateWin", autoCreateWin );
+ conf->writeEntry( "AutoCreateWinForNotice", autoCreateWinForNotice );
+ conf->writeEntry( "NickCompletion", nickCompletion );
+ conf->writeEntry( "DisplayTopic", displayTopic );
+ conf->writeEntry( "OneLineEntry", oneLineEntry );
+ conf->writeEntry( "runDocked", runDocked );
+// conf->writeEntry( "TimeStamp", timeStamp );
+// conf->writeEntry( "BeepNotify", beepNotify );
+ conf->writeEntry( "ColourPicker", colorPicker );
+ conf->writeEntry( "AutoRejoin", autoRejoin );
+ conf->writeEntry( "WindowLength", windowLength );
+ conf->writePathEntry( "BackgroundFile", backgroundFile );
+// conf->writeEntry( "Logging", logging );
+// conf->writeEntry( "BeepOnMessage", beepOnMsg );
+ conf->writeEntry( "PublicAway", publicAway );
+ conf->writeEntry( "ColourNickList", useColourNickList );
+ conf->writeEntry( "dockPopups", dockPopups );
+ conf->writeEntry( "autoSaveHistory", autoSaveHistory );
+ }
+
+ if ( sections & Startup )
+ {
+ conf->setGroup( "StartUp" );
+ /*
+ conf->writeEntry( "Nick", nick );
+ conf->writeEntry( "AlternativeNick", altNick );
+ conf->writeEntry( "RealName", realName );
+ conf->writeEntry( "userID", userID );
+ conf->writeEntry( "NotifyList", notifyList );
+ */
+ }
+
+ if ( sections & Colors )
+ {
+ conf->setGroup( "ColorScheme" );
+ conf->writeEntry( "Text", textColor );
+ conf->writeEntry( "Link", linkColor );
+ conf->writeEntry( "Info", infoColor );
+ conf->writeEntry( "Channel", channelColor );
+ conf->writeEntry( "Error", errorColor );
+ conf->writeEntry( "OwnNick", ownNickColor );
+ conf->writeEntry( "OwnNickBold", ownNickBold );
+ conf->writeEntry( "OwnNickUnderline", ownNickUl );
+ conf->writeEntry( "OwnNickReverse", ownNickRev );
+ conf->writeEntry( "msgContainNick", msgContainNick );
+ conf->writeEntry( "msg1Contain", msg1Contain );
+ conf->writeEntry( "msg1String", msg1String );
+ conf->writeEntry( "msg1Regex", msg1Regex );
+ conf->writeEntry( "msg2Contain", msg2Contain );
+ conf->writeEntry( "msg2String", msg2String );
+ conf->writeEntry( "msg2Regex", msg2Regex );
+ conf->writeEntry( "NickForeground", nickForeground );
+ conf->writeEntry( "NickBackground", nickBackground );
+ conf->writeEntry( "Background", backgroundColor );
+ conf->writeEntry( "SelBackground", selBackgroundColor );
+ conf->writeEntry( "SelForeground", selForegroundColor );
+ conf->writeEntry( "ksircColors", (bool) ksircColors );
+ conf->writeEntry( "mircColors", mircColors );
+ conf->writeEntry( "nickColourization", nickColourization );
+ conf->writeEntry( "ColourTheme", colourTheme );
+ for ( int i = 0; i < 16; ++i ) {
+ conf->writeEntry( QString::fromLatin1( "IRC-%1" ).arg( i ), ircColors[i] );
+ conf->writeEntry( QString::fromLatin1( "nickHighlight-%1" ).arg( i ), nickHighlight[i] );
+ }
+ /* Store the font setting */
+ conf->setGroup( "GlobalOptions" );
+ conf->writeEntry("MainFont", defaultFont);
+ /* end of storing the font settings */
+ }
+ if ( sections & Channels )
+ {
+ QStringList servers;
+
+ conf->deleteGroup( "Channel" );
+
+ conf->setGroup( "Channel" );
+ ServerChannelOpMap::Iterator ser;
+ for( ser = channel.begin(); ser != channel.end(); ++ser ){
+ QStringList channels;
+
+ servers << ser.key();
+
+ ChannelOpMap::Iterator chan;
+ for( chan = ser.data().begin(); chan != ser.data().end(); ++chan ){
+ channels << chan.key();
+ conf->writeEntry(ser.key() + chan.key() + "TimeStamp", chan.data().timeStamp);
+ conf->writeEntry(ser.key() + chan.key() + "BeepNotify", chan.data().beepNotify);
+ conf->writeEntry(ser.key() + chan.key() + "BeepOnMsg", chan.data().beepOnMsg);
+ conf->writeEntry(ser.key() + chan.key() + "Logging", chan.data().logging);
+ conf->writeEntry(ser.key() + chan.key() + "TopicShow", chan.data().topicShow);
+ conf->writeEntry(ser.key() + chan.key() + "Encoding", chan.data().encoding);
+ conf->writeEntry(ser.key() + chan.key() + "FilterJoinPart", chan.data().filterJoinPart);
+ conf->writeEntry(ser.key() + chan.key() + "lastUsed", chan.data().lastUsed);
+ }
+ conf->writeEntry(ser.key(), channels);
+ }
+ conf->writeEntry("Servers", servers);
+ conf->writeEntry("globalglobalApplyGlobally", channel["global"]["global"].applyGlobally);
+ }
+ if ( sections & Servers )
+ {
+ QStringList servers;
+
+ conf->deleteGroup( "Servers" );
+
+ conf->setGroup( "Server" );
+ ServerOpMap::Iterator ser;
+ for( ser = server.begin(); ser != server.end(); ++ser ){
+ QStringList channels;
+
+ if(ser.data().globalCopy == true)
+ continue;
+
+ servers << ser.key();
+
+ conf->writeEntry(ser.key() + "nick", ser.data().nick);
+ conf->writeEntry(ser.key() + "altNick", ser.data().altNick);
+ conf->writeEntry(ser.key() + "realName", ser.data().realName);
+ conf->writeEntry(ser.key() + "userID", ser.data().userID);
+ conf->writeEntry(ser.key() + "notifyList", ser.data().notifyList);
+ }
+ conf->writeEntry("Servers", servers);
+ }
+
+ conf->sync();
+}
+
+void KSOptions::channelSetup(QString serv, QString chan)
+{
+ if(channel.contains(serv) == FALSE){
+ ChannelOpMap coMap;
+ channel.insert(serv, coMap);
+ }
+ if(channel[serv].contains(chan) == FALSE){
+ KSOChannel ksoc;
+ ksoc = channel["global"]["global"];
+ channel[serv].insert(chan, ksoc);
+ channel[serv][chan].server = serv;
+ channel[serv][chan].channel = chan;
+ channel[serv][chan].lastUsed = QDateTime::currentDateTime();
+ }
+ else {
+ channel[serv][chan].lastUsed = QDateTime::currentDateTime();
+ }
+}
+
+void KSOptions::applyChannelGlobal(void)
+{
+ ServerChannelOpMap::Iterator ser;
+ for( ser = channel.begin(); ser != channel.end(); ++ser ){
+ ChannelOpMap::Iterator chan;
+ for( chan = ser.data().begin(); chan != ser.data().end(); ++chan ){
+ if((chan.key() == "global") && (ser.key() == "global"))
+ continue;
+
+ chan.data() = channel["global"]["global"];
+ }
+ }
+
+}
+
+void KSOptions::serverSetup(QString serv)
+{
+ if(server.contains(serv) == FALSE){
+ KSOServer ksos;
+ ksos = server["global"];
+ server.insert(serv, ksos);
+ server[serv].server = serv;
+ server[serv].globalCopy = true;
+ server[serv].lastUsed = QDateTime::currentDateTime();
+ }
+ else {
+ server[serv].lastUsed = QDateTime::currentDateTime();
+ }
+}
+
+
+/* vim: et sw=4 ts=4
+ */