6 releases
0.3.2 | Jul 26, 2024 |
---|---|
0.3.1 | Jul 14, 2024 |
0.2.0 | Apr 29, 2023 |
0.1.1 | Nov 3, 2018 |
0.1.0 | Oct 24, 2018 |
#128 in Images
750 downloads per month
Used in 22 crates
(5 directly)
79KB
2K
SLoC
A library to create syntax ("railroad") diagrams as Scalable Vector Graphics (SVG).
Live demo (code) Some examples using a small DSL of it's own.
Railroad diagrams are a way to represent context-free grammar. Every diagram has exactly one starting- and end-point; everything that belongs to the described language is represented by one of the possible paths between those points.
Using this library, diagrams are created using primitives which implement Node
. Primitives are combined into more complex structures by wrapping simple elements into more complex ones.
use railroad::*;
let mut seq = Sequence::default();
seq.push(Box::new(Start) as Box<dyn Node>)
.push(Box::new(Terminal::new("BEGIN".to_owned())))
.push(Box::new(NonTerminal::new("syntax".to_owned())))
.push(Box::new(End));
let mut dia = Diagram::new(seq);
dia.add_element(svg::Element::new("style")
.set("type", "text/css")
.text(DEFAULT_CSS));
println!("{}", dia);
When adding new Node
-primitives to this library, you may find examples/visual.rs
come in handy to quickly generate special-cases and check if they render properly. Use the visual-debug
feature to add guide-lines to the rendered diagram and extra information to the SVG's code.
Dependencies
~5MB
~98K SLoC