diff options
author | Trygve Laugstøl <trygvis@inamo.no> | 2019-03-28 16:38:50 +0100 |
---|---|---|
committer | Trygve Laugstøl <trygvis@inamo.no> | 2019-03-28 16:43:14 +0100 |
commit | fa85d46af0b91477cf354947df628af0dc0d2800 (patch) | |
tree | b18b775d232560f57eaeb3f43d0861b98201d4ef /demo/thirdparty/olinuxino/py | |
parent | 52401b170d8f1c9deaa153acca76e7d6060a06df (diff) | |
download | ee-python-fa85d46af0b91477cf354947df628af0dc0d2800.tar.gz ee-python-fa85d46af0b91477cf354947df628af0dc0d2800.tar.bz2 ee-python-fa85d46af0b91477cf354947df628af0dc0d2800.tar.xz ee-python-fa85d46af0b91477cf354947df628af0dc0d2800.zip |
ee.xsd:
o Renaming <part-uri> to <part-reference>.
o Adding <supplier> on <part>, removing from <supplier-part-number>. A
part can have exactly one part.
create-order:
o Creating anonymous part objects, with two references, one schematic
reference and one part-uri reference to the selected part.
o Redoing how the order is calculated with the new ObjDb structure.
ee.part.Part:
o Absorbing bom_file_utils into Part. Much better wrapper object around
the xml goop.
Diffstat (limited to 'demo/thirdparty/olinuxino/py')
-rw-r--r-- | demo/thirdparty/olinuxino/py/olinuxino.py | 35 |
1 files changed, 17 insertions, 18 deletions
diff --git a/demo/thirdparty/olinuxino/py/olinuxino.py b/demo/thirdparty/olinuxino/py/olinuxino.py index 0b6fd1e..49b634f 100644 --- a/demo/thirdparty/olinuxino/py/olinuxino.py +++ b/demo/thirdparty/olinuxino/py/olinuxino.py @@ -3,9 +3,8 @@ import re from ee import EeException, EeVal from ee.kicad import Component from ee.kicad.make_bom import MakeBomStrategy -from ee.xml import types, bom_file_utils -from ee.part import fact_keys -from ee.xml.bom_file_utils import facts +from ee.xml import types +from ee.part import fact_keys, Part c_value_re = re.compile("([0-9]+\\.?[0-9]*[mupn]F)/([0-9]+\\.?[0-9]*[k]?V)/([0-9]+)%(?:/([A-Z][0-9][A-Z]))?") r_value_re = re.compile(r"([^/]+)(?:/([^/]+)(?:/([^/]+))?)?") @@ -14,14 +13,14 @@ r_value_re = re.compile(r"([^/]+)(?:/([^/]+)(?:/([^/]+))?)?") class OlinuxinoMakeBomStrategy(MakeBomStrategy): @staticmethod - def set_default(fs, fact_key: str, value): - fact = bom_file_utils.find_fact(fs, fact_key) + def set_default(part: Part, fact_key: str, value): + fact = part.find_fact(fact_key) if fact: return - fs.add_fact(types.Fact(key=fact_key, value=value)) + part.get_facts().append(types.Fact(key=fact_key, value=value)) - def process_part(self, component: Component, part: types.Part): + def process_part(self, component: Component, part: Part): debug = False print(component.ref) @@ -35,7 +34,7 @@ class OlinuxinoMakeBomStrategy(MakeBomStrategy): s = component.footprint.split(":") fp_lib, fp_part = s[0], s[1] - fs = facts(part, create=True) + fs = part.get_facts() na = v.startswith("NA(") and v.endswith(")") or v == "NA" if na: @@ -63,11 +62,11 @@ class OlinuxinoMakeBomStrategy(MakeBomStrategy): if na: print(" NA".format()) - fs.add_fact(types.Fact(key=fact_keys.capacitance, value=capacitance)) - fs.add_fact(types.Fact(key=fact_keys.max_voltage, value=voltage)) - fs.add_fact(types.Fact(key=fact_keys.value_tolerance, value=tolerance)) + fs.append(types.Fact(key=fact_keys.capacitance, value=capacitance)) + fs.append(types.Fact(key=fact_keys.max_voltage, value=voltage)) + fs.append(types.Fact(key=fact_keys.value_tolerance, value=tolerance)) if rs_198_class_2: - fs.add_fact(types.Fact(key=fact_keys.rs_198_class_2, value=rs_198_class_2)) + fs.append(types.Fact(key=fact_keys.rs_198_class_2, value=rs_198_class_2)) elif component.ref_type == "R": # NA @@ -89,18 +88,18 @@ class OlinuxinoMakeBomStrategy(MakeBomStrategy): resistance = str(EeVal.parse(resistance)) - fs.add_fact(types.Fact(key=fact_keys.resistance, value=resistance)) + fs.append(types.Fact(key=fact_keys.resistance, value=resistance)) if tolerance: - fs.add_fact(types.Fact(key=fact_keys.value_tolerance, value=tolerance)) + fs.append(types.Fact(key=fact_keys.value_tolerance, value=tolerance)) if size: - fs.add_fact(types.Fact(key=fact_keys.imperial_footprint_size, value=size)) + fs.append(types.Fact(key=fact_keys.imperial_footprint_size, value=size)) - self.set_default(fs, fact_keys.value_tolerance, "10%") + self.set_default(part, fact_keys.value_tolerance, "10%") else: - fs.add_fact(types.Fact(key=fact_keys.value, value=v)) + fs.append(types.Fact(key=fact_keys.value, value=v)) if na: - fs.add_fact(types.Fact(key=fact_keys.place_part, value="no")) + fs.append(types.Fact(key=fact_keys.place_part, value="no")) # raise EeException("Unknown component kind: ref={}, ref type:{}, value={}, fp_lib={}, fp_part={}". # format(component.ref, component.ref_type, v, fp_lib, fp_part)) |