Add a check for monospace font on Linux.

This commit is contained in:
John Preston 2020-05-05 15:16:53 +04:00
parent 06eadc0caf
commit 8660904bc8

View file

@ -85,9 +85,12 @@ bool LoadCustomFont(const QString &filePath, const QString &familyName, int flag
return ValidateFont(familyName, flags); return ValidateFont(familyName, flags);
} }
QString MonospaceFont() { [[nodiscard]] QString SystemMonospaceFont() {
static const auto family = [&]() -> QString { const auto type = QFontDatabase::FixedFont;
#ifndef Q_OS_LINUX return QFontDatabase::systemFont(type).family();
}
[[nodiscard]] QString ManualMonospaceFont() {
const auto kTryFirst = std::initializer_list<QString>{ const auto kTryFirst = std::initializer_list<QString>{
"Consolas", "Consolas",
"Liberation Mono", "Liberation Mono",
@ -100,10 +103,24 @@ QString MonospaceFont() {
return family; return family;
} }
} }
#endif // !Q_OS_LINUX return QString();
}
const auto type = QFontDatabase::FixedFont; QString MonospaceFont() {
return QFontDatabase::systemFont(type).family(); static const auto family = [&]() -> QString {
const auto manual = ManualMonospaceFont();
const auto system = SystemMonospaceFont();
#if defined Q_OS_WIN || defined Q_OS_MAC
// Prefer our monospace font.
const auto useSystem = manual.isEmpty();
#else // Q_OS_WIN || Q_OS_MAC
// Prefer system monospace font.
const auto metrics = QFontMetrics(QFont(system));
const auto useSystem = manual.isEmpty()
|| (metrics.charWidth("i", 0) == metrics.charWidth("W", 0));
#endif // Q_OS_WIN || Q_OS_MAC
return useSystem ? system : manual;
}(); }();
return family; return family;