From 980539864401ed05cd9b39450d8634e26192408b Mon Sep 17 00:00:00 2001 From: Lex Neva Date: Wed, 2 Nov 2016 23:17:36 -0400 Subject: [PATCH] add embroider_update extension to convert old-style param names to new --- embroider_update.inx | 16 +++++++++++++++ embroider_update.py | 46 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 62 insertions(+) create mode 100644 embroider_update.inx create mode 100644 embroider_update.py diff --git a/embroider_update.inx b/embroider_update.inx new file mode 100644 index 000000000..b700e605a --- /dev/null +++ b/embroider_update.inx @@ -0,0 +1,16 @@ + + + <_name>Update embroidery param names + lexelby.embroider.update + embroider_update.py + inkex.py + + all + + + + + + diff --git a/embroider_update.py b/embroider_update.py new file mode 100644 index 000000000..5597cdcc6 --- /dev/null +++ b/embroider_update.py @@ -0,0 +1,46 @@ +#!/usr/bin/python +# +# Update embroidery parameters stored in XML attributes from old to new +# format. + +import sys +sys.path.append("/usr/share/inkscape/extensions") +import os +import inkex + +PIXELS_PER_MM = 10 + +class EmbroiderParams(inkex.Effect): + def __init__(self, *args, **kwargs): + inkex.Effect.__init__(self) + + self.mapping = { "zigzag_spacing": "zigzag_spacing_mm", + "row_spacing": "row_spacing_mm", + "pull_compensation": "pull_compensation_mm", + "max_stitch_length": "max_stitch_length_mm", + "satin_underlay": "contour_underlay", + "satin_underlay_inset": "contour_underlay_inset_mm", + "satin_zigzag_underlay_spacing": "zigzag_underlay_spacing_mm", + "satin_center_walk": "center_walk_underlay", + "stitch_length": "running_stitch_length_mm", + } + + def effect(self): + for node in self.document.getroot().iter(): + for old, new in self.mapping.iteritems(): + old = "embroider_%s" % old + new = "embroider_%s" % new + + value = node.attrib.pop(old, None) + if value: + if new.endswith('_mm') and value.strip(): + value = str(float(value) / PIXELS_PER_MM) + + node.set(new, value) + + if 'embroider_zigzag_underlay_spacing_mm' in node.attrib: + node.set('embroider_zigzag_underlay', 'yes') + +if __name__ == '__main__': + e = EmbroiderParams() + e.affect()