This crate is a GLSL450 compiler. It’s able to parse valid GLSL450 formatted source into an
abstract syntax tree (AST). That AST can then be transformed into SPIR-V, your own format or
even folded back to a raw GLSL [String
] (think of a minifier, for instance).
You’ll find several modules:
parser
], which exports the parsing interface.syntax
], which exports the AST and language definitions.transpiler
], which provides you with GLSL transpilers.visitor
, which gives you a way to visit AST nodes and mutate them, both with inner and
outer mutation.Feel free to inspect those modules for further information.
Basically, the [Parse
] trait gives you all you need to start parsing. This crate is designed
around the concept of type-driven parsing: parsers are hidden and you just have to state what
result type you expect.
The most common type you want to parse to is [TranslationUnit
], which represents a set of
[ExternalDeclaration
]s. An [ExternalDeclaration
] is just a declaration at the top-most level
of a shader. It can be a global, uniform declarations, vertex attributes, a function, a
structure, etc.
The crate is also getting more and more combinators and functions to transform the AST or create
nodes with regular Rust. The [Visitor
] trait will be a great friend of yours when you will
want to cope with deep mutation, filtering and validation.