10 releases

0.5.2 Nov 28, 2024
0.5.0 Jul 31, 2024
0.4.0 Oct 27, 2021
0.3.2 Mar 13, 2021
0.2.1 Sep 12, 2018

#49 in Command-line interface

Download history 6304/week @ 2024-09-22 6335/week @ 2024-09-29 8434/week @ 2024-10-06 8668/week @ 2024-10-13 11304/week @ 2024-10-20 12496/week @ 2024-10-27 13607/week @ 2024-11-03 11516/week @ 2024-11-10 15248/week @ 2024-11-17 12049/week @ 2024-11-24 13912/week @ 2024-12-01 12108/week @ 2024-12-08 10758/week @ 2024-12-15 5429/week @ 2024-12-22 4504/week @ 2024-12-29 10156/week @ 2025-01-05

31,516 downloads per month
Used in 194 crates (42 directly)

MIT/Apache

89KB
1K SLoC

Pretty-print tree-like structures

The ptree crate supports output formatting due to a user-provided configuration file and/or environment variables. Different output styles

Usage

[dependencies]
ptree = "0.5"

Constructing a tree

There are two main ways of using ptree to print a tree-like data structure. The first is to implement TreeItem for your structure. The second is to create a new tree, either using TreeBuilder or by manually constructing StringItems.

The ptree crate includes implementations of TreeItem for some common types, including a custom StringItem and petgraph::Graph.

Printing the tree

A tree can be printed to standard output using print_tree, or to an arbitrary writer using write_tree. Both functions have variants which take a PrintConfig that controls the output. Text is formatted using ansi-term, which allows changing colors and styles of the printed text.

User configuration

By default, ptree loads configuration from a user configuration file. This allows end users to globally configure the output format for all applications using ptree. Applications can use this configuration directly, modify it, or ignore it altogether.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~2–13MB
~102K SLoC