diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/spack/spack/cmd/dependents.py | 17 | ||||
-rw-r--r-- | lib/spack/spack/database.py | 9 |
2 files changed, 18 insertions, 8 deletions
diff --git a/lib/spack/spack/cmd/dependents.py b/lib/spack/spack/cmd/dependents.py index 0d470e7a89..166f9e129c 100644 --- a/lib/spack/spack/cmd/dependents.py +++ b/lib/spack/spack/cmd/dependents.py @@ -31,7 +31,7 @@ import spack import spack.store import spack.cmd -description = "show installed packages that depend on another" +description = "show packages that depend on another" section = "basic" level = "long" @@ -42,8 +42,11 @@ def setup_parser(subparser): help="List installed dependents of an installed spec, " "instead of possible dependents of a package.") subparser.add_argument( + '-t', '--transitive', action='store_true', default=False, + help="Show all transitive dependents.") + subparser.add_argument( 'spec', nargs=argparse.REMAINDER, - help="spec to list dependents for") + help="spec or package name") def inverted_dependencies(): @@ -69,12 +72,13 @@ def inverted_dependencies(): return dag -def get_dependents(pkg_name, ideps, dependents=None): +def get_dependents(pkg_name, ideps, transitive=False, dependents=None): """Get all dependents for a package. Args: pkg_name (str): name of the package whose dependents should be returned ideps (dict): dictionary of dependents, from inverted_dependencies() + transitive (bool, optional): return transitive dependents when True """ if dependents is None: dependents = set() @@ -84,8 +88,9 @@ def get_dependents(pkg_name, ideps, dependents=None): dependents.add(pkg_name) direct = ideps[pkg_name] - for dep_name in direct: - get_dependents(dep_name, ideps, dependents) + if transitive: + for dep_name in direct: + get_dependents(dep_name, ideps, transitive, dependents) dependents.update(direct) return dependents @@ -109,7 +114,7 @@ def dependents(parser, args): spec = specs[0] ideps = inverted_dependencies() - dependents = get_dependents(spec.name, ideps) + dependents = get_dependents(spec.name, ideps, args.transitive) dependents.remove(spec.name) if dependents: colify(sorted(dependents)) diff --git a/lib/spack/spack/database.py b/lib/spack/spack/database.py index 569de40a94..862eb25e7e 100644 --- a/lib/spack/spack/database.py +++ b/lib/spack/spack/database.py @@ -711,11 +711,16 @@ class Database(object): return self._remove(spec) @_autospec - def installed_dependents(self, spec): + def installed_dependents(self, spec, transitive=True): """List the installed specs that depend on this one.""" dependents = set() for spec in self.query(spec): - for dependent in spec.traverse(direction='parents', root=False): + if transitive: + to_add = spec.traverse(direction='parents', root=False) + else: + to_add = spec.dependents() + + for dependent in to_add: dependents.add(dependent) return dependents |