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
38
39
40
41
42
43
44
45
46
47
48
49
50
module P = struct
type data = Syn.resolver_data
type tag = Asai.Range.t option
type hook = unit
type context = unit
end
module Scope = struct
include Yuujinchou.Scope.Make(P)
type data = P.data
let import_singleton x v =
import_singleton (x, v)
let include_singleton x v =
include_singleton (x, v)
let import_subtree ?modifier path subtree =
import_subtree ?modifier (path, subtree)
let include_subtree ?modifier path subtree =
include_subtree ?modifier (path, subtree)
let pp_path ppf path =
let pp_slash ppf () = Format.fprintf ppf "/" in
Format.(fprintf ppf "%a" (pp_print_list ~pp_sep: pp_slash pp_print_string) path)
let pp_trie =
let pp_print_pair pp1 pp2 ppf (left, right) =
pp1 ppf left; pp2 ppf right
in
Format.(
pp_print_seq
(
pp_print_pair
Trie.pp_path
(pp_print_pair Syn.pp_resolver_data (pp_print_option Asai.Range.dump))
)
)
end
module Lang = Yuujinchou.Language