cargo tree
is a Cargo subcommand that visualizes a crate's dependency graph
in a tree-like format.
In its default mode, cargo tree
will print the dependency graph from the
local crate outwards:
$ cargo tree
chrono v0.2.17 (file:///Volumes/git/rust/rust-chrono)
├── num v0.1.29
│ ├── rand v0.3.12
│ │ ├── advapi32-sys v0.1.2
│ │ │ ├── winapi v0.2.5
│ │ │ └── winapi-build v0.1.1
│ │ ├── libc v0.2.4
│ │ └── winapi v0.2.5 (*)
│ └── rustc-serialize v0.3.16
├── rustc-serialize v0.3.16 (*)
├── serde v0.6.6
│ └── num v0.1.29 (*)
├── serde_json v0.6.0
│ ├── num v0.1.29 (*)
│ └── serde v0.6.6 (*)
└── time v0.1.34
├── kernel32-sys v0.2.1
│ ├── winapi v0.2.5 (*)
│ └── winapi-build v0.1.1 (*)
├── libc v0.2.4 (*)
└── winapi v0.2.5 (*)
Crates will only have their dependencies displayed the first time they are
shown - further copies will have a (*)
appended to indicate that their output
has been truncated.
cargo tree
can also operate in an "inverse" mode where the dependency tree is
walked backwards. This is most often useful when trying to determine where
a certain crate is coming from:
cargo tree -p libc -i
libc v0.2.4
├── rand v0.3.12
│ └── num v0.1.29
│ ├── chrono v0.2.17 (file:///Volumes/git/rust/rust-chrono)
│ ├── serde v0.6.6
│ │ ├── chrono v0.2.17 (file:///Volumes/git/rust/rust-chrono) (*)
│ │ └── serde_json v0.6.0
│ │ └── chrono v0.2.17 (file:///Volumes/git/rust/rust-chrono) (*)
│ └── serde_json v0.6.0 (*)
└── time v0.1.34
└── chrono v0.2.17 (file:///Volumes/git/rust/rust-chrono) (*)