4 个版本 (2 个稳定版)
1.1.0 | 2020年12月21日 |
---|---|
1.0.0 | 2020年12月21日 |
0.1.1 | 2020年9月20日 |
0.1.0 | 2020年9月19日 |
#2813 in Rust 模式
13KB
250 行
Rust 的一个通用操作符优先级解析器。您可以将自己的处理函数、令牌结构和操作符枚举插入其中,该库提供算法。
简单示例在 int_math.rs 中提供
cargo run --example int_math
示例
fn handler(lhs: f64, op: Op, rhs: f64, _ctx: &()) -> Result<f64, ()> {
Ok(match op {
Op::Add => lhs + rhs,
Op::Sub => lhs - rhs,
Op::Mul => lhs * rhs,
Op::Div => lhs / rhs,
Op::Exp => lhs.powf(rhs)
})
}
let climber = Climber::new(
vec![
Rule::new(Op::Add, Assoc::Left) | Rule::new(Op::Sub, Assoc::Right),
Rule::new(Op::Mul, Assoc::Left) | Rule::new(Op::Div, Assoc::Right),
Rule::new(Op::Exp, Assoc::Right)
],
handler
);
// 2 + 2 * 3
// 2 + 6
// 8
let expression = Expression::new(
2.0f64,
vec![
(Op::Add, 2.0f64),
(Op::Mul, 3.0f64)
]
);
assert_eq!(climber.process(&expression, &()).unwrap(), 8.0f64);
此包基于 Pest 解析器的 PrecClimber,但是一个更通用的实现,适用于非 Pest 使用。