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

#103 in Images

Download history 203/week @ 2024-08-05 112/week @ 2024-08-12 29/week @ 2024-08-19 149/week @ 2024-08-26 73/week @ 2024-09-02 54/week @ 2024-09-09 113/week @ 2024-09-16 113/week @ 2024-09-23 84/week @ 2024-09-30 23/week @ 2024-10-07 53/week @ 2024-10-14 127/week @ 2024-10-21 41/week @ 2024-10-28 49/week @ 2024-11-04 59/week @ 2024-11-11 96/week @ 2024-11-18

254 downloads per month
Used in 20 crates (4 directly)

MIT license

79KB
2K SLoC

A library to create syntax ("railroad") diagrams as Scalable Vector Graphics (SVG).

Build status Crates.io Version Docs

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);

diagram for create table sql syntax

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