X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;ds=sidebyside;f=src%2Fuisupport%2Fqssparser.cpp;h=091ac4b2dfa61fd742f606d1364bb017d92ed46b;hb=120861b909702039da9993278d8319dad14fd292;hp=52ce79ac2ef610b642ab8826b62c064adba9af8f;hpb=0ff679f6bdd6729d12bee1ed7a2b6ac812c3e31c;p=quassel.git diff --git a/src/uisupport/qssparser.cpp b/src/uisupport/qssparser.cpp index 52ce79ac..091ac4b2 100644 --- a/src/uisupport/qssparser.cpp +++ b/src/uisupport/qssparser.cpp @@ -49,6 +49,22 @@ QssParser::QssParser() _paletteColorRoles["tooltip-text"] = QPalette::ToolTipText; _paletteColorRoles["window"] = QPalette::Window; _paletteColorRoles["window-text"] = QPalette::WindowText; + + _uiStylePalette = QVector(UiStyle::NumRoles, QBrush()); + + _uiStyleColorRoles["marker-line"] = UiStyle::MarkerLine; + _uiStyleColorRoles["active-nick"] = UiStyle::ActiveNick; + _uiStyleColorRoles["inactive-nick"] = UiStyle::InactiveNick; + _uiStyleColorRoles["channel"] = UiStyle::Channel; + _uiStyleColorRoles["inactive-channel"] = UiStyle::InactiveChannel; + _uiStyleColorRoles["active-channel"] = UiStyle::ActiveChannel; + _uiStyleColorRoles["unread-channel"] = UiStyle::UnreadChannel; + _uiStyleColorRoles["highlighted-channel"] = UiStyle::HighlightedChannel; + _uiStyleColorRoles["query"] = UiStyle::Query; + _uiStyleColorRoles["inactive-query"] = UiStyle::InactiveQuery; + _uiStyleColorRoles["active-query"] = UiStyle::ActiveQuery; + _uiStyleColorRoles["unread-query"] = UiStyle::UnreadQuery; + _uiStyleColorRoles["highlighted-query"] = UiStyle::HighlightedQuery; } void QssParser::processStyleSheet(QString &ss) { @@ -127,7 +143,7 @@ void QssParser::parseChatLineData(const QString &decl, const QString &contents) } } - _formats[fmtType] = format; + _formats[fmtType].merge(format); } quint64 QssParser::parseFormatType(const QString &decl) { @@ -212,6 +228,8 @@ quint64 QssParser::parseFormatType(const QString &decl) { quint64 labeltype = 0; if(condValue == "highlight") labeltype = UiStyle::Highlight; + else if(condValue == "selected") + labeltype = UiStyle::Selected; else { qWarning() << Q_FUNC_INFO << tr("Invalid message label: %1").arg(condValue); return UiStyle::Invalid; @@ -300,16 +318,18 @@ void QssParser::parsePaletteData(const QString &decl, const QString &contents) { } QString rolestr = line.left(idx).trimmed(); QString brushstr = line.mid(idx + 1).trimmed(); - if(!_paletteColorRoles.contains(rolestr)) { - qWarning() << Q_FUNC_INFO << tr("Unknown palette role name: %1").arg(rolestr); - continue; - } - QBrush brush = parseBrush(brushstr); - if(colorGroups.count()) { - foreach(QPalette::ColorGroup group, colorGroups) - _palette.setBrush(group, _paletteColorRoles.value(rolestr), brush); + + if(_paletteColorRoles.contains(rolestr)) { + QBrush brush = parseBrush(brushstr); + if(colorGroups.count()) { + foreach(QPalette::ColorGroup group, colorGroups) + _palette.setBrush(group, _paletteColorRoles.value(rolestr), brush); + } else + _palette.setBrush(_paletteColorRoles.value(rolestr), brush); + } else if(_uiStyleColorRoles.contains(rolestr)) { + _uiStylePalette[_uiStyleColorRoles.value(rolestr)] = parseBrush(brushstr); } else - _palette.setBrush(_paletteColorRoles.value(rolestr), brush); + qWarning() << Q_FUNC_INFO << tr("Unknown palette role name: %1").arg(rolestr); } } @@ -329,11 +349,12 @@ QBrush QssParser::parseBrush(const QString &str, bool *ok) { qWarning() << Q_FUNC_INFO << tr("Invalid palette color role specification: %1").arg(str); return QBrush(); } - if(!_paletteColorRoles.contains(rx.cap(1))) { - qWarning() << Q_FUNC_INFO << tr("Unknown palette color role: %1").arg(rx.cap(1)); - return QBrush(); - } - return QBrush(_palette.brush(_paletteColorRoles.value(rx.cap(1)))); + if(_paletteColorRoles.contains(rx.cap(1))) + return QBrush(_palette.brush(_paletteColorRoles.value(rx.cap(1)))); + if(_uiStyleColorRoles.contains(rx.cap(1))) + return QBrush(_uiStylePalette.at(_uiStyleColorRoles.value(rx.cap(1)))); + qWarning() << Q_FUNC_INFO << tr("Unknown palette color role: %1").arg(rx.cap(1)); + return QBrush(); } else if(str.startsWith("qlineargradient")) { static QString rxFloat("\\s*(-?\\s*[0-9]*\\.?[0-9]+)\\s*"); @@ -486,7 +507,7 @@ QGradientStops QssParser::parseGradientStops(const QString &str_) { /******** Font Properties ********/ void QssParser::parseFont(const QString& value, QTextCharFormat* format) { - QRegExp rx("((?:(?:normal|italic|oblique|bold|100|200|300|400|500|600|700|800|900) ){0,2}) ?(\\d+)(pt|px)? \"(.*)\""); + QRegExp rx("((?:(?:normal|italic|oblique|underline|bold|100|200|300|400|500|600|700|800|900) ){0,2}) ?(\\d+)(pt|px)? \"(.*)\""); if(!rx.exactMatch(value)) { qWarning() << Q_FUNC_INFO << tr("Invalid font specification: %1").arg(value); return; @@ -497,6 +518,8 @@ void QssParser::parseFont(const QString& value, QTextCharFormat* format) { foreach(QString prop, proplist) { if(prop == "italic") format->setFontItalic(true); + else if(prop == "underline") + format->setFontUnderline(true); //else if(prop == "oblique") // format->setStyle(QFont::StyleOblique); else if(prop == "bold") @@ -520,6 +543,8 @@ void QssParser::parseFontStyle(const QString& value, QTextCharFormat* format) { format->setFontItalic(false); else if(value == "italic") format->setFontItalic(true); + else if(value == "underline") + format->setFontUnderline(true); //else if(value == "oblique") // format->setStyle(QFont::StyleOblique); else {