mirror of
https://gitlab.com/scemama/QCaml.git
synced 2024-11-14 01:53:39 +01:00
39 lines
876 B
OCaml
39 lines
876 B
OCaml
|
{
|
||
|
open Nuclei_parser
|
||
|
}
|
||
|
|
||
|
let eol = ['\n']
|
||
|
let white = [' ' '\t']+
|
||
|
let word = [^' ' '\t' '\n']+
|
||
|
let letter = ['A'-'Z' 'a'-'z']
|
||
|
let integer = ['0'-'9']+
|
||
|
let real = '-'? integer '.' integer (['e' 'E'] ('+'|'-')? integer)?
|
||
|
|
||
|
|
||
|
rule read_all = parse
|
||
|
| eof { EOF }
|
||
|
| eol { EOL }
|
||
|
| white as w { SPACE w }
|
||
|
| integer as i { INTEGER (int_of_string i) }
|
||
|
| real as f { FLOAT (float_of_string f) }
|
||
|
| word as w { WORD w }
|
||
|
|
||
|
|
||
|
{
|
||
|
let debug () =
|
||
|
let ic = open_in "caffeine.xyz" in
|
||
|
let lexbuf = Lexing.from_channel ic in
|
||
|
while true do
|
||
|
let s =
|
||
|
match read_all lexbuf with
|
||
|
| EOL -> "EOL"
|
||
|
| SPACE w -> "SPACE("^w^")"
|
||
|
| INTEGER i -> "INTEGER("^(string_of_int i)^")"
|
||
|
| FLOAT f -> "FLOAT("^(string_of_float f)^")"
|
||
|
| WORD w -> "WORD("^w^")"
|
||
|
| EOF -> "EOF"
|
||
|
in
|
||
|
print_endline s
|
||
|
done;
|
||
|
}
|