summaryrefslogtreecommitdiff
path: root/tools/formatSoftware.py
diff options
context:
space:
mode:
authorLars-Dominik Braun <lars@6xq.net>2017-01-21 11:24:56 +0100
committerLars-Dominik Braun <lars@6xq.net>2017-01-28 14:31:28 +0100
commita6d474471dddc2d7a187a66358aafcb86235ca69 (patch)
tree7242cbf0f0e645b2156e143dbebaa2d28b4fcdba /tools/formatSoftware.py
parentc7befe173ed2b0f5fd82228fa45c7a105ac44818 (diff)
downloadeumel-a6d474471dddc2d7a187a66358aafcb86235ca69.tar.gz
eumel-a6d474471dddc2d7a187a66358aafcb86235ca69.tar.bz2
eumel-a6d474471dddc2d7a187a66358aafcb86235ca69.zip
Restructure git
Move tools into separate repo, split TTL file.
Diffstat (limited to 'tools/formatSoftware.py')
-rwxr-xr-xtools/formatSoftware.py54
1 files changed, 2 insertions, 52 deletions
diff --git a/tools/formatSoftware.py b/tools/formatSoftware.py
index a54a740..756a247 100755
--- a/tools/formatSoftware.py
+++ b/tools/formatSoftware.py
@@ -7,57 +7,7 @@ import sys
from itertools import chain, groupby
from jinja2 import Environment
from formatRefs import first
-
-class RDFWalker:
- """
- Simple RDF graph walker
- """
-
- def __init__ (self, g, s, n, path=[]):
- """
- :param g: Graph
- :param s: Namespace
- :param n: Start node
- """
- self.g = g
- self.n = n
- self.s = s
- self._path = path
-
- def __getattr__ (self, k):
- """
- If k is underscore _, walk up tree one level, otherwise search for
- direct descendents and get first one.
- """
- if k == '_':
- return RDFWalker (self.g, self.s, self._path[0], self._path[1:])
- yieldall = False
- if k.endswith ('_'):
- yieldall = True
- k = k[:-1]
-
- if k == 'a':
- attr = RDF.type
- else:
- attr = getattr (self.s, k)
-
- ret = [RDFWalker (self.g, self.s, n, [self.n] + self._path) for n in self.g.objects (self.n, attr)]
-
- if yieldall:
- return ret
- elif not ret:
- return None
- else:
- return ret[0]
-
- def __eq__ (self, b):
- return self.n == b.n
-
- def __lt__ (self, b):
- return str (self) < str (b)
-
- def __str__ (self):
- return str (self.n)
+from rdf import RDFWalker
if __name__ == '__main__':
env = Environment ()
@@ -108,7 +58,7 @@ if __name__ == '__main__':
</div>
{% endfor %}""")
g = Graph()
- result = g.parse ("index.ttl", format='turtle')
+ result = g.parse (sys.stdin, format='turtle')
s = Namespace ("https://schema.org/")
items = []