#infix #postfix #expression #token #shunting #compatible #environments

no-std maschen

A no-std compatible shunting yard implementation

3 unstable releases

0.2.1 Oct 5, 2024
0.2.0 Oct 5, 2024
0.1.0 Oct 5, 2024

#738 in Algorithms

MIT license

12KB
207 lines

Overview

A shunting-yard implementation for transforming infix expressions to postfix. This crate only implements the algorithm, and does not evaluate expressions.

It is generic over the token type, so you can convert streams of whatever kinds of token you need.

It is also generic over the backing storage, so it is appropriate for use in no-alloc environments.

Features

  • Infix operators (left-associative)
    • Precedence between infix operators
  • Unary operators
  • Functions with 1 or more arguments

Use case: Embedded Scripting

An embedded system may want to evaluate mathematical expressions provided at run-time by a user. For the user's convenience, you want to let them write infix expressions. However for computational convenience, you want to convert those to postfix to be run.

Once you have converted the input into tokens, maschen can be used to do this conversion. Then you will have an easily evaluated postfix token stream.

Since maschen leaves the evaluation of the expression to the caller and doesn't care what the tokens actually are, they can be complex values such as handles to variables in your scripting language.

How to use

Implement maschen::Token for your Token type. Then instantiate an instance of maschen::ShuntingYard, and process() each token in turn. Finally call finish() to retrieve the output.

No-std

If you disable the std feature, the ShuntingYard::new method will be unavailable, and you will have to implement maschen::Stack on some type to use it as the backing storage for the yard. In an embedded environment, this will presumably be a static or stack-allocated array.

Maschen?

https://en.wikipedia.org/wiki/Maschen_Marshalling_Yard

Dependencies

~220–670KB
~16K SLoC