-
Notifications
You must be signed in to change notification settings - Fork 10
/
showparse.ml
37 lines (30 loc) · 1.4 KB
/
showparse.ml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
open Parser
let () = Arity.install ()
(* Translate a parse observation into something that shows the names of notations rather than their internal abstract representations, for easier inspection and testing. Note that since we intercept the parse tree before the "compilation" step, there is no name resolution, so this doesn't need to be run inside a Yuujinchou handler and can use unbound variables. *)
type obs = Term of parse_tree
and parse_tree =
| Notn of string * obs list
| App of parse_tree * parse_tree
| Placeholder
| Ident of string list
| Constr of string
| Field of string
| Superscript of parse_tree option * string
let rec get_obs (obs : Notation.observation) : obs =
match obs with
| Term r -> Term (get_tree r.value)
and get_tree : type lt ls rt rs. (lt, ls, rt, rs) Notation.parse -> parse_tree =
fun r ->
match r with
| Notn n -> Notn (Notation.name (Notation.notn n), List.map get_obs (Notation.args n))
| App a -> App (get_tree a.fn.value, get_tree a.arg.value)
| Placeholder _ -> Placeholder
| Ident (x, _) -> Ident x
| Constr (x, _) -> Constr x
| Field (x, _) -> Field x
| Superscript (None, s, _) -> Superscript (None, s)
| Superscript (Some x, s, _) -> Superscript (Some (get_tree x.value), s)
let parse tm =
let p = Parse.Term.parse (`String { content = tm; title = Some "user-supplied term" }) in
let (Term tm) = Parse.Term.final p in
get_tree tm.value