diff options
Diffstat (limited to 'trygvis')
| -rw-r--r-- | trygvis/eda/cli/__init__.py | 9 | ||||
| -rw-r--r-- | trygvis/eda/cli/add_to_db.py | 23 | ||||
| -rwxr-xr-x | trygvis/eda/cli/db_stats.py | 31 | ||||
| -rwxr-xr-x | trygvis/eda/cli/digikey_download_for_schematic.py | 12 | ||||
| -rwxr-xr-x | trygvis/eda/cli/make_bom.py | 12 | 
5 files changed, 47 insertions, 40 deletions
| diff --git a/trygvis/eda/cli/__init__.py b/trygvis/eda/cli/__init__.py index 9cfb710..8a4ce6f 100644 --- a/trygvis/eda/cli/__init__.py +++ b/trygvis/eda/cli/__init__.py @@ -27,7 +27,7 @@ def do_exit(msg=None):      sys.exit(msg) -def open_database(path): +def with_database(path, tx):      g = ConjunctiveGraph('Sleepycat')      rt = g.open(path, create=False)      if rt == store.NO_STORE: @@ -36,7 +36,10 @@ def open_database(path):      elif rt != store.VALID_STORE:          raise CliException("The database is corrupt: %s" % path) -    return g +    try: +        tx(g) +    finally: +        g.close()  def create_graph(digikey=False, kicad=False): @@ -67,7 +70,7 @@ _initNs = {      "kicad-type": kicad_rdf.KICAD_TYPE} -def sparql(g, query, init_bindings = None): +def sparql(g, query, init_bindings=None):      q = prepareQuery(query, initNs=_initNs)      return g.query(q, initBindings=init_bindings) diff --git a/trygvis/eda/cli/add_to_db.py b/trygvis/eda/cli/add_to_db.py index 0511850..e3b07c1 100644 --- a/trygvis/eda/cli/add_to_db.py +++ b/trygvis/eda/cli/add_to_db.py @@ -2,16 +2,17 @@ import trygvis.eda.cli as cli  def run(files, path, args): -    g = cli.open_database(path) +    def load(g): +        s = 0 +        for f in files: +            cli.info("Adding %s" % f) +            pre = len(g) +            g.load(f, format="turtle") +            post = len(g) +            diff = post - pre +            s += diff +            cli.info("Loaded %d tuples" % diff) -    s = 0 -    for f in files: -        cli.info("Adding %s" % f) -        pre = len(g) -        g.load(f, format="turtle") -        post = len(g) -        diff = post - pre -        s += diff -        cli.info("Loaded %d tuples" % diff) +        cli.info("Done. Loaded %d tuples" % s) -    cli.info("Done. Loaded %d tuples" % s) +    cli.with_database(path, load) diff --git a/trygvis/eda/cli/db_stats.py b/trygvis/eda/cli/db_stats.py index 4780c20..5ee99ac 100755 --- a/trygvis/eda/cli/db_stats.py +++ b/trygvis/eda/cli/db_stats.py @@ -2,9 +2,8 @@ from trygvis.eda import cli  def run(db_path): -    g = cli.open_database(db_path) - -    res = cli.sparql(g, """ +    def db_stats(g): +        res = cli.sparql(g, """  SELECT ?schematic ?label  WHERE {      ?schematic a kicad-type:schematic @@ -13,16 +12,16 @@ WHERE {      }  }  """) -    cli.info("Found %d schematics in database" % len(res)) -    for row in res: -        name = row.label if row.label is not None else "<unnamed>" -        url = row.schematic +        cli.info("Found %d schematics in database" % len(res)) +        for row in res: +            name = row.label if row.label is not None else "<unnamed>" +            url = row.schematic -        cli.info("%s:" % name) -        cli.info("  URL: %s" % url) -    cli.info() +            cli.info("%s:" % name) +            cli.info("  URL: %s" % url) +        cli.info() -    res = cli.sparql(g, """ +        res = cli.sparql(g, """  SELECT      ?dk_part ?dk_part_number ?label  WHERE { @@ -33,7 +32,9 @@ WHERE {      }  }  ORDER BY ?dk_part_number -    """) -    cli.info("Found %d Digi-Key parts:" % len(res)) -    for row in res: -        cli.info("  %-30s: %s" % (row.dk_part_number, row.label)) +""") +        cli.info("Found %d Digi-Key parts:" % len(res)) +        for row in res: +            cli.info("  %-30s: %s" % (row.dk_part_number, row.label)) + +    cli.with_database(db_path, db_stats) diff --git a/trygvis/eda/cli/digikey_download_for_schematic.py b/trygvis/eda/cli/digikey_download_for_schematic.py index 99f5266..ecfbc9e 100755 --- a/trygvis/eda/cli/digikey_download_for_schematic.py +++ b/trygvis/eda/cli/digikey_download_for_schematic.py @@ -1,5 +1,3 @@ -from os.path import isfile -  from rdflib.plugins.sparql import prepareQuery  import rdflib.term @@ -20,10 +18,7 @@ initNs = {      "kicad-type": kicad_rdf.KICAD_TYPE} -def run(schematic_url, db_path, args): -    cli.info("Schematic: %s" % schematic_url) -    g = cli.open_database(db_path) - +def work(schematic_url, g):      client = DigikeyClient()      db = DigikeyDatabase()      download_category_tree(db, client) @@ -131,3 +126,8 @@ ORDER BY ?digikey_pn      #         for a in attributes:      #             [tmpG.add(node) for node in a.toNodes()]      #         writeGraph(tmpG, 'ttl/' + filename) + + +def run(schematic_url, db_path, args): +    cli.info("Schematic: %s" % schematic_url) +    cli.with_database(db_path, lambda g: work(schematic_url, g)) diff --git a/trygvis/eda/cli/make_bom.py b/trygvis/eda/cli/make_bom.py index 39d664b..eae7043 100755 --- a/trygvis/eda/cli/make_bom.py +++ b/trygvis/eda/cli/make_bom.py @@ -22,10 +22,12 @@ class Component(object):  def run(schematic_url, db_path): -    g = cli.open_database(db_path) +    cli.with_database(db_path, lambda g: work(schematic_url, g)) + +def work(schematic_url, g):      components = {} -    dkParts = {} +    dk_parts = {}      cli.info("Loading components") @@ -95,11 +97,11 @@ ORDER BY ?ref ?attr_type ?attr_value      for row in res:          pn = row.part_number -        if not hasattr(dkParts, pn): +        if not hasattr(dk_parts, pn):              part = DigiKeyPart(pn) -            dkParts[pn] = part +            dk_parts[pn] = part          else: -            part = dkParts[pn] +            part = dk_parts[pn]          part.set_attribute(row.type, row.value)          cli.info('%5s: %-20s %s' % (pn, row.type + ':', row.value)) | 
