diff options
author | Valentin Rothberg <rothberg@redhat.com> | 2019-07-12 11:35:48 +0200 |
---|---|---|
committer | Valentin Rothberg <rothberg@redhat.com> | 2019-07-16 14:16:16 +0200 |
commit | 25d63f009dfb0bd646b761591a08989cfd9d4fda (patch) | |
tree | 5e3f087177553f2c2c5dbe5654d5b6e488380e15 | |
parent | 9ae3e7c1eced61253330c2c8bd93d51ee97a6774 (diff) | |
download | podman-25d63f009dfb0bd646b761591a08989cfd9d4fda.tar.gz podman-25d63f009dfb0bd646b761591a08989cfd9d4fda.tar.bz2 podman-25d63f009dfb0bd646b761591a08989cfd9d4fda.zip |
dependency-tree analysis: direct and transitive
Change the script to generate two files. One including direct
dependencies, the other including direct and transitive dependencies.
Signed-off-by: Valentin Rothberg <rothberg@redhat.com>
-rw-r--r-- | dependencies/analyses/README.md | 10 | ||||
-rwxr-xr-x | dependencies/analyses/dependency-tree.sh | 9 |
2 files changed, 14 insertions, 5 deletions
diff --git a/dependencies/analyses/README.md b/dependencies/analyses/README.md index e05bc3e8f..a440a0ebd 100644 --- a/dependencies/analyses/README.md +++ b/dependencies/analyses/README.md @@ -71,15 +71,17 @@ Running the script can help identify sources of bloat and reveal potential candi Use the `dependency-tree.sh` script to figure out which package includes which packages. The output of the script has the format `package: dependency_1, dependency_2, ...`. Each line is followed by a blank line to make it easier to read. -Note that the list of dependencies includes only the direct dependencies and not all transitive dependencies. -The transitive dependencies of a given package can be examined by running `go list -f '{{ .Name }}: {{ join .Deps ", " }}' $PACKAGE` or by browsing through the output of `dependency-tree.sh`. +The script generates two files: + + - `direct-tree.txt` - listing direct dependencies + - `transitive-tree.txt` - listing direct and transitive dependencies Running such a dependency-tree analysis may look as follows: ``` -[libpod]$ ./dependencies/analyses/dependency-tree.sh github.com/containers/libpod > tree.txt -[libpod]$ grep "^github.com/containers/libpod/pkg/registries" tree.txt +[libpod]$ ./dependencies/analyses/dependency-tree.sh github.com/containers/libpod +[libpod]$ grep "^github.com/containers/libpod/pkg/registries" direct-tree.txt github.com/containers/libpod/pkg/registries: github.com/containers/libpod/vendor/github.com/containers/image/pkg/sysregistriesv2, github.com/containers/libpod/vendor/github.com/containers/image/types, github.com/containers/libpod/pkg/rootless, github.com/containers/libpod/vendor/github.com/docker/distribution/reference, github.com/containers/libpod/vendor/github.com/pkg/errors, os, path/filepath, strings ``` diff --git a/dependencies/analyses/dependency-tree.sh b/dependencies/analyses/dependency-tree.sh index 3c9dccc51..9a2e3282d 100755 --- a/dependencies/analyses/dependency-tree.sh +++ b/dependencies/analyses/dependency-tree.sh @@ -10,4 +10,11 @@ DATA=$(go list $1/... \ | awk '{ printf "%s\n\n", $0 }' \ ) -echo "$DATA" +echo "$DATA" > direct-tree.txt + +DATA=$(go list $1/... \ + | xargs -d '\n' go list -f '{{ .ImportPath }}: {{ join .Deps ", " }}' \ + | awk '{ printf "%s\n\n", $0 }' \ + ) + +echo "$DATA" > transitive-tree.txt |