Mercurial > p > roundup > code
view scripts/schema_diagram.py @ 2646:fd7b2fc1eb28
Config is now base class for all configurations...
...main Roundup configuration class is CoreConfig.
Builtin TRACKER_HOME renamed to HOME in Config and Options.
In CoreConfig, TRACKER_HOME is an alias for HOME.
Option.value2str(): added parameter 'current' -
stringify current Option value.
Option RDBMS_PORT defaults to None.
Config: added methods add_section, update_option, getopt (not implemented).
Config.save(): added warning about unset options at the top of the file.
new class UserConfig for inifile-driven configs.
CoreConfig: new attributes .ext and .detectors holding UserConfigs
for extensions and detectors, respectively.
| author | Alexander Smishlajev <a1s@users.sourceforge.net> |
|---|---|
| date | Tue, 27 Jul 2004 11:26:20 +0000 |
| parents | d56b7fc64923 |
| children | 64b05e24dbd8 |
line wrap: on
line source
#! /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 = 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 '}'
