|
1 |
| -use pest::Parser; |
| 1 | +use pest::{iterators::Pair, Parser}; |
2 | 2 | use pest_derive::{self, Parser};
|
3 | 3 |
|
4 | 4 | #[derive(Parser)]
|
5 | 5 | #[grammar = "typed_script.pest"]
|
6 | 6 | struct TSParser;
|
7 | 7 |
|
| 8 | +#[derive(Debug)] |
8 | 9 | pub enum TSExpression {
|
9 |
| - Value(TSValue) |
| 10 | + Value(TSValue), |
10 | 11 | }
|
11 | 12 |
|
| 13 | +#[derive(Debug)] |
12 | 14 | pub enum TSValue {
|
13 |
| - String, |
14 |
| - Number, |
15 |
| - Boolean, |
| 15 | + String(String), |
| 16 | + Variable(String), |
| 17 | + Number, |
| 18 | + Boolean, |
16 | 19 | }
|
17 | 20 |
|
| 21 | +#[derive(Debug)] |
18 | 22 | pub enum TSType {
|
19 | 23 | String,
|
20 | 24 | Number,
|
21 |
| - Boolean |
| 25 | + Boolean, |
22 | 26 | }
|
23 | 27 |
|
| 28 | +#[derive(Debug)] |
24 | 29 | pub struct TSIdentifier(String);
|
25 | 30 |
|
| 31 | +#[derive(Debug)] |
26 | 32 | pub enum TSAST {
|
27 | 33 | Value(TSValue),
|
28 | 34 | Expression(TSExpression),
|
29 |
| - Assignment(TSIdentifier, TSExpression) |
| 35 | + Assignment(TSIdentifier, TSExpression), |
30 | 36 | }
|
31 | 37 |
|
| 38 | +#[derive(Debug)] |
32 | 39 | pub enum TypedAst {
|
33 | 40 | Value(TSValue, TSType),
|
34 |
| - Expression(TSExpression, TSType), |
35 |
| - Assignment(TSIdentifier, TSExpression, TSType) |
| 41 | + Expression(TSExpression), |
| 42 | + Assignment(TSIdentifier, TSExpression), |
36 | 43 | }
|
37 | 44 |
|
38 |
| - |
39 | 45 | fn main() {
|
40 |
| - let parsed_res = TSParser::parse(Rule::program, "let myvar = \"test\";").unwrap(); |
41 |
| - |
42 |
| - let mut ast: Vec<TSAST> = vec![]; |
43 |
| - |
44 |
| - for rule in parsed_res{ |
45 |
| - match rule.as_rule(){ |
46 |
| - Rule::program => println!("{}", rule), |
47 |
| - Rule::expression => println!("{}", rule), |
48 |
| - Rule::assignment => println!("{}", rule), |
49 |
| - _ => println!("{}", rule) |
50 |
| - } |
| 46 | + let parsed_res = TSParser::parse(Rule::program, "let myvar = \"test\"; myvar").unwrap(); |
| 47 | + |
| 48 | + let mut ast: Vec<TypedAst> = vec![]; |
| 49 | + |
| 50 | + for rule in parsed_res { |
| 51 | + let node = match rule.as_rule() { |
| 52 | + Rule::program => todo!(), |
| 53 | + Rule::expression => TypedAst::Expression(parse_expression(rule).unwrap()), |
| 54 | + Rule::assignment => parse_assignment(rule).unwrap(), |
| 55 | + _ => continue, |
| 56 | + }; |
| 57 | + |
| 58 | + ast.push(node); |
51 | 59 | }
|
52 | 60 |
|
| 61 | + println!("ast {:?}", ast); |
53 | 62 | }
|
54 | 63 |
|
55 |
| -fn parse_assignment(assignment: Rule::assignment) -> Result<TAST, Box<dyn std::error::Error>> { |
56 |
| - |
| 64 | +fn parse_assignment(assignment: Pair<Rule>) -> Result<TypedAst, Box<dyn std::error::Error>> { |
57 | 65 | let mut inner_rules = assignment.into_inner();
|
58 | 66 |
|
59 |
| - inner_rules.next(); |
60 |
| - |
61 | 67 | let identifier = inner_rules.next().unwrap();
|
62 |
| - |
63 |
| - inner_rules.next(); |
64 | 68 |
|
65 | 69 | let expression = inner_rules.next().unwrap();
|
66 | 70 |
|
67 |
| - println!("id: {identifier}, exp: {expression} "); |
| 71 | + let expression = parse_expression(expression); |
| 72 | + |
| 73 | + let assignment = TypedAst::Assignment( |
| 74 | + TSIdentifier(identifier.as_str().into()), |
| 75 | + expression.unwrap(), |
| 76 | + ); |
| 77 | + |
| 78 | + Ok(assignment) |
| 79 | +} |
| 80 | + |
| 81 | +fn parse_expression(expression: Pair<Rule>) -> Result<TSExpression, Box<dyn std::error::Error>> { |
| 82 | + let mut inner_rules = expression.into_inner().next().unwrap(); |
| 83 | + |
| 84 | + let typed_exp = match inner_rules.as_rule() { |
| 85 | + Rule::string => TSExpression::Value(TSValue::String(inner_rules.as_str().into())), |
| 86 | + Rule::identifier => TSExpression::Value(TSValue::Variable(inner_rules.as_str().into())), |
| 87 | + _ => todo!(), |
| 88 | + }; |
68 | 89 |
|
69 |
| - todo!() |
| 90 | + Ok(typed_exp) |
70 | 91 | }
|
0 commit comments