aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChimrod <>2023-09-24 12:51:35 +0200
committerChimrod <>2023-09-24 12:51:35 +0200
commitafe13e92cf46e0bd4bf493bd0896f9fc0152ff37 (patch)
tree109933e3e527bd3e5d90b8b8572fe22967067351
parente21c752ccd0d3d73921beddb671aa48429c2dd90 (diff)
Variable without index are now evaluated as well
-rw-r--r--lib/parser.mly5
-rw-r--r--lib/qsp_expression.mly2
-rw-r--r--test/qsp_parser_test.ml72
3 files changed, 26 insertions, 53 deletions
diff --git a/lib/parser.mly b/lib/parser.mly
index c506e9c..35aebaf 100644
--- a/lib/parser.mly
+++ b/lib/parser.mly
@@ -1,11 +1,6 @@
%{
-
-
module T = Qsp_syntax.T
-
- let dummy_pos = (Lexing.dummy_pos, Lexing.dummy_pos)
-
%}
%parameter<Analyzer: Qsp_syntax.S.Analyzer>
diff --git a/lib/qsp_expression.mly b/lib/qsp_expression.mly
index d1680f3..3d758c4 100644
--- a/lib/qsp_expression.mly
+++ b/lib/qsp_expression.mly
@@ -81,7 +81,7 @@ unary_operator:
let index = match brackets with
| None ->
(* No declaration, consider index at 0 *)
- Some (Analyzer.Expression.integer dummy_pos "0")
+ None
| Some other -> other in
Analyzer.Expression.{ pos = $loc ; name ; index }
}
diff --git a/test/qsp_parser_test.ml b/test/qsp_parser_test.ml
index 6ac8bfa..505f905 100644
--- a/test/qsp_parser_test.ml
+++ b/test/qsp_parser_test.ml
@@ -61,7 +61,7 @@ let test_negative_numeric_expression () =
[ Expression (Op (_position, Neg, Integer (_position, "123"))) ]
let test_negative_numeric_expression2 () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let var = { Ast.pos = _position; name = "CURTIMESUN"; index } in
_test_instruction "-(780-CurTimeSun)"
Ast.
@@ -75,12 +75,12 @@ let test_negative_numeric_expression2 () =
]
let test_str_variable () =
- let index = Some T.(Integer (_position, "0")) in
+ let index = None in
let var = { Ast.pos = _position; name = "$VALUE"; index } in
_test_instruction "$value" [ Expression (Ident var) ]
let test_variable () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let var = { Ast.pos = _position; name = "VALUE"; index } in
_test_instruction "value" [ Expression (Ident var) ]
@@ -90,7 +90,7 @@ let test_indexed_variable () =
_test_instruction "value[1]" [ Expression (Ident var) ]
let test_let_literal () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let var = { Ast.pos = _position; name = "VALUE"; index } in
_test_instruction "let value = '123'"
Ast.[ Declaration (_position, var, Eq', Literal (_position, "123")) ]
@@ -101,13 +101,13 @@ let test_set_array_append () =
Ast.[ Declaration (_position, var, Eq', Literal (_position, "")) ]
let test_direct_assignation () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let var = { T.pos = _position; name = "VALUE"; index } in
_test_instruction "value = '123'"
Ast.[ Declaration (_position, var, Eq', Literal (_position, "123")) ]
let test_command_assignation () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let st_1 = { Ast.pos = _position; name = "ST_1"; index } in
_test_instruction "st_1 = input 'Enter the amount'"
Ast.
@@ -121,13 +121,13 @@ let test_command_assignation () =
]
let test_assignation2 () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let var = { Ast.pos = _position; name = "VALUE"; index } in
_test_instruction "set value += 123"
Ast.[ Declaration (_position, var, Inc, Integer (_position, "123")) ]
let test_multilie_literal () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let var = { Ast.pos = _position; name = "VALUE"; index } in
_test_instruction {|
value = {
@@ -150,11 +150,7 @@ let test_nested_literal () =
[
Ast.Declaration
( _position,
- {
- Ast.pos = _position;
- name = "VALUE";
- index = Some (Ast.Integer (_position, "0"));
- },
+ { Ast.pos = _position; name = "VALUE"; index = None },
Qsp_syntax.T.Eq',
Ast.Literal (_position, "\n\n {\n\n }\n") );
]
@@ -182,7 +178,7 @@ apples = 5
pears = 10
|} in
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let apples = { Ast.pos = _position; name = "APPLES"; index }
and pears = { Ast.pos = _position; name = "PEARS"; index }
and value_5 = Ast.Integer (_position, "5")
@@ -197,7 +193,7 @@ pears = 10
let test_multiline2 () =
let content = "apples = 5 & pears = 10" in
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let apples = { Ast.pos = _position; name = "APPLES"; index }
and pears = { Ast.pos = _position; name = "PEARS"; index }
and value_5 = Ast.Integer (_position, "5")
@@ -210,7 +206,7 @@ let test_multiline2 () =
let test_equality () =
let content = "apples = 5 = pears" in
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let apples = { Ast.pos = _position; name = "APPLES"; index }
and pears = { Ast.pos = _position; name = "PEARS"; index }
and value_5 = Ast.Integer (_position, "5") in
@@ -224,7 +220,7 @@ let test_plus () =
let content = {|
apples = 5 + pears
|} in
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let apples = { Ast.pos = _position; name = "APPLES"; index }
and pears = { Ast.pos = _position; name = "PEARS"; index }
and value_5 = Ast.Integer (_position, "5") in
@@ -241,7 +237,7 @@ let test_plus_litt () =
let content = {|
'five'+ pears
|} in
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let pears = { Ast.pos = _position; name = "PEARS"; index } in
_test_instruction content
[
@@ -254,7 +250,7 @@ let test_concat () =
let content = {|
$firstName + ' ' + $lastName
|} in
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let firstname = { Ast.pos = _position; name = "$FIRSTNAME"; index }
and lastName = { Ast.pos = _position; name = "$LASTNAME"; index }
and space = Ast.Literal (_position, " ") in
@@ -271,7 +267,7 @@ $firstName + ' ' + $lastName
let test_comment () = _test_instruction "! Comment" [ Comment _position ]
let test_comment2 () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let a = { Ast.pos = _position; name = "A"; index }
and value_0 = Ast.Integer (_position, "0") in
_test_instruction "a = 0 &! Comment"
@@ -282,7 +278,7 @@ let test_comment3 () = _test_instruction {|!!1234
(** The exclamation mark here is an operation and not a comment *)
let test_comment4 () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let a = { Ast.pos = _position; name = "A"; index }
and value_0 = Ast.Integer (_position, "0") in
_test_instruction "a = rand(0, 1) ! 0"
@@ -307,11 +303,7 @@ let test_comment5 () =
[
Ast.Declaration
( _position,
- {
- Ast.pos = _position;
- name = "A";
- index = Some (Ast.Integer (_position, "0"));
- },
+ { Ast.pos = _position; name = "A"; index = None },
Qsp_syntax.T.Eq',
Ast.Function (_position, Rand, []) );
Ast.Comment _position;
@@ -338,7 +330,7 @@ also count}. This is still the same comment. |}
(** This test ensure that the unary operator is applied to the whole expression
*)
let test_precedence () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let x = Ast.Ident { Ast.pos = _position; name = "X"; index }
and y = Ast.Ident { Ast.pos = _position; name = "Y"; index } in
_test_instruction "no x = y"
@@ -347,7 +339,7 @@ let test_precedence () =
(** This test ensure that a ! is not considered as a comment in an
expression *)
let test_precedence2 () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let x = { Ast.pos = _position; name = "X"; index }
and y = Ast.Ident { Ast.pos = _position; name = "Y"; index } in
_test_instruction "x = y ! 0"
@@ -501,20 +493,12 @@ let test_if_inline_act () =
( _position,
Qsp_syntax.T.Gte,
Ast.Ident
- {
- Ast.pos = _position;
- name = "HOUR";
- index = Some (Ast.Integer (_position, "0"));
- },
+ { Ast.pos = _position; name = "HOUR"; index = None },
Ast.Integer (_position, "8") ) ),
[
Ast.Declaration
( _position,
- {
- Ast.pos = _position;
- name = "MINUT";
- index = Some (Ast.Integer (_position, "0"));
- },
+ { Ast.pos = _position; name = "MINUT"; index = None },
Qsp_syntax.T.Inc,
Ast.Integer (_position, "1") );
Ast.Act
@@ -591,14 +575,8 @@ let test_gt () =
Ast.Call
( _position,
"GOTO",
- [
- Ast.Ident
- {
- Ast.pos = _position;
- name = "$CURLOC";
- index = Some (Ast.Integer (_position, "0"));
- };
- ] );
+ [ Ast.Ident { Ast.pos = _position; name = "$CURLOC"; index = None } ]
+ );
]
let test_nl () =
@@ -661,7 +639,7 @@ let test_precedence6 () =
(** An identifier cannot start by a number *0 is a product and not an
identifier *)
let test_operator () =
- let index = Some Ast.(Integer (_position, "0")) in
+ let index = None in
let a = { Ast.pos = _position; name = "A"; index }
and value_0 = Ast.Integer (_position, "0") in
_test_instruction "a *0"