-
Notifications
You must be signed in to change notification settings - Fork 125
/
opaToQml.mli
81 lines (58 loc) · 2.14 KB
/
opaToQml.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
(*
Copyright © 2011 MLstate
This file is part of OPA.
OPA is free software: you can redistribute it and/or modify it under the
terms of the GNU Affero General Public License, version 3, as published by
the Free Software Foundation.
OPA 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 Affero General Public License for
more details.
You should have received a copy of the GNU Affero General Public License
along with OPA. If not, see <http://www.gnu.org/licenses/>.
*)
(**
Conversion from OpaAst to QmlAst.
@author Valentin Gatien-Baron
@author Mathieu Barbin
*)
(** {6 Opa to Qml} *)
(**
Convesion from SurfaceAst to QmlAst.
No hack allowed there, this is not a libconvert, but part of the official flow of the compiler.
Ideally, this traduction should appear once at some point along the passes of opa.
*)
(** {6 Errors} *)
type error
exception Exception of error
val string_of_error : error -> string
(** {6 Options} *)
type options = unit
val options : options
(** {6 Traduction before renaming} *)
module NonuidOpaToQml :
sig
val code :
?options:options ->
(SurfaceAst.nonuid, SurfaceAst.all_directives) SurfaceAst.code ->
Ident.t list * QmlAst.code
end
(** {6 Traduction after renaming } *)
module UidsOpaToQml :
sig
val typeident_aux : ?check:bool -> Ident.t -> QmlAst.TypeIdent.t
val typedef : Ident.t SurfaceAst.typedef_node -> QmlAst.typedef
val code :
?options:options ->
(SurfaceAst.uids, SurfaceAst.basic_directive) SurfaceAst.code ->
Ident.t list * QmlAst.code
end
(** please do not provide QmlAst To OpaAst *)
(** {6 Mixity Parsing } *)
(** Parse a opa syntax file contents and return a qml ast *)
module Parser :
sig
exception Exception of string
val of_string : ?filename:string -> string -> QmlAst.code
end
val propagate_slicer_annotation : ('a, [< SurfaceAst.all_directives > `coerce `doctype `opacapi `side_annotation `visibility_annotation ] as 'b) SurfaceAst.expr -> (('a, 'b) SurfaceAst.expr -> ('a, 'b) SurfaceAst.expr)