summaryrefslogtreecommitdiff
path: root/gerbonara/cad/kicad/pcb.py
diff options
context:
space:
mode:
authorjaseg <git@jaseg.de>2023-06-21 13:37:38 +0200
committerjaseg <git@jaseg.de>2023-06-21 13:37:38 +0200
commit467e482bf435fce83900fb446761dded4ffd7b31 (patch)
tree3fce9951c9fb64b0125ecc55d8a7ff193dc1c628 /gerbonara/cad/kicad/pcb.py
parentdd8507d202e1fe0dbcb39aacf87fb07eaa07ec8a (diff)
downloadgerbonara-467e482bf435fce83900fb446761dded4ffd7b31.tar.gz
gerbonara-467e482bf435fce83900fb446761dded4ffd7b31.tar.bz2
gerbonara-467e482bf435fce83900fb446761dded4ffd7b31.zip
Fix pcb stackup handling
Diffstat (limited to 'gerbonara/cad/kicad/pcb.py')
-rw-r--r--gerbonara/cad/kicad/pcb.py11
1 files changed, 7 insertions, 4 deletions
diff --git a/gerbonara/cad/kicad/pcb.py b/gerbonara/cad/kicad/pcb.py
index bb608bb..8a90a7e 100644
--- a/gerbonara/cad/kicad/pcb.py
+++ b/gerbonara/cad/kicad/pcb.py
@@ -33,12 +33,12 @@ class PageSettings:
page_format: str = 'A4'
width: float = None
height: float = None
- portrait: bool = False
+ portrait: Flag() = False
@sexp_type('layers')
class LayerSettings:
- index: int = None
+ index: int = 0
canonical_name: str = None
layer_type: AtomChoice(Atom.jumper, Atom.mixed, Atom.power, Atom.signal, Atom.user) = Atom.signal
custom_name: str = None
@@ -206,7 +206,7 @@ class Board:
generator: Named(Atom) = Atom.gerbonara
general: GeneralSection = field(default_factory=GeneralSection)
page: PageSettings = field(default_factory=PageSettings)
- layers: Named(Array(LayerSettings)) = field(default_factory=list)
+ layers: Named(Array(Untagged(LayerSettings))) = field(default_factory=list)
setup: BoardSetup = field(default_factory=BoardSetup)
properties: List(Property) = field(default_factory=list)
nets: List(Net) = field(default_factory=list)
@@ -245,7 +245,10 @@ class Board:
def write(self, filename=None):
with open(filename or self.original_filename, 'w') as f:
- f.write(build_sexp(sexp(self)))
+ f.write(self.serialize())
+
+ def serialize(self):
+ return build_sexp(sexp(type(self), self)[0])
@classmethod
def open(kls, pcb_file, *args, **kwargs):