This repository has been archived on 2022-12-27. You can view files and clone it, but cannot push or open issues or pull requests.
compilateurMIPS/lexer.mll

28 lines
630 B
OCaml
Raw Normal View History

2022-12-06 20:39:15 +01:00
{
open Lexing
open Parser
exception Error of char
}
2022-12-08 19:55:22 +01:00
let alpha = ['a'-'z' 'A'-'Z']
let num = ['0'-'9']
let ident = alpha (alpha | num | '-' | '_')*
2022-12-06 20:39:15 +01:00
rule token = parse
2022-12-08 19:55:22 +01:00
| eof { Lend }
| [ ' ' '\t' ] { token lexbuf }
| '\n' { Lexing.new_line lexbuf; token lexbuf }
| num+ as n { Lint (int_of_string n) }
| "int" { Ltype (Int_t) }
| '=' { Lassign }
| ';' { Lsc }
| ident as i { Lvar i }
2022-12-08 21:29:42 +01:00
| '#' { comment lexbuf }
2022-12-08 19:55:22 +01:00
| _ as c { raise (Error c) }
2022-12-08 21:29:42 +01:00
and comment = parse
| eof { Lend }
| '\n' { Lexing.new_line lexbuf; token lexbuf }
| _ { comment lexbuf }