Project

General

Profile

Download (5.58 KB) Statistics
| Branch: | Tag: | Revision:
1
(********************************************************************)
2
(*                                                                  *)
3
(*  The LustreC compiler toolset   /  The LustreC Development Team  *)
4
(*  Copyright 2012 -    --   ONERA - CNRS - INPT                    *)
5
(*                                                                  *)
6
(*  LustreC is free software, distributed WITHOUT ANY WARRANTY      *)
7
(*  under the terms of the GNU Lesser General Public License        *)
8
(*  version 2.1.                                                    *)
9
(*                                                                  *)
10
(********************************************************************)
11

    
12

    
13
open LustreSpec
14

    
15
exception Error of Location.t * error
16

    
17
val dummy_type_dec: type_dec
18
val dummy_clock_dec: clock_dec
19

    
20
val mktyp: Location.t -> type_dec_desc -> type_dec
21
val mkclock: Location.t -> clock_dec_desc -> clock_dec
22
val mkvar_decl: Location.t -> ?orig:bool -> ident * type_dec * clock_dec * bool (* is const *) * expr option (* value *) -> var_decl
23

    
24
val var_decl_of_const: const_desc -> var_decl
25
val mkexpr: Location.t ->  expr_desc -> expr
26
val mkeq: Location.t -> ident list * expr -> eq
27
val mkassert: Location.t -> expr -> assert_t
28
val mktop_decl: Location.t -> ident -> bool -> top_decl_desc -> top_decl
29
val mkpredef_call: Location.t -> ident -> expr list -> expr
30
val mk_new_name: (ident -> bool) -> ident -> ident
31
val mk_new_node_name: node_desc -> ident -> ident
32
val mktop: top_decl_desc -> top_decl
33

    
34

    
35
val node_table : (ident, top_decl) Hashtbl.t
36
val print_node_table:  Format.formatter -> unit -> unit
37
val node_name: top_decl -> ident
38
val node_inputs: top_decl -> var_decl list
39
val node_from_name: ident -> top_decl
40
val is_generic_node: top_decl -> bool
41
val is_imported_node: top_decl -> bool
42

    
43
val consts_table: (ident, top_decl) Hashtbl.t
44
val print_consts_table:  Format.formatter -> unit -> unit
45
val type_table: (type_dec_desc, top_decl) Hashtbl.t
46
val print_type_table:  Format.formatter -> unit -> unit
47
val is_clock_dec_type: type_dec_desc -> bool
48
val get_repr_type: type_dec_desc -> type_dec_desc
49
val is_user_type: type_dec_desc -> bool
50
val coretype_equal: type_dec_desc -> type_dec_desc -> bool
51
val tag_true: label
52
val tag_false: label
53
val tag_default: label
54
val tag_table: (label, top_decl) Hashtbl.t
55
val field_table: (label, top_decl) Hashtbl.t
56

    
57
val get_enum_type_tags: type_dec_desc -> label list
58

    
59
val get_struct_type_fields: type_dec_desc -> (label * type_dec_desc) list
60

    
61
val consts_of_enum_type: top_decl -> top_decl list
62

    
63
val const_of_bool: bool -> constant
64
val const_is_bool: constant -> bool
65
val const_negation: constant -> constant
66
val const_or: constant -> constant -> constant
67
val const_and: constant -> constant -> constant
68
val const_xor: constant -> constant -> constant
69
val const_impl: constant -> constant -> constant
70

    
71
val get_node_vars: node_desc -> var_decl list
72
val get_node_var: ident -> node_desc -> var_decl
73
val get_node_eqs: node_desc -> eq list
74
val get_node_eq: ident -> node_desc -> eq
75
val get_node_interface: node_desc -> imported_node_desc
76

    
77
(* val get_const: ident -> constant *)
78

    
79
val sort_handlers : (label * 'a) list -> (label * 'a) list
80

    
81
val is_eq_expr: expr -> expr -> bool
82

    
83
val pp_error :  Format.formatter -> error -> unit
84

    
85
(* Caution, returns an untyped, unclocked, etc, expression *)
86
val is_tuple_expr : expr -> bool
87
val ident_of_expr : expr -> ident
88
val expr_of_vdecl : var_decl -> expr
89
val expr_of_ident : ident -> Location.t -> expr
90
val expr_list_of_expr : expr -> expr list
91
val expr_of_expr_list : Location.t -> expr list -> expr
92
val call_of_expr: expr -> (ident * expr list * expr option)
93
val expr_of_dimension: Dimension.dim_expr -> expr
94
val dimension_of_expr: expr -> Dimension.dim_expr
95
val dimension_of_const: Location.t -> constant -> Dimension.dim_expr
96

    
97
(* REMOVED, pushed in utils.ml   val new_tag : unit -> tag *)
98

    
99
val add_internal_funs: unit -> unit
100

    
101
val pp_prog_type : Format.formatter -> program -> unit
102

    
103
val pp_prog_clock : Format.formatter -> program -> unit
104

    
105
val const_of_top: top_decl -> const_desc
106
val node_of_top: top_decl -> node_desc
107
val imported_node_of_top: top_decl -> imported_node_desc
108
val typedef_of_top: top_decl -> typedef_desc
109
val dependency_of_top: top_decl -> (bool * ident)
110

    
111
val get_nodes : program -> top_decl list
112
val get_imported_nodes : program -> top_decl list
113
val get_consts : program -> top_decl list
114
val get_typedefs: program -> top_decl list
115
val get_dependencies : program -> top_decl list
116
(* val prog_unfold_consts: program -> program *)
117

    
118
val rename_static: (ident -> Dimension.dim_expr) -> type_dec_desc -> type_dec_desc
119
val rename_carrier: (ident -> ident) -> clock_dec_desc -> clock_dec_desc
120

    
121
val get_expr_vars: Utils.ISet.t -> expr -> Utils.ISet.t
122
val expr_replace_var: (ident -> ident) -> expr -> expr
123
val eq_replace_rhs_var: (ident -> bool) -> (ident -> ident) -> eq -> eq
124

    
125
(** rename_prog f_node f_var f_const prog *)
126
val rename_prog: (ident -> ident) -> (ident -> ident) -> (ident -> ident) -> program -> program
127
val substitute_expr: var_decl list -> eq list -> expr -> expr
128

    
129
val copy_var_decl: var_decl -> var_decl
130
val copy_const: const_desc -> const_desc
131
val copy_node: node_desc -> node_desc
132
val copy_top: top_decl -> top_decl
133
val copy_prog: top_decl list -> top_decl list
134

    
135
(** Annotation expression related functions *)
136
val mkeexpr: Location.t ->  expr -> eexpr
137
val merge_node_annot: node_annot -> node_annot -> node_annot 
138
val extend_eexpr: (quantifier_type * var_decl list) list -> eexpr -> eexpr
139
val update_expr_annot: ident -> expr -> expr_annot -> expr
140
(* val mkpredef_call: Location.t -> ident -> eexpr list -> eexpr*)
141

    
142
(* Local Variables: *)
143
(* compile-command:"make -C .." *)
144
(* End: *)
(14-14/53)