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