diff options
-rw-r--r-- | lib/qparser/lexbuf.mli | 18 | ||||
-rw-r--r-- | lib/qparser/lexer.ml | 2 |
2 files changed, 16 insertions, 4 deletions
diff --git a/lib/qparser/lexbuf.mli b/lib/qparser/lexbuf.mli index 97a4d65..5a0bbcd 100644 --- a/lib/qparser/lexbuf.mli +++ b/lib/qparser/lexbuf.mli @@ -1,4 +1,7 @@ +(** Lexing buffer. *) + type t +(** The state of the buffer *) val from_lexbuf : ?reset_line:bool -> Sedlexing.lexbuf -> t (** Create a new buffer *) @@ -16,12 +19,21 @@ val content : t -> string (** Extract the token matched by the rule *) val set_start_position : t -> Lexing.position -> unit +(** Reset the starting position. Used while parsing the string to keep the + begining of the whole string. *) + val tokenize : (t -> 'a) -> t -> unit -> 'a * Lexing.position * Lexing.position +(** Function to use in the parser in order to extract the token match, and the + starting and ending position. *) + +val level : t -> int +(** The state track the nesting level in the expression. Depending of the + level, the token [!] will be considered as a comment or a boolean + operation. *) + val incr_level : t -> unit val decr_level : t -> unit val reset_level : t -> unit -val level : t -> int -(** Return the nested expression level *) - val rollback : t -> unit +(** Rollback the latest token matched *) diff --git a/lib/qparser/lexer.ml b/lib/qparser/lexer.ml index 383d6a3..f2d04bf 100644 --- a/lib/qparser/lexer.ml +++ b/lib/qparser/lexer.ml @@ -43,11 +43,11 @@ let wait_balance : (Buffer.t -> Lexbuf.t -> 'a) -> Lexbuf.t -> 'a = with Not_found -> raise UnclosedQuote let space = [%sedlex.regexp? ' ' | '\t'] +let spaces = [%sedlex.regexp? Plus space] let eol = [%sedlex.regexp? '\r' | '\n' | "\r\n"] let coma = [%sedlex.regexp? ','] let digit = [%sedlex.regexp? '0' .. '9'] let letters = [%sedlex.regexp? 'a' .. 'z' | 'A' .. 'Z' | '_'] -let spaces = [%sedlex.regexp? Plus space] let ident = [%sedlex.regexp? Opt ('$' | '*'), letters, Star (digit | letters)] let location_ident = [%sedlex.regexp? letters | digit] let location_prefix = [%sedlex.regexp? '!' | '$' | '#' | '^'] |