有没有办法在OCamlLex中返回多个令牌?
我正在尝试为基于缩进的语言编写词法分析器和解析器,并且我希望我的词法分析器在注意到缩进级别比以前更少时返回多个DEDENT
标记。这将允许它在多个块结束时通知解析器。
通过使用此方法,我可以使用INDENT
和DEDENT
作为BEGIN
和END
的替代品,因为这两个令牌将被隐含INDENT
和DEDENT
令牌。
答案 0 :(得分:7)
返回令牌列表。如果解析器本身不能处理它(比如ocamlyacc) - 只需在其间插入一个缓存:
let cache =
let l = ref [] in
fun lexbuf ->
match !l with
| x::xs -> l := xs; x
| [] -> match Lexer.tokens lexbuf with
| [] -> failwith "oops"
| x::xs -> l := xs; x
或者您可以在完整文档上运行词法分析器,然后在完整令牌流上运行解析器。
BTW你看到了ocaml+twt吗?