pieuvre/lexer.mll

41 lines
977 B
OCaml
Raw Normal View History

2024-04-09 11:09:33 +02:00
{
open Parser
exception Eof
}
let lowercase = ['a'-'z']
let uppercase = ['A'-'Z']
let digit = ['0'-'9']
let word = (lowercase | uppercase)*
let var_id = lowercase lowercase* digit*
2024-04-16 10:07:09 +02:00
let ty_id = uppercase uppercase* digit*
2024-04-09 11:09:33 +02:00
rule token = parse
| [' ' '\t'] { token lexbuf }
| '\n' { EOL }
2024-04-30 11:44:28 +02:00
| '.' { DOT }
2024-04-09 11:09:33 +02:00
| '+' { PLUS }
| '*' { TIMES }
2024-04-16 10:07:09 +02:00
| "True" { TOP }
| "False" { BOT }
2024-04-09 11:09:33 +02:00
| '(' { LPAREN }
| ')' { RPAREN }
2024-04-09 11:30:52 +02:00
| "fun" { FUN }
2024-04-09 11:09:33 +02:00
| ':' { COLON }
| "=>" { ARR }
2024-04-16 10:07:09 +02:00
| "->" { TARR }
| '~' { TILDE }
2024-04-09 11:09:33 +02:00
| "exf" { EXFALSO }
2024-04-30 11:44:28 +02:00
| "Goal" { GOAL }
| "exact" { EXACT }
| "assumption" { ASSUMPTION }
| "intro" { INTRO }
| "cut" { CUT }
| "apply" { APPLY }
2024-04-09 11:09:33 +02:00
| var_id as s { VARID(s) }
| ty_id as s { TYID(s) }
| eof { raise Eof }