# HG changeset patch
# User sheepluva
# Date 1319601420 -7200
# Node ID c06b7e2eb7a47fca9ec50f84961046b04769b1cc
# Parent  c0f2e0915e5747a27b5d6c6f18f881ca2bbc7821
custom highlighting

diff -r c0f2e0915e57 -r c06b7e2eb7a4 QTfrontend/ui/widget/chatwidget.cpp
--- a/QTfrontend/ui/widget/chatwidget.cpp	Wed Oct 26 02:21:44 2011 +0200
+++ b/QTfrontend/ui/widget/chatwidget.cpp	Wed Oct 26 05:57:00 2011 +0200
@@ -136,6 +136,8 @@
                 style.append(in.readLine()+"\n");
             }
             orgStyleSheet = style;
+
+            file.close();
         }
     }
 
@@ -483,7 +485,8 @@
 
     // check first character for color code and set color properly
     char c = str[0].toAscii();
-    switch (c) {
+    switch (c)
+    {
         case 3:
             cssClass = (isFriend ? "msg_FriendJoin" : "msg_UserJoin");
             break;
@@ -495,9 +498,21 @@
                 cssClass = "msg_FriendChat";
     }
 
-    bool isHL = (!nick.isEmpty() &&
-                (nick != m_userNick) &&
-                str.toLower().contains(m_hlRegExp));
+    bool isHL = false;
+
+    if ((!nick.isEmpty()) && (nick != m_userNick))
+    {
+        QString lcStr = str.toLower();
+
+        foreach (const QRegExp & hl, m_highlights)
+        {
+            if (lcStr.contains(hl))
+            {
+                isHL = true;
+                break;
+            }
+        }
+    }
 
     addLine(cssClass, formattedStr, isHL);
 }
@@ -584,8 +599,48 @@
     chatStrings.clear();
     chatNicks->clear();
     m_userNick = gameSettings->value("net/nick","").toString();
-    m_hlRegExp = QRegExp(QString("^(.* )?%1(( |[^-a-z0-9_]( |$)).*)?$").
-                            arg(QRegExp::escape(m_userNick).toLower()));
+
+    // clear and re compile regexp for highlighting
+    m_highlights.clear();
+
+    QString hlRegExp("^(.* )?%1(( |[^-a-z0-9_]( |$)).*)?$");
+    QRegExp whitespace("\\s");
+
+    m_highlights.append(QRegExp(hlRegExp.arg(m_userNick)));
+
+    QFile file(cfgdir->absolutePath() + "/" + m_userNick + "_highlight.txt");
+
+    if (file.exists() && (file.open(QIODevice::ReadOnly | QIODevice::Text)))
+    {
+        QTextStream in(&file);
+        while (!in.atEnd())
+        {
+            QString line = in.readLine();
+            QStringList list = line.split(whitespace);
+            foreach (QString word, list)
+            {
+                m_highlights.append(QRegExp(
+                                hlRegExp.arg(QRegExp::escape(word.toLower()))));
+            }
+        }
+
+        if (file.isOpen())
+            file.close();
+    }
+
+    QFile file2(cfgdir->absolutePath() + "/" + m_userNick + "_hlregexp.txt");
+
+    if (file2.exists() && (file2.open(QIODevice::ReadOnly | QIODevice::Text)))
+    {
+        QTextStream in(&file2);
+        while (!in.atEnd())
+        {
+            m_highlights.append(QRegExp(in.readLine().toLower()));
+        }
+
+        if (file2.isOpen())
+            file2.close();
+    }
 }
 
 void HWChatWidget::onKick()
@@ -788,6 +843,9 @@
         displayNotice(tr("Stylesheet imported from %1").arg(path));
         displayNotice(tr("Enter %1 if you want to use the current styleSheet in future, enter %2 to reset!").arg("/saveStyleSheet").arg("/discaredStyleSheet"));
 
+        if (file.isOpen())
+            file.close();
+
         event->acceptProposedAction();
     }
     else
diff -r c0f2e0915e57 -r c06b7e2eb7a4 QTfrontend/ui/widget/chatwidget.h
--- a/QTfrontend/ui/widget/chatwidget.h	Wed Oct 26 02:21:44 2011 +0200
+++ b/QTfrontend/ui/widget/chatwidget.h	Wed Oct 26 05:57:00 2011 +0200
@@ -24,6 +24,7 @@
 #include <QListWidget>
 #include <QString>
 #include <QGridLayout>
+#include <QList>
 #include <QRegExp>
 
 #include "SDLInteraction.h"
@@ -133,7 +134,7 @@
   QString m_helloSound;
   QString m_hilightSound;
   QString m_userNick;
-  QRegExp m_hlRegExp; ///< regular expression used for highlighting messages
+  QList<QRegExp> m_highlights; ///< regular expressions used for highlighting
   bool notify;
   bool showReady;