Project

General

Profile

Statistics
| Branch: | Tag: | Revision:

lustrec / src / compiler_common.ml @ 5fccce23

History | View | Annotate | Download (7.49 KB)

1 ef34b4ae xthirioux
(********************************************************************)
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
open Utils
13
open Format 
14 8446bf03 ploc
open Lustre_types
15 ef34b4ae xthirioux
open Corelang
16
17 04a63d25 xthirioux
let check_main () =
18
  if !Options.main_node = "" then
19
    begin
20 e7cc5186 ploc
      eprintf "Code generation error: %a@." Error.pp_error_msg Error.No_main_specified;
21
      raise (Error (Location.dummy_loc, Error.No_main_specified))
22 04a63d25 xthirioux
    end
23
24 ef34b4ae xthirioux
let create_dest_dir () =
25
  begin
26
    if not (Sys.file_exists !Options.dest_dir) then
27
      begin
28 521e2a6b ploc
	Log.report ~level:1 (fun fmt -> fprintf fmt ".. creating destination directory@ ");
29 ef34b4ae xthirioux
	Unix.mkdir !Options.dest_dir (Unix.stat ".").Unix.st_perm
30
      end;
31
    if (Unix.stat !Options.dest_dir).Unix.st_kind <> Unix.S_DIR then
32
      begin
33
	eprintf "Failure: destination %s is not a directory.@.@." !Options.dest_dir;
34
	exit 1
35
      end
36
  end
37
38
(* Loading Lusi file and filling type tables with parsed
39
   functions/nodes *)
40
let parse_header own filename =
41
  Location.set_input filename;
42
  let h_in = open_in filename in
43
  let lexbuf = Lexing.from_channel h_in in
44
  Location.init lexbuf filename;
45
  (* Parsing *)
46
  Log.report ~level:1 (fun fmt -> fprintf fmt ".. parsing header file %s@ " filename);
47
    try
48
      let header = Parse.header Parser_lustre.header Lexer_lustre.token lexbuf in
49 54d032f5 xthirioux
      (*ignore (Modules.load_header ISet.empty header);*)
50 ef34b4ae xthirioux
      close_in h_in;
51
      header
52
    with
53 04a63d25 xthirioux
    | (Parse.Error err) as exc -> 
54 ef34b4ae xthirioux
      Parse.report_error err;
55
      raise exc
56
    | Corelang.Error (loc, err) as exc -> (
57
      eprintf "Parsing error: %a%a@."
58 e7cc5186 ploc
	Error.pp_error_msg err
59 ef34b4ae xthirioux
	Location.pp_loc loc;
60
      raise exc
61
    )
62
63
let parse_source source_name =
64
  (* Loading the input file *)
65
  Location.set_input source_name;
66
  let s_in = open_in source_name in
67
  let lexbuf = Lexing.from_channel s_in in
68
  Location.init lexbuf source_name;
69
70
  (* Parsing *)
71
  Log.report ~level:1 
72 521e2a6b ploc
    (fun fmt -> fprintf fmt ".. parsing source file %s@ " source_name);
73 ef34b4ae xthirioux
  try
74
    let prog = Parse.prog Parser_lustre.prog Lexer_lustre.token lexbuf in
75 54d032f5 xthirioux
    (*ignore (Modules.load_program ISet.empty prog);*)
76 ef34b4ae xthirioux
    close_in s_in;
77
    prog
78
  with
79 04a63d25 xthirioux
  | (Parse.Error err) as exc -> 
80 ef34b4ae xthirioux
    Parse.report_error err;
81
    raise exc
82
  | Corelang.Error (loc, err) as exc ->
83 ec433d69 xthirioux
    eprintf "Parsing error: %a%a@."
84 e7cc5186 ploc
      Error.pp_error_msg err
85 ef34b4ae xthirioux
      Location.pp_loc loc;
86
    raise exc
87
88 04a63d25 xthirioux
let expand_automata decls =
89
  Log.report ~level:1 (fun fmt -> fprintf fmt ".. expanding automata@ ");
90
  try
91
    Automata.expand_decls decls
92
  with (Corelang.Error (loc, err)) as exc ->
93
    eprintf "Automata error: %a%a@."
94 e7cc5186 ploc
      Error.pp_error_msg err
95 04a63d25 xthirioux
      Location.pp_loc loc;
96
    raise exc
97
98 ef34b4ae xthirioux
let check_stateless_decls decls =
99
  Log.report ~level:1 (fun fmt -> fprintf fmt ".. checking stateless/stateful status@ ");
100
  try
101
    Stateless.check_prog decls
102
  with (Stateless.Error (loc, err)) as exc ->
103 ec433d69 xthirioux
    eprintf "Stateless status error: %a%a@."
104 ef34b4ae xthirioux
      Stateless.pp_error err
105
      Location.pp_loc loc;
106
    raise exc
107
108 04a63d25 xthirioux
let force_stateful_decls decls =
109
  Log.report ~level:1 (fun fmt -> fprintf fmt ".. forcing stateful status@ ");
110
  try
111
    Stateless.force_prog decls
112
  with (Stateless.Error (loc, err)) as exc ->
113
    eprintf "Stateless status error: %a%a@."
114
      Stateless.pp_error err
115
      Location.pp_loc loc;
116
    raise exc
117
118 ef34b4ae xthirioux
let type_decls env decls =  
119
  Log.report ~level:1 (fun fmt -> fprintf fmt ".. typing@ ");
120
  let new_env = 
121
    begin
122
      try
123
	Typing.type_prog env decls
124
      with (Types.Error (loc,err)) as exc ->
125 ec433d69 xthirioux
	eprintf "Typing error: %a%a@."
126 ef34b4ae xthirioux
	  Types.pp_error err
127
	  Location.pp_loc loc;
128
	raise exc
129
    end 
130
  in
131 e7cc5186 ploc
  if !Options.print_types || !Options.verbose_level > 2 then
132 ef34b4ae xthirioux
    Log.report ~level:1 (fun fmt -> fprintf fmt "@[<v 2>  %a@]@ " Corelang.pp_prog_type decls);
133
  new_env
134
      
135
let clock_decls env decls = 
136
  Log.report ~level:1 (fun fmt -> fprintf fmt ".. clock calculus@ ");
137
  let new_env =
138
    begin
139
      try
140
	Clock_calculus.clock_prog env decls
141
      with (Clocks.Error (loc,err)) as exc ->
142 ec433d69 xthirioux
	eprintf "Clock calculus error: %a%a@." Clocks.pp_error err Location.pp_loc loc;
143 ef34b4ae xthirioux
	raise exc
144
    end
145
  in
146 e7cc5186 ploc
  if !Options.print_clocks  || !Options.verbose_level > 2 then
147 ef34b4ae xthirioux
    Log.report ~level:1 (fun fmt -> fprintf fmt "@[<v 2>  %a@]@ " Corelang.pp_prog_clock decls);
148
  new_env
149
150 2d27eedd ploc
(* Typing/Clocking with an empty env *)
151 ef34b4ae xthirioux
let check_top_decls header =
152
  let new_tenv = type_decls Basic_library.type_env header in   (* Typing *)
153
  let new_cenv = clock_decls Basic_library.clock_env header in   (* Clock calculus *)
154
  header, new_tenv, new_cenv
155
156
157
(*
158
 List.fold_right
159
   (fun top_decl (ty_env, ck_env) ->
160
     match top_decl.top_decl_desc with
161
     | Node nd          -> (Env.add_value ty_env nd.node_id nd.node_type,
162
			    Env.add_value ck_env nd.node_id nd.node_clock)
163
     | ImportedNode ind -> (Env.add_value ty_env ind.nodei_id ind.nodei_type,
164
			    Env.add_value ck_env ind.nodei_id ind.nodei_clock)
165
     | Const c          -> get_envs_from_const c (ty_env, ck_env)
166
     | TypeDef _        -> List.fold_left (fun envs top -> consts_of_enum_type top_decl
167
     | Open _           -> (ty_env, ck_env))
168
   header
169
   (Env.initial, Env.initial)
170
 *)
171
172 e70326c9 ploc
let generate_lusic_header destname lusic_ext =	
173
  match !Options.output with
174
  | "C" -> C_backend_lusic.print_lusic_to_h destname lusic_ext
175
  | _ -> ()
176
	 
177
178
    
179 ef34b4ae xthirioux
let check_compatibility (prog, computed_types_env, computed_clocks_env) (header, declared_types_env, declared_clocks_env) =
180
  try
181
    (* checking defined types are compatible with declared types*)
182
    Typing.check_typedef_compat header;
183
184
    (* checking type compatibility with computed types*)
185
    Typing.check_env_compat header declared_types_env computed_types_env;
186
187
    (* checking clocks compatibility with computed clocks*)
188
    Clock_calculus.check_env_compat header declared_clocks_env computed_clocks_env;
189
190
    (* checking stateless status compatibility *)
191
    Stateless.check_compat header
192
  with
193
  | (Types.Error (loc,err)) as exc ->
194 6efbcb73 xthirioux
    eprintf "Type mismatch between computed type and declared type in lustre interface file: %a%a@."
195
      Types.pp_error err
196
      Location.pp_loc loc;
197 ef34b4ae xthirioux
    raise exc
198
  | Clocks.Error (loc, err) as exc ->
199 6efbcb73 xthirioux
    eprintf "Clock mismatch between computed clock and declared clock in lustre interface file: %a%a@."
200
      Clocks.pp_error err
201
      Location.pp_loc loc;
202 ef34b4ae xthirioux
    raise exc
203
  | Stateless.Error (loc, err) as exc ->
204 6efbcb73 xthirioux
    eprintf "Stateless status mismatch between defined status and declared status in lustre interface file: %a%a@."
205
      Stateless.pp_error err
206
      Location.pp_loc loc;
207 ef34b4ae xthirioux
    raise exc
208
209
210 990210f3 ploc
let track_exception () =
211
  if !Options.track_exceptions
212
  then (Printexc.print_backtrace stdout; flush stdout)
213
  else ()
214
215
216 66359a5e ploc
let update_vdecl_parents_prog prog =
217
  let update_vdecl_parents parent v =
218
    v.var_parent_nodeid <- Some parent
219
  in
220
  List.iter (
221
    fun top -> match top.top_decl_desc with
222
    | Node nd ->
223
       List.iter
224
	 (update_vdecl_parents nd.node_id)
225
	 (nd.node_inputs @ nd.node_outputs @ nd.node_locals )  
226
    | ImportedNode ind -> 
227
       List.iter
228
	 (update_vdecl_parents ind.nodei_id)
229
	 (ind.nodei_inputs @ ind.nodei_outputs )  
230
    | _ -> ()
231
  ) prog