From: Francois Perrad Date: Sat, 3 Jan 2015 14:29:12 +0000 (+0100) Subject: graph-depends: display virtual package with italic style X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=ef0b091ca458770412adfdcc05fc3893434551dc;p=buildroot.git graph-depends: display virtual package with italic style virtual packages are found by their version, so we retrieve the version of all packages Signed-off-by: Francois Perrad Tested-by: "Yann E. MORIN" Tested-by: Luca Ceresoli Signed-off-by: Thomas Petazzoni --- diff --git a/package/pkg-generic.mk b/package/pkg-generic.mk index 1b09955631..c1b379bf87 100644 --- a/package/pkg-generic.mk +++ b/package/pkg-generic.mk @@ -565,6 +565,9 @@ $(1)-rsync: $$($(2)_TARGET_RSYNC) $(1)-source: $$($(2)_TARGET_RSYNC_SOURCE) endif +$(1)-show-version: + @echo $$($(2)_VERSION) + $(1)-show-depends: @echo $$($(2)_FINAL_DEPENDENCIES) diff --git a/support/scripts/graph-depends b/support/scripts/graph-depends index 1ecfedac7a..28fe2f0010 100755 --- a/support/scripts/graph-depends +++ b/support/scripts/graph-depends @@ -76,6 +76,28 @@ host_colour = colours[2] allpkgs = [] +# Execute the "make -show-version" command to get the version of a given +# list of packages, and return the version formatted as a Python dictionary. +def get_version(pkgs): + sys.stderr.write("Getting version for %s\n" % pkgs) + cmd = ["make", "-s", "--no-print-directory" ] + for pkg in pkgs: + cmd.append("%s-show-version" % pkg) + p = subprocess.Popen(cmd, stdout=subprocess.PIPE, universal_newlines=True) + output = p.communicate()[0] + if p.returncode != 0: + sys.stderr.write("Error getting version %s\n" % pkgs) + sys.exit(1) + output = output.split("\n") + if len(output) != len(pkgs) + 1: + sys.stderr.write("Error getting version\n") + sys.exit(1) + version = {} + for i in range(0, len(pkgs)): + pkg = pkgs[i] + version[pkg] = output[i] + return version + # Execute the "make show-targets" command to get the list of the main # Buildroot TARGETS and return it formatted as a Python list. This # list is used as the starting point for full dependency graphs @@ -257,6 +279,8 @@ def remove_extra_deps(deps): return deps dict_deps = remove_extra_deps(dict_deps) +dict_version = get_version([pkg for pkg in allpkgs + if pkg != "all" and not pkg.startswith("root")]) # Print the attributes of a node: label and fill-color def print_attrs(pkg): @@ -274,7 +298,11 @@ def print_attrs(pkg): color = host_colour else: color = target_colour - print("%s [label = \"%s\"]" % (name, label)) + version = dict_version.get(pkg) + if version == "virtual": + print("%s [label = <%s>]" % (name, label)) + else: + print("%s [label = \"%s\"]" % (name, label)) print("%s [color=%s,style=filled]" % (name, color)) # Print the dependency graph of a package