-
Notifications
You must be signed in to change notification settings - Fork 15
Expand file tree
/
Copy pathschema_diagram.py
More file actions
48 lines (43 loc) · 1.52 KB
/
schema_diagram.py
File metadata and controls
48 lines (43 loc) · 1.52 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#! /usr/bin/python
#
# Schema diagram generator contributed by Stefan Seefeld of the fresco
# project http://www.fresco.org/.
#
# It generates a 'dot file' that is then fed into the 'dot'
# tool (http://www.graphviz.org) to generate a graph:
#
# %> ./schema.py
# %> dot -Tps schema.dot -o schema.ps
# %> gv schema.ps
#
import sys
import roundup.instance
# open the instance
instance = roundup.instance.open(sys.argv[1])
db = instance.open()
# diagram preamble
print('digraph schema {')
print('size="8,6"')
print('node [shape="record" bgcolor="#ffe4c4" style=filled]')
print('edge [taillabel="1" headlabel="1" dir=back arrowtail=ediamond]')
# get all the classes
types = list(db.classes.keys())
# one record node per class
for i in range(len(types)):
print('node%d [label=\"{%s|}"]'%(i, types[i]))
# now draw in the relations
for name in db.classes.keys():
type = db.classes[name]
attributes = type.getprops()
for a in attributes.keys():
attribute = attributes[a]
if isinstance(attribute, roundup.hyperdb.Link):
print('node%d -> node%d [label=%s]'%(types.index(name),
types.index(attribute.classname),
a))
elif isinstance(attribute, roundup.hyperdb.Multilink):
print('node%d -> node%d [taillabel="*" label=%s]'%(types.index(name),
types.index(attribute.classname),
a))
# all done
print('}')