Project

General

Profile

Statistics
| Branch: | Tag: | Revision:

lustrec / src / corelang.mli @ 4f26dcf5

History | View | Annotate | Download (6.56 KB)

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 Lustre_types
14

    
15
exception Error of Location.t * Error.error_kind
16
module VSet: Set.S with type elt = Lustre_types.var_decl 
17
  
18
val dummy_type_dec: type_dec
19
val dummy_clock_dec: clock_dec
20

    
21
val mktyp: Location.t -> type_dec_desc -> type_dec
22
val mkclock: Location.t -> clock_dec_desc -> clock_dec
23
val mkvar_decl: Location.t -> ?orig:bool ->
24
  ident *
25
    type_dec *
26
    clock_dec *
27
    bool (* is const *) *
28
    expr option (* value *) *
29
    string option (* parent id *)
30
  -> var_decl
31

    
32
val dummy_var_decl: ident -> Types.type_expr -> var_decl
33

    
34
val var_decl_of_const: ?parentid:ident option -> const_desc -> var_decl
35
val mkexpr: Location.t ->  expr_desc -> expr
36
val mkeq: Location.t -> ident list * expr -> eq
37
val mkassert: Location.t -> expr -> assert_t
38
val mktop_decl: Location.t -> ident -> bool -> top_decl_desc -> top_decl
39
val mkpredef_call: Location.t -> ident -> expr list -> expr
40
val mk_new_name: (ident -> bool) -> ident -> ident
41
val mk_new_node_name: node_desc -> ident -> ident
42
val mktop: top_decl_desc -> top_decl
43

    
44
(* constructor for machine types *)
45
val mkinstr: ?lustre_expr:expr -> ?lustre_eq: eq -> Machine_code_types.instr_t_desc -> Machine_code_types.instr_t
46
val get_instr_desc: Machine_code_types.instr_t -> Machine_code_types.instr_t_desc
47
val update_instr_desc: Machine_code_types.instr_t -> Machine_code_types.instr_t_desc -> Machine_code_types.instr_t
48
  
49
val node_table : (ident, top_decl) Hashtbl.t
50
val print_node_table:  Format.formatter -> unit -> unit
51
val node_name: top_decl -> ident
52
val node_inputs: top_decl -> var_decl list
53
val node_from_name: ident -> top_decl
54
val is_generic_node: top_decl -> bool
55
val is_imported_node: top_decl -> bool
56

    
57
val consts_table: (ident, top_decl) Hashtbl.t
58
val print_consts_table:  Format.formatter -> unit -> unit
59
val type_table: (type_dec_desc, top_decl) Hashtbl.t
60
val print_type_table:  Format.formatter -> unit -> unit
61
val is_clock_dec_type: type_dec_desc -> bool
62
val get_repr_type: type_dec_desc -> type_dec_desc
63
val is_user_type: type_dec_desc -> bool
64
val coretype_equal: type_dec_desc -> type_dec_desc -> bool
65
val tag_true: label
66
val tag_false: label
67
val tag_default: label
68
val tag_table: (label, top_decl) Hashtbl.t
69
val field_table: (label, top_decl) Hashtbl.t
70

    
71
val get_enum_type_tags: type_dec_desc -> label list
72

    
73
val get_struct_type_fields: type_dec_desc -> (label * type_dec_desc) list
74

    
75
val consts_of_enum_type: top_decl -> top_decl list
76

    
77
val const_of_bool: bool -> constant
78
val const_is_bool: constant -> bool
79
val const_negation: constant -> constant
80
val const_or: constant -> constant -> constant
81
val const_and: constant -> constant -> constant
82
val const_xor: constant -> constant -> constant
83
val const_impl: constant -> constant -> constant
84

    
85
val get_node_vars: node_desc -> var_decl list
86
val get_node_var: ident -> node_desc -> var_decl
87
val get_node_eqs: node_desc -> eq list * automata_desc list
88
val get_node_eq: ident -> node_desc -> eq
89
val get_node_interface: node_desc -> imported_node_desc
90

    
91
(* val get_const: ident -> constant *)
92

    
93
val sort_handlers : (label * 'a) list -> (label * 'a) list
94

    
95
val is_eq_expr: expr -> expr -> bool
96

    
97
(* val pp_error :  Format.formatter -> error -> unit *)
98

    
99
(* Caution, returns an untyped, unclocked, etc, expression *)
100
val is_tuple_expr : expr -> bool
101
val ident_of_expr : expr -> ident
102
val expr_of_vdecl : var_decl -> expr
103
val expr_of_ident : ident -> Location.t -> expr
104
val expr_list_of_expr : expr -> expr list
105
val expr_of_expr_list : Location.t -> expr list -> expr
106
val call_of_expr: expr -> (ident * expr list * expr option)
107
val expr_of_dimension: Dimension.dim_expr -> expr
108
val dimension_of_expr: expr -> Dimension.dim_expr
109
val dimension_of_const: Location.t -> constant -> Dimension.dim_expr
110
val expr_to_eexpr: expr -> eexpr
111
(* REMOVED, pushed in utils.ml   val new_tag : unit -> tag *)
112

    
113
val add_internal_funs: unit -> unit
114

    
115
val pp_prog_type : Format.formatter -> program -> unit
116

    
117
val pp_prog_clock : Format.formatter -> program -> unit
118

    
119
val const_of_top: top_decl -> const_desc
120
val node_of_top: top_decl -> node_desc
121
val imported_node_of_top: top_decl -> imported_node_desc
122
val typedef_of_top: top_decl -> typedef_desc
123
val dependency_of_top: top_decl -> (bool * ident)
124

    
125
val get_nodes : program -> top_decl list
126
val get_imported_nodes : program -> top_decl list
127
val get_consts : program -> top_decl list
128
val get_typedefs: program -> top_decl list
129
val get_dependencies : program -> top_decl list
130
(* val prog_unfold_consts: program -> program *)
131

    
132
val rename_static: (ident -> Dimension.dim_expr) -> type_dec_desc -> type_dec_desc
133
val rename_carrier: (ident -> ident) -> clock_dec_desc -> clock_dec_desc
134

    
135
val get_expr_vars: expr -> Utils.ISet.t
136
(*val expr_replace_var: (ident -> ident) -> expr -> expr*)
137

    
138
val eq_replace_rhs_var: (ident -> bool) -> (ident -> ident) -> eq -> eq
139

    
140
(** val rename_expr f_node f_var expr *)
141
val rename_expr : (ident -> ident) -> (ident -> ident) -> expr -> expr
142
(** val rename_eq f_node f_var eq *)
143
val rename_eq : (ident -> ident) -> (ident -> ident) -> eq -> eq
144
(** val rename_aut f_node f_var aut *)
145
val rename_aut : (ident -> ident) -> (ident -> ident) -> automata_desc -> automata_desc
146
(** rename_prog f_node f_var prog *)
147
val rename_prog: (ident -> ident) -> (ident -> ident) -> (ident -> ident) -> program -> program
148

    
149
val substitute_expr: var_decl list -> eq list -> expr -> expr
150

    
151
val copy_var_decl: var_decl -> var_decl
152
val copy_const: const_desc -> const_desc
153
val copy_node: node_desc -> node_desc
154
val copy_top: top_decl -> top_decl
155
val copy_prog: top_decl list -> top_decl list
156

    
157
(** Annotation expression related functions *)
158
val mkeexpr: Location.t ->  expr -> eexpr
159
val merge_contracts:  contract_desc -> contract_desc -> contract_desc 
160
val extend_eexpr: (quantifier_type * var_decl list) list -> eexpr -> eexpr
161
val update_expr_annot: ident -> expr -> expr_annot -> expr
162
(* val mkpredef_call: Location.t -> ident -> eexpr list -> eexpr*)
163

    
164
val expr_contains_expr: tag -> expr -> bool
165
(* Local Variables: *)
166
(* compile-command:"make -C .." *)
167
(* End: *)