3 releases

0.1.2 Aug 31, 2020
0.1.1 Aug 31, 2020
0.1.0 Aug 31, 2020

#442 in Text processing

Download history 782/week @ 2023-12-14 45/week @ 2023-12-21 990/week @ 2023-12-28 2770/week @ 2024-01-04 925/week @ 2024-01-11 1351/week @ 2024-01-18 1608/week @ 2024-01-25 1213/week @ 2024-02-01 1162/week @ 2024-02-08 818/week @ 2024-02-15 1473/week @ 2024-02-22 1257/week @ 2024-02-29 1057/week @ 2024-03-07 999/week @ 2024-03-14 1688/week @ 2024-03-21 502/week @ 2024-03-28

4,524 downloads per month
Used in 7 crates (6 directly)

MIT license

32KB
422 lines

Crate text_trees

Simple textual output for tree-like structures.

MIT License Minimum Rust Version Rust GitHub stars crates.io docs.rs

This crate is another that will output a tree structure in text. Similar to the existing ascii_tree crate, however it is more flexible in its formatting options.

Example

The following creates a StringTreeNode using a combination of with_child_nodes and with_children that demonstrates the structure of the tree well.

use text_trees::StringTreeNode;

fn make_tree() -> StringTreeNode {
    StringTreeNode::with_child_nodes(
        "root".to_string(),
        vec![
            "Uncle".into(),
            StringTreeNode::with_child_nodes(
                "Parent".to_string(),
                vec![
                    StringTreeNode::with_children(
                        "Child 1".to_string(),
                        vec!["Grand Child 1".into()].into_iter(),
                    ),
                    StringTreeNode::with_child_nodes(
                        "Child 2".to_string(),
                        vec![StringTreeNode::with_child_nodes(
                            "Grand Child 2".to_string(),
                            vec![StringTreeNode::with_children(
                                "Great Grand Child 2".to_string(),
                                vec!["Great Great Grand Child 2".to_string()].into_iter(),
                            )]
                            .into_iter(),
                        )]
                        .into_iter(),
                    ),
                ]
                .into_iter(),
            ),
            StringTreeNode::with_children(
                "Aunt".to_string(),
                vec!["Child 3".to_string()].into_iter(),
            ),
        ]
        .into_iter(),
    )
}

The tree implements Display and therefore provides a to_string method. It also has a to_string_with_format method that allows for customization of the output format. Finally, it has two write methods that take implementations of std::io::Write and will serialize accordingly.

use text_trees::{FormatCharacters, TreeFormatting, TreeNode};

fn ascii_tree(tree: TreeNode<String>) {
    let result = tree.to_string_with_format(
        &TreeFormatting::dir_tree(FormatCharacters::ascii())
    );
    assert!(result.is_ok());

    // ... do something else
}

This results in a textual representation of the tree as follows.

root
+-- Uncle
+-- Parent
|   +-- Child 1
|   |   '-- Grand Child 1
|   '-- Child 2
|       '-- Grand Child 2
|           '-- Great Grand Child 2
|               '-- Great Great Grand Child 2
'-- Aunt
    '-- Child 3

Changes

Version 0.1.2

  • Documentation changes only.

Version 0.1.1

  • Bug in top-down, bottom-anchored, tree with missing spacing.
  • Updated all examples to match the tree output changes.
  • Added tls tree-ls example.

Version 0.1.0

  • Initial version, supports only directory style trees.

TODO

TBD

No runtime deps