source: Deliverables/D2.2/8051/src/options.ml @ 619

Last change on this file since 619 was 619, checked in by ayache, 9 years ago

Update of D2.2 from Paris.

File size: 2.6 KB
RevLine 
[486]1open Misc.ArgExt
2
3let default_choice       = "default"
4let option_settings_step = "during option settings"
5
6let language_from_string kind default s =
7  try 
8    Languages.from_string s
9  with Not_found -> 
10    if s = default_choice then 
11      default
12    else 
13      Error.global_error option_settings_step
14        (Printf.sprintf "`%s' is not a valid %s language." s kind)
15 
16let source_language_of_string   = language_from_string "source" Languages.Clight
17let source_language             = ref (source_language_of_string default_choice)
18let set_source_language s       = source_language := source_language_of_string s
19let get_source_language ()      = !source_language
20
21let target_language_of_string   = language_from_string "target" Languages.ASM
22let target_language             = ref (target_language_of_string default_choice)
23let set_target_language s       = target_language := target_language_of_string s
24let get_target_language ()      = !target_language
25
26let input_files                 = ref []
27let add_input_file f            = input_files := f :: !input_files
28let input_files ()              = !input_files
29
[619]30let output_files                = ref None
31let set_output_files s          = output_files := Some s
32let get_output_files ()         = !output_files
33
[486]34let annotation_flag             = ref false
35let request_annotation          = (:=) annotation_flag
36let annotation_requested ()     = !annotation_flag
37
38let interpretation_flag         = ref false
39let request_interpretation      = (:=) interpretation_flag
40let interpretation_requested () = !interpretation_flag
41
42let debug_flag                  = ref false
43let set_debug                   = (:=) debug_flag
44let is_debug_enabled ()         = !debug_flag
45
[619]46let print_result_flag           = ref false
47let set_print_result            = (:=) print_result_flag
48let is_print_result_enabled ()  = !print_result_flag
49
[486]50let dev_test                    = ref false
51let set_dev_test                = (:=) dev_test
52let is_dev_test_enabled ()      = !dev_test
53
54let options = OptionsParsing.register [
55  "-s", Arg.String set_source_language,
56  " Choose the source language between:";
57  extra_doc " Clight, Cminor";
58  extra_doc " [default is C]";
59
60  "-l", Arg.String set_target_language,
61  " Choose the target language between:";
62  extra_doc " Clight, Cminor, RTLabs, RTL, ERTL, LTL, LIN, ASM";
63  extra_doc " [default is ASM]";
64
65  "-a", Arg.Set annotation_flag,
66  " Add cost annotations on the source code.";
67
68  "-i", Arg.Set interpretation_flag,
69  " Interpret the compiled code.";
70
71  "-d", Arg.Set debug_flag,
72  " Debugging mode.";
73
[619]74  "-o", Arg.String set_output_files,
75  " Prefix of the output files.";
76
77  "-res", Arg.Set print_result_flag,
78  " Print the result of interpretations.";
79
[486]80  "-dev", Arg.Set dev_test,
81  " Playground for developers.";
82]
Note: See TracBrowser for help on using the repository browser.