summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKaalleen <36401965+kaalleen@users.noreply.github.com>2024-05-11 08:19:23 +0200
committerGitHub <noreply@github.com>2024-05-11 08:19:23 +0200
commit18deb5ee3b9244715de6ce28fbc4afdb804781f5 (patch)
treec71a76f81263e8dfccaa99b76b78877c58aedd80
parentbf42ef00ca315e78c0069c01d97517e3786f2135 (diff)
Several fixes (#2893)
* fix untranslatable string in tartan code panel * warn about duplicated glyphs in font file * font sampling: change default line length * prevent element_id referenced before assignment
-rw-r--r--lib/extensions/outline.py2
-rw-r--r--lib/gui/lettering_font_sample.py18
-rw-r--r--lib/gui/tartan/code_panel.py2
3 files changed, 18 insertions, 4 deletions
diff --git a/lib/extensions/outline.py b/lib/extensions/outline.py
index 364cec6d..a4026017 100644
--- a/lib/extensions/outline.py
+++ b/lib/extensions/outline.py
@@ -60,12 +60,12 @@ class Outline(InkstitchExtension):
return d
def element_to_outline(self, element):
+ element_id = element.label or element.get_id()
if element.tag_name == 'g':
for element in element.iterdescendants(SVG_PATH_TAG):
self.element_to_outline(element)
return
elif element.tag_name != 'path':
- element_id = element.label or element.get_id()
errormsg(_("{element_id} is not a path element. "
"This extension is designed to generate an outline of an embroidery pattern.").format(element_id=element_id))
return
diff --git a/lib/gui/lettering_font_sample.py b/lib/gui/lettering_font_sample.py
index af9de5ec..e5312c7e 100644
--- a/lib/gui/lettering_font_sample.py
+++ b/lib/gui/lettering_font_sample.py
@@ -44,7 +44,7 @@ class FontSampleFrame(wx.Frame):
scale_spinner_label = wx.StaticText(self.settings, label=_("Scale (%)"))
self.scale_spinner = wx.SpinCtrl(self.settings, wx.ID_ANY, min=0, max=1000, initial=100)
max_line_width_label = wx.StaticText(self.settings, label=_("Max. line width"))
- self.max_line_width = wx.SpinCtrl(self.settings, wx.ID_ANY, min=0, max=5000, initial=500)
+ self.max_line_width = wx.SpinCtrl(self.settings, wx.ID_ANY, min=0, max=5000, initial=180)
grid_settings_sizer.Add(direction_label, 0, wx.ALIGN_LEFT, 0)
grid_settings_sizer.Add(self.direction, 0, wx.EXPAND, 0)
@@ -157,9 +157,15 @@ class FontSampleFrame(wx.Frame):
"Extensions > Ink/Stitch > Font Management > Update Glyphlist"
% font.marked_custom_font_name
)
- if len(font.available_glyphs) != len(font_variant.glyphs):
+
+ self.duplicate_warning(font)
+
+ # font variant glyph list length falls short if a single quote sign is available
+ # let's add it in the length comparison
+ if len(set(font.available_glyphs)) != len(font_variant.glyphs):
errormsg(update_glyphlist_warning)
printed_warning = True
+
for glyph in font.available_glyphs:
glyph_obj = font_variant[glyph]
if glyph_obj is None:
@@ -189,6 +195,14 @@ class FontSampleFrame(wx.Frame):
font.render_text(text, self.layer, variant=direction, back_and_forth=False)
self.GetTopLevelParent().Close()
+ def duplicate_warning(self, font):
+ # warn about duplicated glyphs
+ if len(set(font.available_glyphs)) != len(font.available_glyphs):
+ duplicated_glyphs = " ".join(
+ [glyph for glyph in set(font.available_glyphs) if font.available_glyphs.count(glyph) > 1]
+ )
+ errormsg(_("Found duplicated glyphs in font file: {duplicated_glyphs}").format(duplicated_glyphs=duplicated_glyphs))
+
def cancel(self, event):
self.GetTopLevelParent().Close()
diff --git a/lib/gui/tartan/code_panel.py b/lib/gui/tartan/code_panel.py
index f9dfe475..02d8d93c 100644
--- a/lib/gui/tartan/code_panel.py
+++ b/lib/gui/tartan/code_panel.py
@@ -31,7 +31,7 @@ class CodePanel(wx.Panel):
code_sizer.Add(tt_unit_sizer, 0, wx.ALL, 10)
- load_button = wx.Button(self, label="Apply Code")
+ load_button = wx.Button(self, label=_("Apply Code"))
load_button.Bind(wx.EVT_BUTTON, self._load_palette_code)
load_palette_sizer.Add(load_button, 0, wx.ALL, 10)