Parsing Expression Grammars in Rust

This is a simple parser generator based on the Parsing Expression Grammar formalism.

Please see the release notes for breaking changes between rust-peg 0.3.x and 0.4.x.

Grammar Definition Syntax

rust use super::name;

The grammar may begin with a series of use declarations, just like in Rust, which are included in the generated module. Since the grammar is in its own module, you must use super::StructName; to access a structure from the parent module.

```rust

[pub]

rule_name -> type = expression ```

If a rule is marked with #[pub], the generated module has a public function that begins parsing at that rule.

You can use line comments and block comments just as in Rust code, for example:

// comment name -> String = /* weirdly placed comment */ [0-9]+ { from_str::<u64>(match_str).unwrap() } // comment

Usage

With a build script

A Cargo build script can compile your PEG grammar to Rust source automatically.

Example crate using rust-peg with a build script

Add to your Cargo.toml:

```

Under [package]

build = "build.rs"

[build-dependencies] peg = { version = "0.4" } ```

Create build.rs with:

``` extern crate peg;

fn main() { peg::cargobuild("src/mygrammar.rustpeg"); } ```

And import the generated code:

mod my_grammar { include!(concat!(env!("OUT_DIR"), "/my_grammar.rs")); }

As a syntax extension

rust-syntax-ext only works on Nightly builds of Rust.

Examples using rust-peg as a syntax extension

Add to your Cargo.toml:

toml [dependencies] peg-syntax-ext = "0.4.0"

Add to your crate root: ```rust

![feature(plugin)]

![plugin(pegsyntaxext)]

```

Use peg_file! modname("mygrammarfile.rustpeg"); to include the grammar from an external file. The macro expands into a module called modname with functions corresponding to the #[pub] rules in your grammar.

Or, use rust peg! modname(r#" // grammar rules here "#);`

to embed a short PEG grammar inline in your Rust source file. Example.

As a standalone code generator

Run peg input_file.rustpeg to compile a grammar and generate Rust code on stdout.

Tracing

If you pass the peg/trace feature to Cargo when building your project, a trace of the parsing will be output to stdout when running the binary. For example, $ cargo run --features peg/trace ... [PEG_TRACE] Matched rule type at 8:5 [PEG_TRACE] Attempting to match rule ident at 8:12 [PEG_TRACE] Attempting to match rule letter at 8:12 [PEG_TRACE] Failed to match rule letter at 8:12 ...