#!/usr/bin/python # depgraph # Copyright (C) 2008 Stefano Zacchiroli # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. """Graph the dependencies of all packages contained in a given Packages file. Only consider Depends fields. Versioned dependencies are considered as they were not versioned. The graph is retourned in output as a (non normalized) graphviz graph suitable to be processed by dot (for an unstable/main Packages file, generating the final graph will take a while ...).""" from __future__ import print_function import sys from debian import deb822 __fresh_id = 0 def main(): if len(sys.argv) != 2: print("Usage: depgraph PACKAGES_FILE") sys.exit(2) def get_id(): global __fresh_id __fresh_id += 1 return ("NODE_%d" % __fresh_id) def emit_arc(node1, node2): print(' "%s" -> "%s" ;' % (node1, node2)) def emit_node(node, dsc): print(' "%s" [label="%s"] ;' % (node, dsc)) print("digraph depgraph {") for pkg in deb822.Packages.iter_paragraphs(open(sys.argv[1])): name = pkg['package'] rels = pkg.relations for deps in rels['depends']: if len(deps) == 1: emit_arc(name, deps[0]['name']) else: # output an OR node or_node = get_id() emit_arc(name, or_node) emit_node(or_node, 'OR') for dep in deps: emit_arc(or_node, dep['name'].lower()) # even though it is forbidden by policy, there are some # dependencies with upper case letter in the archive, # apparently apt-get turn them to lowercase ... print("}") if __name__ == '__main__': main()