X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fuisupport%2Fqssparser.cpp;h=2aa09ffd1456563f373a63b4c031f89fc592ee59;hb=76ff3775486d1f813d932adf38a53b45966eb274;hp=88cf885bfdad639f10002521338a987cecdf42d5;hpb=51aa1cb1a7ce6313e89e74818916dbaaf72be290;p=quassel.git diff --git a/src/uisupport/qssparser.cpp b/src/uisupport/qssparser.cpp index 88cf885b..2aa09ffd 100644 --- a/src/uisupport/qssparser.cpp +++ b/src/uisupport/qssparser.cpp @@ -83,7 +83,7 @@ void QssParser::loadStyleSheet(const QString &styleSheet) { while((pos = blockrx.indexIn(ss, pos)) >= 0) { //qDebug() << blockrx.cap(1) << blockrx.cap(2); - if(blockrx.cap(2) == "ChatLine") + if(blockrx.cap(1).startsWith("ChatLine")) parseChatLineData(blockrx.cap(1).trimmed(), blockrx.cap(2).trimmed()); //else // TODO: add moar here @@ -107,12 +107,34 @@ void QssParser::parseChatLineData(const QString &decl, const QString &contents) continue; } QString property = line.left(idx).trimmed(); - QString value = line.mid(idx + 1).trimmed(); + QString value = line.mid(idx + 1).simplified(); if(property == "background" || property == "background-color") - format.setBackground(parseBrushValue(value)); + format.setBackground(parseBrush(value)); else if(property == "foreground" || property == "color") - format.setForeground(parseBrushValue(value)); + format.setForeground(parseBrush(value)); + + // font-related properties + else if(property.startsWith("font")) { + bool ok; + QFont font = format.font(); + if(property == "font") + ok = parseFont(value, &font); + else if(property == "font-style") + ok = parseFontStyle(value, &font); + else if(property == "font-weight") + ok = parseFontWeight(value, &font); + else if(property == "font-size") + ok = parseFontSize(value, &font); + else if(property == "font-family") + ok = parseFontFamily(value, &font); + else { + qWarning() << Q_FUNC_INFO << tr("Invalid font property: %1").arg(line); + continue; + } + if(ok) + format.setFont(font); + } else { qWarning() << Q_FUNC_INFO << tr("Unknown ChatLine property: %1").arg(property); @@ -137,15 +159,15 @@ quint64 QssParser::parseFormatType(const QString &decl) { // First determine the subelement if(!subElement.isEmpty()) { - if(subElement == "Timestamp") + if(subElement == "timestamp") fmtType |= UiStyle::Timestamp; - else if(subElement == "Sender") + else if(subElement == "sender") fmtType |= UiStyle::Sender; - else if(subElement == "Nick") + else if(subElement == "nick") fmtType |= UiStyle::Nick; - else if(subElement == "Hostmask") + else if(subElement == "hostmask") fmtType |= UiStyle::Hostmask; - else if(subElement == "ModeFlags") + else if(subElement == "modeflags") fmtType |= UiStyle::ModeFlags; else { qWarning() << Q_FUNC_INFO << tr("Invalid subelement name in %1").arg(decl); @@ -155,28 +177,34 @@ quint64 QssParser::parseFormatType(const QString &decl) { // Now, figure out the message type if(!msgType.isEmpty()) { - if(msgType == "Plain") + if(msgType == "plain") fmtType |= UiStyle::PlainMsg; - else if(msgType == "Notice") + else if(msgType == "notice") fmtType |= UiStyle::NoticeMsg; - else if(msgType == "Server") - fmtType |= UiStyle::ServerMsg; - else if(msgType == "Error") - fmtType |= UiStyle::ErrorMsg; - else if(msgType == "Join") + else if(msgType == "action") + fmtType |= UiStyle::ActionMsg; + else if(msgType == "nick") + fmtType |= UiStyle::NickMsg; + else if(msgType == "mode") + fmtType |= UiStyle::ModeMsg; + else if(msgType == "join") fmtType |= UiStyle::JoinMsg; - else if(msgType == "Part") + else if(msgType == "part") fmtType |= UiStyle::PartMsg; - else if(msgType == "Quit") + else if(msgType == "quit") fmtType |= UiStyle::QuitMsg; - else if(msgType == "Kick") + else if(msgType == "kick") fmtType |= UiStyle::KickMsg; - else if(msgType == "Rename") - fmtType |= UiStyle::RenameMsg; - else if(msgType == "Mode") - fmtType |= UiStyle::ModeMsg; - else if(msgType == "Action") - fmtType |= UiStyle::ActionMsg; + else if(msgType == "kill") + fmtType |= UiStyle::KillMsg; + else if(msgType == "server") + fmtType |= UiStyle::ServerMsg; + else if(msgType == "info") + fmtType |= UiStyle::InfoMsg; + else if(msgType == "error") + fmtType |= UiStyle::ErrorMsg; + else if(msgType == "daychange") + fmtType |= UiStyle::DayChangeMsg; else { qWarning() << Q_FUNC_INFO << tr("Invalid message type in %1").arg(decl); } @@ -262,7 +290,7 @@ void QssParser::parsePaletteData(const QString &decl, const QString &contents) { qWarning() << Q_FUNC_INFO << tr("Unknown palette role name: %1").arg(rolestr); continue; } - QBrush brush = parseBrushValue(brushstr); + QBrush brush = parseBrush(brushstr); if(colorGroups.count()) { foreach(QPalette::ColorGroup group, colorGroups) _palette.setBrush(group, _paletteColorRoles.value(rolestr), brush); @@ -271,10 +299,10 @@ void QssParser::parsePaletteData(const QString &decl, const QString &contents) { } } -QBrush QssParser::parseBrushValue(const QString &str, bool *ok) { +QBrush QssParser::parseBrush(const QString &str, bool *ok) { if(ok) *ok = false; - QColor c = parseColorValue(str); + QColor c = parseColor(str); if(c.isValid()) { if(ok) *ok = true; @@ -363,7 +391,7 @@ QBrush QssParser::parseBrushValue(const QString &str, bool *ok) { return QBrush(); } -QColor QssParser::parseColorValue(const QString &str) { +QColor QssParser::parseColor(const QString &str) { if(str.startsWith("rgba")) { ColorTuple tuple = parseColorTuple(str.mid(4)); if(tuple.count() == 4) @@ -429,7 +457,7 @@ QGradientStops QssParser::parseGradientStops(const QString &str_) { int idx; while((idx = rx.indexIn(str)) == 0) { qreal x = rx.cap(1).toDouble(); - QColor c = parseColorValue(rx.cap(3)); + QColor c = parseColor(rx.cap(3)); if(!c.isValid()) return QGradientStops(); result << QGradientStop(x, c); @@ -440,3 +468,89 @@ QGradientStops QssParser::parseGradientStops(const QString &str_) { return result; } + +/******** Font Properties ********/ + +bool QssParser::parseFont(const QString &value, QFont *font) { + QRegExp rx("((?:(?:normal|italic|oblique|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 false; + } + font->setStyle(QFont::StyleNormal); + font->setWeight(QFont::Normal); + QStringList proplist = rx.cap(1).split(' ', QString::SkipEmptyParts); + foreach(QString prop, proplist) { + if(prop == "italic") + font->setStyle(QFont::StyleItalic); + else if(prop == "oblique") + font->setStyle(QFont::StyleOblique); + else if(prop == "bold") + font->setWeight(QFont::Bold); + else { // number + int w = prop.toInt(); + font->setWeight(qMin(w / 8, 99)); // taken from Qt's qss parser + } + } + + if(rx.cap(3) == "px") + font->setPixelSize(rx.cap(2).toInt()); + else + font->setPointSize(rx.cap(2).toInt()); + + font->setFamily(rx.cap(4)); + return true; +} + +bool QssParser::parseFontStyle(const QString &value, QFont *font) { + if(value == "normal") + font->setStyle(QFont::StyleNormal); + else if(value == "italic") + font->setStyle(QFont::StyleItalic); + else if(value == "oblique") + font->setStyle(QFont::StyleOblique); + else { + qWarning() << Q_FUNC_INFO << tr("Invalid font style specification: %1").arg(value); + return false; + } + return true; +} + +bool QssParser::parseFontWeight(const QString &value, QFont *font) { + if(value == "normal") + font->setWeight(QFont::Normal); + else if(value == "bold") + font->setWeight(QFont::Bold); + else { + bool ok; + int w = value.toInt(&ok); + if(!ok) { + qWarning() << Q_FUNC_INFO << tr("Invalid font weight specification: %1").arg(value); + return false; + } + font->setWeight(qMin(w / 8, 99)); // taken from Qt's qss parser + } + return true; +} + +bool QssParser::parseFontSize(const QString &value, QFont *font) { + QRegExp rx("\\(d+)(pt|px)"); + if(!rx.exactMatch(value)) { + qWarning() << Q_FUNC_INFO << tr("Invalid font size specification: %1").arg(value); + return false; + } + if(rx.cap(2) == "px") + font->setPixelSize(rx.cap(1).toInt()); + else + font->setPointSize(rx.cap(1).toInt()); + return true; +} + +bool QssParser::parseFontFamily(const QString &value, QFont *font) { + QString family = value; + if(family.startsWith('"') && family.endsWith('"')) { + family = family.mid(1, family.length() -2); + } + font->setFamily(family); + return true; +}