Compare commits
No commits in common. "a887bf4b3e8101bdc99554e5a9e25803e7dc5c6e" and "abbf5514e8301acc88b3c34510cab07f2a4e7a10" have entirely different histories.
a887bf4b3e
...
abbf5514e8
5 changed files with 8 additions and 17 deletions
14
src/eval.rs
14
src/eval.rs
|
|
@ -20,16 +20,12 @@ impl Evaluator {
|
|||
}
|
||||
},
|
||||
Expr::Binary { op, left, right } => {
|
||||
let lhs = self.eval_expr(*left);
|
||||
let rhs = self.eval_expr(*right);
|
||||
|
||||
match op {
|
||||
BinaryOp::Add => lhs + rhs,
|
||||
BinaryOp::Sub => lhs - rhs,
|
||||
BinaryOp::Mul => lhs * rhs,
|
||||
BinaryOp::Div => lhs / rhs,
|
||||
BinaryOp::Mod => lhs % rhs,
|
||||
BinaryOp::Exp => lhs.pow(rhs as u32) // probably shouldn't cast like that
|
||||
BinaryOp::Add => self.eval_expr(*left) + self.eval_expr(*right),
|
||||
BinaryOp::Sub => self.eval_expr(*left) - self.eval_expr(*right),
|
||||
BinaryOp::Mul => self.eval_expr(*left) * self.eval_expr(*right),
|
||||
BinaryOp::Div => self.eval_expr(*left) / self.eval_expr(*right),
|
||||
BinaryOp::Mod => self.eval_expr(*left) % self.eval_expr(*right)
|
||||
}
|
||||
},
|
||||
expr => panic!("can't eval expression: {expr:?}")
|
||||
|
|
|
|||
|
|
@ -4,8 +4,7 @@ pub enum BinaryOp {
|
|||
Sub,
|
||||
Mul,
|
||||
Div,
|
||||
Mod,
|
||||
Exp
|
||||
Mod
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone)]
|
||||
|
|
@ -15,15 +14,14 @@ pub enum UnaryOp {
|
|||
|
||||
pub fn prefix_bp(op: &UnaryOp) -> u8 {
|
||||
match op {
|
||||
UnaryOp::Neg => 7
|
||||
UnaryOp::Neg => 5
|
||||
}
|
||||
}
|
||||
|
||||
pub fn infix_bp(op: &BinaryOp) -> (u8, u8) {
|
||||
match op {
|
||||
BinaryOp::Add | BinaryOp::Sub => (1, 2),
|
||||
BinaryOp::Mul | BinaryOp::Div | BinaryOp::Mod => (3, 4),
|
||||
BinaryOp::Exp => (5, 6)
|
||||
BinaryOp::Mul | BinaryOp::Div | BinaryOp::Mod => (3, 4)
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -59,7 +59,6 @@ impl Lexer {
|
|||
Some(b'*') => {self.advance(); Some(Token::Asterisk)},
|
||||
Some(b'/') => {self.advance(); Some(Token::Slash)},
|
||||
Some(b'%') => {self.advance(); Some(Token::Percent)},
|
||||
Some(b'^') => {self.advance(); Some(Token::Caret)},
|
||||
|
||||
Some(b'(') => {self.advance(); Some(Token::LParen)},
|
||||
Some(b')') => {self.advance(); Some(Token::RParen)},
|
||||
|
|
|
|||
|
|
@ -69,7 +69,6 @@ impl Parser {
|
|||
Some(Token::Asterisk) => BinaryOp::Mul,
|
||||
Some(Token::Slash) => BinaryOp::Div,
|
||||
Some(Token::Percent) => BinaryOp::Mod,
|
||||
Some(Token::Caret) => BinaryOp::Exp,
|
||||
_ => break
|
||||
};
|
||||
|
||||
|
|
|
|||
|
|
@ -9,7 +9,6 @@ pub enum Token {
|
|||
Asterisk,
|
||||
Slash,
|
||||
Percent,
|
||||
Caret,
|
||||
|
||||
// Parentheses
|
||||
LParen,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue