summaryrefslogtreecommitdiff
path: root/gerbonara/cad
diff options
context:
space:
mode:
authorjaseg <git@jaseg.de>2024-07-18 11:35:25 +0200
committerjaseg <git@jaseg.de>2024-07-18 11:36:13 +0200
commitf1b3ab5e7223d76634878e1231ae0906b5bdbb36 (patch)
tree5523535024307c0884278102c207cc2b656c2113 /gerbonara/cad
parent2092b86431912ad6f16d6eb020edde8d54ad15db (diff)
downloadgerbonara-f1b3ab5e7223d76634878e1231ae0906b5bdbb36.tar.gz
gerbonara-f1b3ab5e7223d76634878e1231ae0906b5bdbb36.tar.bz2
gerbonara-f1b3ab5e7223d76634878e1231ae0906b5bdbb36.zip
kicad: Improve compatibility with old symbol files
Diffstat (limited to 'gerbonara/cad')
-rw-r--r--gerbonara/cad/kicad/base_types.py2
-rw-r--r--gerbonara/cad/kicad/sexp_mapper.py18
2 files changed, 19 insertions, 1 deletions
diff --git a/gerbonara/cad/kicad/base_types.py b/gerbonara/cad/kicad/base_types.py
index a4eba70..c5c04e9 100644
--- a/gerbonara/cad/kicad/base_types.py
+++ b/gerbonara/cad/kicad/base_types.py
@@ -345,7 +345,7 @@ class Justify:
@sexp_type('effects')
class TextEffect:
font: FontSpec = field(default_factory=FontSpec)
- hide: OmitDefault(Named(YesNoAtom())) = False
+ hide: OmitDefault(Named(LegacyCompatibleFlag())) = False
justify: OmitDefault(Justify) = field(default_factory=Justify)
diff --git a/gerbonara/cad/kicad/sexp_mapper.py b/gerbonara/cad/kicad/sexp_mapper.py
index d2d9d30..c197765 100644
--- a/gerbonara/cad/kicad/sexp_mapper.py
+++ b/gerbonara/cad/kicad/sexp_mapper.py
@@ -202,6 +202,24 @@ class YesNoAtom:
yield self.yes if value else self.no
+class LegacyCompatibleFlag:
+ '''Variant of YesNoAtom that accepts both the `(flag <yes/no>)` variant and the bare `flag` variant for compatibility.'''
+
+ def __init__(self, yes=Atom.yes, no=Atom.no, value_when_empty=True):
+ self.yes, self.no = yes, no
+ self.value_when_empty = value_when_empty
+
+ def __map__(self, value, parent=None):
+ if value == []:
+ return self.value_when_empty
+
+ value, = value
+ return value == self.yes
+
+ def __sexp__(self, value):
+ yield self.yes if value else self.no
+
+
class Wrap(WrapperType):
def __map__(self, value, parent=None):
value, = value