aboutsummaryrefslogtreecommitdiff
path: root/src/elixir_math_parser.yrl
diff options
context:
space:
mode:
authorWilliam Hergès <william@herges.fr>2025-11-08 21:31:48 +0100
committerWilliam Hergès <william@herges.fr>2025-11-08 21:31:48 +0100
commitaa1d984db18333d89b6bb2b1fa9852f85edba2de (patch)
tree304ea07295475003c192ef4d587c615a597fb9d9 /src/elixir_math_parser.yrl
parent0c49df8a68d47b5c42e1d28b43111c341b540145 (diff)
feat(calc): strengthen reducing
Diffstat (limited to 'src/elixir_math_parser.yrl')
-rw-r--r--src/elixir_math_parser.yrl14
1 files changed, 8 insertions, 6 deletions
diff --git a/src/elixir_math_parser.yrl b/src/elixir_math_parser.yrl
index 762cf4b..3ec4946 100644
--- a/src/elixir_math_parser.yrl
+++ b/src/elixir_math_parser.yrl
@@ -1,7 +1,7 @@
Nonterminals
root
- assignment
- assignments
+ statement
+ statements
expr
.
@@ -15,6 +15,7 @@ Terminals
'='
'('
')'
+ ';;'
.
Rootsymbol
@@ -28,12 +29,13 @@ Left 400 '*'.
Left 400 '/'.
Left 600 '('.
-root -> assignments : '$1'.
+root -> statements : '$1'.
-assignments -> assignment : '$1'.
-assignments -> assignment assignments : lists:merge('$1', '$2').
+statements -> statement : '$1'.
+statements -> statement statements : lists:merge('$1', '$2').
+statements -> statement ';;' statements : lists:merge('$1', '$3').
-assignment -> atom '=' expr : [{assign, '$1', '$3'}].
+statement -> atom '=' expr : [{assign, '$1', '$3'}].
expr -> int : unwrap('$1').
expr -> atom : '$1'.