summaryrefslogtreecommitdiff
path: root/lib/lettering
diff options
context:
space:
mode:
authorKaalleen <36401965+kaalleen@users.noreply.github.com>2024-07-10 16:06:24 +0200
committerGitHub <noreply@github.com>2024-07-10 16:06:24 +0200
commit9f4e397947fd0d1978fbef687e7cab9b6d98ea52 (patch)
treebbb26cd27e009bbcb6fb6515b0f425ac0b7faa56 /lib/lettering
parentef6df385c30f85c739dc5c5098134529ed52d160 (diff)
Lettering: skip font with corrupt json file (#3071)
* lettering: warn about corrupt/missing json file * ignore hidden directories and files placed directly in the font folder
Diffstat (limited to 'lib/lettering')
-rw-r--r--lib/lettering/font.py14
-rw-r--r--lib/lettering/utils.py2
2 files changed, 15 insertions, 1 deletions
diff --git a/lib/lettering/font.py b/lib/lettering/font.py
index 17c6f0f9..431dc8d4 100644
--- a/lib/lettering/font.py
+++ b/lib/lettering/font.py
@@ -91,7 +91,19 @@ class Font(object):
with open(os.path.join(self.path, "font.json"), encoding="utf-8-sig") as metadata_file:
self.metadata = json.load(metadata_file)
except IOError:
- pass
+ path = os.path.join(self.path, "font.json")
+ msg = _("JSON file missing. Expected a JSON file at the following location:")
+ msg += f"\n{path}\n\n"
+ msg += _("Generate the JSON file through:\nExtensions > Ink/Stitch > Font Management > Generate JSON...")
+ msg += '\n\n'
+ inkex.errormsg(msg)
+ except json.decoder.JSONDecodeError as exception:
+ path = os.path.join(self.path, "font.json")
+ msg = _("Corrupt JSON file")
+ msg += f" ({exception}):\n{path}\n\n"
+ msg += _("Regenerate the JSON file through:\nExtensions > Ink/Stitch > Font Management > Generate JSON...")
+ msg += '\n\n'
+ inkex.errormsg(msg)
def _load_license(self):
try:
diff --git a/lib/lettering/utils.py b/lib/lettering/utils.py
index d1ec1b8e..1ba1bb9a 100644
--- a/lib/lettering/utils.py
+++ b/lib/lettering/utils.py
@@ -23,6 +23,8 @@ def get_font_list():
continue
for font_dir in font_dirs:
+ if not os.path.isdir(os.path.join(font_path, font_dir)) or font_dir.startswith('.'):
+ continue
font = Font(os.path.join(font_path, font_dir))
if font.marked_custom_font_name == "" or font.marked_custom_font_id == "":
continue