This library allows you to build a tree one element at a time and output it as a pretty string. This is particularly convenient for generating clean output from nested and recursive functions. A design goal was to allow this library to be used as a drop-in replacement of println!(...)
.
By adding the add_branch!(...)
macro at the start of a recursive function, you can see the entire call tree, instantly.
rust
use debug_tree::{default_tree, add_branch, add_leaf};
fn factors(x: usize) {
add_branch!("{}", x);
for i in 1..x {
if x % i == 0 {
factors(i);
}
}
}
fn main() {
factors(6);
default_tree().flush_print();
}
6
├╼ 1
├╼ 2
│ └╼ 1
└╼ 3
└╼ 1
Branches also make nested function calls a lot easier to follow. ```rust use debugtree::{defaulttree, addbranch, addleaf}; fn a() { addbranch!("a"); b(); c(); } fn b() { addbranch!("b"); c(); } fn c() { addbranch!("c"); addleaf!("Nothing to see here"); }
fn main() {
a();
defaulttree().flushprint();
}
a
├╼ b
│ └╼ c
│ └╼ Nothing to see here
└╼ c
└╼ Nothing to see here
```
Newlines in multi-line strings are automatically indented.
rust
use debug_tree::{default_tree, add_branch, add_leaf};
fn main() {
add_branch!("1");
add_leaf!("1.1\nNext line");
add_leaf!("1.2");
default_tree().flush_print();
}
1
├╼ 1.1
│ Next line
└╼ 1.2
In the case that multiple trees are needed, the trees can be created manually without the helper macros. ```rust use debug_tree::TreeBuilder; fn main() { // Make a new tree. let tree = TreeBuilder::new();
// Add a scoped branch. The next item added will belong to the branch.
let branch = tree.add_branch("1 Branch");
// Add a leaf to the current branch
tree.add_leaf("1.1 Child");
// Leave scope early
branch.release();
tree.add_leaf("2 Sibling");
tree.flush_print(); // Print and clear.
// default_tree().peek_print(); // Would print but not clear.
}
```
1 Branch
└╼ 1.1 Child
2 Sibling