forked from rescript-lang/rescript
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathast_extract.mli
104 lines (79 loc) · 3.23 KB
/
ast_extract.mli
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
(* Copyright (C) 2015-2016 Bloomberg Finance L.P.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* In addition to the permissions granted to you by the LGPL, you may combine
* or link a "work that uses the Library" with a publicly distributed version
* of this file to produce a combined library or application, then distribute
* that combined work under the terms of your choosing, with no requirement
* to comply with the obligations normally placed on you by section 4 of the
* LGPL version 3 (or the corresponding section of a later version of the LGPL
* should you choose to use a later version).
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *)
module Set_string = Depend.StringSet
val read_parse_and_extract : 'a Ml_binary.kind -> 'a -> Set_string.t
type ('a,'b) t
(* val sort_files_by_dependencies :
domain:Set_string.t -> Set_string.t Map_string.t -> string Queue.t *)
val sort :
('a -> Parsetree.structure) ->
('b -> Parsetree.signature) ->
('a, 'b) t Map_string.t -> string Queue.t
(**
[build fmt files parse_implementation parse_interface]
Given a list of files return an ast table
*)
val collect_ast_map :
Format.formatter ->
string list ->
(Format.formatter -> string -> 'a) ->
(Format.formatter -> string -> 'b) ->
('a, 'b) t Map_string.t
type dir_spec =
{ dir : string ;
mutable excludes : string list
}
(** If the genereated queue is empty, it means
1. The main module does not exist (does not exist due to typo)
2. It does exist but not in search path
The order matters from head to tail
*)
val collect_from_main :
?extra_dirs:dir_spec list ->
?excludes : string list ->
?alias_map: string Hash_string.t ->
Format.formatter ->
(Format.formatter -> string -> 'a) ->
(Format.formatter -> string -> 'b) ->
('a -> Parsetree.structure) ->
('b -> Parsetree.signature) ->
string -> ('a, 'b) t Map_string.t * string Queue.t
val build_queue :
Format.formatter ->
string Queue.t ->
('b, 'c) t Map_string.t ->
(Format.formatter -> string -> string -> 'b -> unit) ->
(Format.formatter -> string -> string -> 'c -> unit) -> unit
val handle_queue :
string Queue.t ->
('a, 'b) t Map_string.t ->
(string -> string -> 'a -> unit) ->
(string -> string -> 'b -> unit) ->
(string -> string -> string -> 'b -> 'a -> unit) -> unit
val build_lazy_queue :
Format.formatter ->
string Queue.t ->
(Parsetree.structure lazy_t, Parsetree.signature lazy_t) t Map_string.t ->
(Format.formatter -> string -> string -> Parsetree.structure -> unit) ->
(Format.formatter -> string -> string -> Parsetree.signature -> unit) -> unit