mirror of
https://github.com/zizmorcore/zizmor.git
synced 2025-12-23 08:47:33 +00:00
|
Some checks are pending
CodSpeed Benchmarks / Run benchmarks (push) Waiting to run
CI / Lint (push) Waiting to run
CI / Test (push) Waiting to run
CI / Test site build (push) Waiting to run
CI / All tests pass (push) Blocked by required conditions
zizmor wheel builds for PyPI 🐍 / Build Linux wheels (manylinux) (push) Waiting to run
zizmor wheel builds for PyPI 🐍 / Build Linux wheels (musllinux) (push) Waiting to run
zizmor wheel builds for PyPI 🐍 / Build Windows wheels (push) Waiting to run
zizmor wheel builds for PyPI 🐍 / Build macOS wheels (push) Waiting to run
zizmor wheel builds for PyPI 🐍 / Build source distribution (push) Waiting to run
zizmor wheel builds for PyPI 🐍 / Release (push) Blocked by required conditions
Deploy zizmor documentation site 🌐 / Deploy zizmor documentation to GitHub Pages 🌐 (push) Waiting to run
GitHub Actions Security Analysis with zizmor 🌈 / Run zizmor 🌈 (push) Waiting to run
Avoids dep hell. Signed-off-by: William Woodruff <william@yossarian.net> |
||
|---|---|---|
| .. | ||
| src | ||
| Cargo.toml | ||
| README.md | ||
tree-sitter-iter
A very simple pre-order iterator for tree-sitter CSTs.
This library is part of zizmor.
Usage
Given a tree_sitter::Tree, you can create a TreeIter to iterate
over its nodes in pre-order:
use tree_sitter_iter::TreeIter;
let tree: tree_sitter::Tree = parse(); // Your parsing logic here.
for node in TreeIter::new(&tree) {
println!("Node kind: {}", node.kind());
}
TreeIter implements the standard Iterator trait, meaning that
you can use any of the normal iterator combinators. For example, to
filter only to nodes of a specific kind:
for node in TreeIter::new(&tree).filter(|n| n.kind() == "call") {
// Do something with each "call" node.
}
tree-sitter-iter's space and time performance is equivalent to a
walk of the tree using the TreeCursor APIs. In other words, it's
exactly the same as using a TreeCursor manually, but with a more ergonomic
iterator interface.
See the documentation for more details.