aboutsummaryrefslogtreecommitdiff
path: root/lib/qparser/lexer.ml
diff options
context:
space:
mode:
Diffstat (limited to 'lib/qparser/lexer.ml')
-rw-r--r--lib/qparser/lexer.ml40
1 files changed, 28 insertions, 12 deletions
diff --git a/lib/qparser/lexer.ml b/lib/qparser/lexer.ml
index 75072c6..abe47ac 100644
--- a/lib/qparser/lexer.ml
+++ b/lib/qparser/lexer.ml
@@ -11,6 +11,14 @@ exception EOF
(* Extract the location name from the pattern *)
let location_name = Str.regexp {|.* \(.*\)|}
+(** Remove all the expression state when we are leaving the expression itself. *)
+let rec leave_expression buffer =
+ match Lexbuf.state buffer with
+ | Some Lexbuf.Expression ->
+ Lexbuf.leave_state buffer;
+ leave_expression buffer
+ | _ -> ()
+
(** Try to read the identifier and check if this is a function, a keyword, or
just a variable.
@@ -20,7 +28,9 @@ let build_ident buffer =
try
let value = Hashtbl.find Idents.keyword_table id in
let _ =
- match value with IF | ELIF -> Lexbuf.incr_level buffer | _ -> ()
+ match value with
+ | IF | ELIF -> Lexbuf.enter_state buffer Lexbuf.Expression
+ | _ -> ()
in
value
with Not_found ->
@@ -172,7 +182,7 @@ let rec token : Lexbuf.t -> token =
LOCATION_START ident
| '-', Plus '-', Star (Sub (any, ('\r' | '\n'))) ->
- Lexbuf.reset_level buffer;
+ leave_expression buffer;
LOCATION_END
| Plus digit -> INTEGER (Lexbuf.content buffer)
| '+' -> PLUS
@@ -184,31 +194,38 @@ let rec token : Lexbuf.t -> token =
| '*' -> STAR
| ':' ->
(* We are leaving the block, the comment will be handled again *)
- Lexbuf.decr_level buffer;
-
+ Lexbuf.leave_state buffer;
COLUMN
| '[' -> L_BRACKET
| ']' -> R_BRACKET
| '(' ->
- Lexbuf.incr_level buffer;
+ Lexbuf.enter_state buffer Lexbuf.Expression;
L_PAREN
| ')' ->
- Lexbuf.decr_level buffer;
+ Lexbuf.leave_state buffer;
R_PAREN
| '<' -> LT
| '>' -> GT
+ | ">>" ->
+ Lexbuf.leave_state buffer;
+ token buffer
| coma -> COMA
| '=' ->
- Lexbuf.incr_level buffer;
+ Lexbuf.enter_state buffer Lexbuf.Expression;
+
EQUAL
| ident -> build_ident buffer
| eol ->
- Lexbuf.reset_level buffer;
+ leave_expression buffer;
+
EOL
| '&' ->
- Lexbuf.reset_level buffer;
+ leave_expression buffer;
AMPERSAND
- | '!' -> if Lexbuf.level buffer > 0 then EXCLAMATION else skip_comment buffer
+ | '!' -> (
+ match Lexbuf.state buffer with
+ | Some Lexbuf.Expression -> EXCLAMATION
+ | _ -> skip_comment buffer)
| spaces -> token buffer
| '\'' ->
Lexbuf.enter_state buffer Lexbuf.String;
@@ -224,7 +241,6 @@ let rec token : Lexbuf.t -> token =
| _ ->
let tok = Lexbuf.content buffer in
let msg = Format.asprintf "Unexpected character %S" tok in
-
raise @@ LexError msg
let main buffer =
@@ -249,7 +265,7 @@ let rec discard buffer =
discard buffer
| eof -> raise EOF
| '-', Plus '-', Star (Sub (any, ('\r' | '\n'))) ->
- Lexbuf.reset_level buffer;
+ leave_expression buffer;
()
| '!' ->
ignore @@ skip_comment buffer;