From a5ab7f48c164182e48b609bf446fc9f18d1df266 Mon Sep 17 00:00:00 2001 From: Akuli Date: Mon, 6 Nov 2023 18:37:37 +0200 Subject: [PATCH] Do not use "font metrics ... -fixed" in monospace detection --- porcupine/settings.py | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/porcupine/settings.py b/porcupine/settings.py index 99ea91f38..edfd9a7c8 100644 --- a/porcupine/settings.py +++ b/porcupine/settings.py @@ -895,10 +895,8 @@ def _is_monospace(font_family: str) -> bool: if "emoji" in font_family.lower(): return False - # Let's first ask Tcl whether the font is fixed. This is fastest but - # returns the wrong result for some fonts that are not actually monospace. - if not tcl_interpreter.call("font", "metrics", (font_family, "12"), "-fixed"): - return False + # We can't use "font metrics ... -fixed" because it is sometimes wrong. + # https://github.com/Akuli/porcupine/issues/1368 # In non-monospace fonts, i is very narrow and m is very wide. # Also, make sure that bolding or italic doesn't change the width. @@ -923,7 +921,7 @@ def _get_monospace_font_families() -> list[str]: cache = json.load(file) # all_families stored to cache in case user installs more fonts - if cache["version"] == 2 and cache["all_families"] == all_families: + if cache["version"] == 3 and cache["all_families"] == all_families: _log.debug(f"Taking list of monospace families from {cache_path}") return cache["monospace_families"] @@ -939,7 +937,7 @@ def _get_monospace_font_families() -> list[str]: with cache_path.open("w") as file: json.dump( { - "version": 2, + "version": 3, "all_families": all_families, "monospace_families": monospace_families, },