Add --all argument to spack dependents

--all causes spack dependents to list all possible dependents for a
package, rather than actual dependents for an installed spec.
This commit is contained in:
Todd Gamblin 2017-06-12 01:07:29 -07:00
parent 44653fa488
commit f2ddcfac5f

View file

@ -25,6 +25,7 @@
import argparse
import llnl.util.tty as tty
from llnl.util.tty.colify import colify
import spack
import spack.store
@ -36,15 +37,64 @@
def setup_parser(subparser):
subparser.add_argument(
'-a', '--all', action='store_true', default=False,
help="List all potential dependents of the package instead of actual "
"dependents of an installed spec")
subparser.add_argument(
'spec', nargs=argparse.REMAINDER,
help="specs to list dependencies of")
def inverted_dag():
"""Returns inverted package DAG as adjacency lists."""
dag = {}
for pkg in spack.repo.all_packages():
dag.setdefault(pkg.name, set())
for dep in pkg.dependencies:
deps = [dep]
# expand virtuals if necessary
if spack.repo.is_virtual(dep):
deps = [s.name for s in spack.repo.providers_for(dep)]
for d in deps:
dag.setdefault(d, set()).add(pkg.name)
return dag
def all_dependents(name, inverted_dag, dependents=None):
if dependents is None:
dependents = set()
if name in dependents:
return set()
dependents.add(name)
direct = inverted_dag[name]
for dname in direct:
all_dependents(dname, inverted_dag, dependents)
dependents.update(direct)
return dependents
def dependents(parser, args):
specs = spack.cmd.parse_specs(args.spec)
if len(specs) != 1:
tty.die("spack dependents takes only one spec.")
if args.all:
spec = specs[0]
idag = inverted_dag()
dependents = all_dependents(spec.name, idag)
dependents.remove(spec.name)
if dependents:
colify(sorted(dependents))
else:
print("No dependents")
else:
spec = spack.cmd.disambiguate_spec(specs[0])
tty.msg("Dependents of %s" % spec.cformat('$_$@$%@$/'))