From: Manuel Nickschas Date: Sun, 21 Jun 2009 21:38:53 +0000 (+0200) Subject: Fix QSS font handling X-Git-Tag: 0.5-rc1~137 X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=commitdiff_plain;h=03976b69a41261782602d745805a178d8f3f1dc9 Fix QSS font handling This fixes some issues with merging font properties in stylesheets. As a side-effect, we don't parse the "oblique" font style anymore, as this is not a supported QTextFormat property. --- diff --git a/src/uisupport/qssparser.cpp b/src/uisupport/qssparser.cpp index 41bd0aaf..d7a788e9 100644 --- a/src/uisupport/qssparser.cpp +++ b/src/uisupport/qssparser.cpp @@ -116,24 +116,20 @@ void QssParser::parseChatLineData(const QString &decl, const QString &contents) // font-related properties else if(property.startsWith("font")) { - bool ok; - QFont font = format.font(); if(property == "font") - ok = parseFont(value, &font); + parseFont(value, &format); else if(property == "font-style") - ok = parseFontStyle(value, &font); + parseFontStyle(value, &format); else if(property == "font-weight") - ok = parseFontWeight(value, &font); + parseFontWeight(value, &format); else if(property == "font-size") - ok = parseFontSize(value, &font); + parseFontSize(value, &format); else if(property == "font-family") - ok = parseFontFamily(value, &font); + parseFontFamily(value, &format); else { qWarning() << Q_FUNC_INFO << tr("Invalid font property: %1").arg(line); continue; } - if(ok) - format.setFont(font); } else { @@ -473,86 +469,80 @@ QGradientStops QssParser::parseGradientStops(const QString &str_) { /******** Font Properties ********/ -bool QssParser::parseFont(const QString &value, QFont *font) { +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)? \"(.*)\""); if(!rx.exactMatch(value)) { qWarning() << Q_FUNC_INFO << tr("Invalid font specification: %1").arg(value); - return false; + return; } - font->setStyle(QFont::StyleNormal); - font->setWeight(QFont::Normal); + format->setFontItalic(false); + format->setFontWeight(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); + format->setFontItalic(true); + //else if(prop == "oblique") + // format->setStyle(QFont::StyleOblique); else if(prop == "bold") - font->setWeight(QFont::Bold); + format->setFontWeight(QFont::Bold); else { // number int w = prop.toInt(); - font->setWeight(qMin(w / 8, 99)); // taken from Qt's qss parser + format->setFontWeight(qMin(w / 8, 99)); // taken from Qt's qss parser } } if(rx.cap(3) == "px") - font->setPixelSize(rx.cap(2).toInt()); + format->setProperty(QTextFormat::FontPixelSize, rx.cap(2).toInt()); else - font->setPointSize(rx.cap(2).toInt()); + format->setFontPointSize(rx.cap(2).toInt()); - font->setFamily(rx.cap(4)); - return true; + format->setFontFamily(rx.cap(4)); } -bool QssParser::parseFontStyle(const QString &value, QFont *font) { +void QssParser::parseFontStyle(const QString& value, QTextCharFormat* format) { if(value == "normal") - font->setStyle(QFont::StyleNormal); + format->setFontItalic(false); else if(value == "italic") - font->setStyle(QFont::StyleItalic); - else if(value == "oblique") - font->setStyle(QFont::StyleOblique); + format->setFontItalic(true); + //else if(value == "oblique") + // format->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) { +void QssParser::parseFontWeight(const QString& value, QTextCharFormat* format) { if(value == "normal") - font->setWeight(QFont::Normal); + format->setFontWeight(QFont::Normal); else if(value == "bold") - font->setWeight(QFont::Bold); + format->setFontWeight(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; + return; } - font->setWeight(qMin(w / 8, 99)); // taken from Qt's qss parser + format->setFontWeight(qMin(w / 8, 99)); // taken from Qt's qss parser } - return true; } -bool QssParser::parseFontSize(const QString &value, QFont *font) { +void QssParser::parseFontSize(const QString& value, QTextCharFormat* format) { QRegExp rx("\\(d+)(pt|px)"); if(!rx.exactMatch(value)) { qWarning() << Q_FUNC_INFO << tr("Invalid font size specification: %1").arg(value); - return false; + return; } if(rx.cap(2) == "px") - font->setPixelSize(rx.cap(1).toInt()); + format->setProperty(QTextFormat::FontPixelSize, rx.cap(1).toInt()); else - font->setPointSize(rx.cap(1).toInt()); - return true; + format->setFontPointSize(rx.cap(1).toInt()); } -bool QssParser::parseFontFamily(const QString &value, QFont *font) { +void QssParser::parseFontFamily(const QString& value, QTextCharFormat* format) { QString family = value; if(family.startsWith('"') && family.endsWith('"')) { - family = family.mid(1, family.length() -2); + family = family.mid(1, family.length() - 2); } - font->setFamily(family); - return true; + format->setFontFamily(family); } diff --git a/src/uisupport/qssparser.h b/src/uisupport/qssparser.h index bb64e216..37a642ef 100644 --- a/src/uisupport/qssparser.h +++ b/src/uisupport/qssparser.h @@ -52,11 +52,11 @@ class QssParser { QGradientStops parseGradientStops(const QString &str); // Parse font-related properties - bool parseFont(const QString &str, QFont *font); - bool parseFontStyle(const QString &str, QFont *font); - bool parseFontWeight(const QString &str, QFont *font); - bool parseFontSize(const QString &str, QFont *font); - bool parseFontFamily(const QString &str, QFont *font); + void parseFont(const QString &str, QTextCharFormat *format); + void parseFontStyle(const QString &str, QTextCharFormat *format); + void parseFontWeight(const QString &str, QTextCharFormat *format); + void parseFontSize(const QString &str, QTextCharFormat *format); + void parseFontFamily(const QString &str, QTextCharFormat *format); QHash _paletteColorRoles; diff --git a/src/uisupport/uistyle.cpp b/src/uisupport/uistyle.cpp index 80a29b2f..229e4bab 100644 --- a/src/uisupport/uistyle.cpp +++ b/src/uisupport/uistyle.cpp @@ -204,7 +204,7 @@ UiStyle::StyledString UiStyle::styleString(const QString &s_, quint32 baseFormat return StyledString(); } StyledString result; - result.formatList.append(qMakePair((quint16)0, (quint32)None)); + result.formatList.append(qMakePair((quint16)0, baseFormat)); quint32 curfmt = baseFormat; int pos = 0; quint16 length = 0; for(;;) {