author | wenzelm |
Thu, 26 Jul 2012 19:41:05 +0200 | |
changeset 48527 | 4ee8d70cd5a3 |
parent 48520 | 6d4ea2efa64b |
child 48541 | f31ef1a0285a |
permissions | -rw-r--r-- |
48418 | 1 |
(* Title: Pure/System/build.ML |
2 |
Author: Makarius |
|
3 |
||
4 |
Build Isabelle sessions. |
|
5 |
*) |
|
6 |
||
7 |
signature BUILD = |
|
8 |
sig |
|
9 |
val build: string -> unit |
|
10 |
end; |
|
11 |
||
12 |
structure Build: BUILD = |
|
13 |
struct |
|
14 |
||
48465 | 15 |
local |
16 |
||
48500 | 17 |
fun no_document options = |
18 |
(case Options.string options "document" of "" => true | "false" => true | _ => false) andalso |
|
19 |
(Options.string options "document_dump" = ""); |
|
20 |
||
48465 | 21 |
fun use_thys options = |
48457 | 22 |
Thy_Info.use_thys |
23 |
|> Unsynchronized.setmp Proofterm.proofs (Options.int options "proofs") |
|
24 |
|> Unsynchronized.setmp print_mode |
|
25 |
(space_explode "," (Options.string options "print_mode") @ print_mode_value ()) |
|
26 |
|> Unsynchronized.setmp Goal.parallel_proofs (Options.int options "parallel_proofs") |
|
27 |
|> Unsynchronized.setmp Goal.parallel_proofs_threshold |
|
28 |
(Options.int options "parallel_proofs_threshold") |
|
29 |
|> Unsynchronized.setmp Multithreading.trace (Options.int options "threads_trace") |
|
48460 | 30 |
|> Unsynchronized.setmp Multithreading.max_threads (Options.int options "threads") |
48500 | 31 |
|> no_document options ? Present.no_document |
48486 | 32 |
|> Unsynchronized.setmp quick_and_dirty (Options.bool options "quick_and_dirty") |
33 |
|> Unsynchronized.setmp Printer.show_question_marks_default |
|
34 |
(Options.bool options "show_question_marks") |
|
35 |
|> Unsynchronized.setmp Name_Space.names_long_default (Options.bool options "names_long") |
|
36 |
|> Unsynchronized.setmp Name_Space.names_short_default (Options.bool options "names_short") |
|
48492 | 37 |
|> Unsynchronized.setmp Name_Space.names_unique_default (Options.bool options "names_unique") |
48520 | 38 |
|> Unsynchronized.setmp Thy_Output.display_default (Options.bool options "thy_output_display") |
39 |
|> Unsynchronized.setmp Thy_Output.quotes_default (Options.bool options "thy_output_quotes") |
|
40 |
|> Unsynchronized.setmp Thy_Output.indent_default (Options.int options "thy_output_indent") |
|
41 |
|> Unsynchronized.setmp Thy_Output.source_default (Options.bool options "thy_output_source") |
|
42 |
|> Unsynchronized.setmp Thy_Output.break_default (Options.bool options "thy_output_break") |
|
48527 | 43 |
|> Unsynchronized.setmp Pretty.margin_default (Options.int options "pretty_margin") |
48492 | 44 |
|> Unsynchronized.setmp Toplevel.timing (Options.bool options "timing"); |
48457 | 45 |
|
48465 | 46 |
fun use_theories (options, thys) = |
47 |
let val condition = space_explode "," (Options.string options "condition") in |
|
48 |
(case filter_out (can getenv_strict) condition of |
|
49 |
[] => use_thys options thys |
|
50 |
| conds => |
|
48512 | 51 |
Output.physical_stderr ("Skipping theories " ^ commas_quote thys ^ |
48477 | 52 |
" (undefined " ^ commas conds ^ ")\n")) |
48465 | 53 |
end; |
54 |
||
55 |
in |
|
56 |
||
48418 | 57 |
fun build args_file = |
58 |
let |
|
48511
37999ee01156
remove old output heaps, to ensure that result is valid wrt. check_stamps;
wenzelm
parents:
48500
diff
changeset
|
59 |
val (do_output, (options, (timing, (verbose, (browser_info, (parent_base_name, |
48459
375e45df6fdf
timing is command line options, not system option;
wenzelm
parents:
48458
diff
changeset
|
60 |
(name, (base_name, theories)))))))) = |
48418 | 61 |
File.read (Path.explode args_file) |> YXML.parse_body |> |
48457 | 62 |
let open XML.Decode in |
48459
375e45df6fdf
timing is command line options, not system option;
wenzelm
parents:
48458
diff
changeset
|
63 |
pair bool (pair Options.decode (pair bool (pair bool (pair string (pair string |
375e45df6fdf
timing is command line options, not system option;
wenzelm
parents:
48458
diff
changeset
|
64 |
(pair string (pair string ((list (pair Options.decode (list string))))))))))) |
48457 | 65 |
end; |
48418 | 66 |
|
48457 | 67 |
val _ = |
48511
37999ee01156
remove old output heaps, to ensure that result is valid wrt. check_stamps;
wenzelm
parents:
48500
diff
changeset
|
68 |
Session.init do_output false |
48457 | 69 |
(Options.bool options "browser_info") browser_info |
48458 | 70 |
(Options.string options "document") |
48457 | 71 |
(Options.bool options "document_graph") |
48466
3b2fb20df17d
further imitation of ISABELLE_USEDIR_OPTIONS via options;
wenzelm
parents:
48465
diff
changeset
|
72 |
(space_explode ":" (Options.string options "document_variants")) |
48482
45137257399a
pass parent_base_name, which is required for Session.init sanity check;
wenzelm
parents:
48477
diff
changeset
|
73 |
parent_base_name base_name |
48516
c5d0f19ef7cb
refined "document_dump_mode": "all", "tex+sty", "tex";
wenzelm
parents:
48513
diff
changeset
|
74 |
(Options.string options "document_dump", Options.string options "document_dump_mode") |
48513
ace120a2cb70
discontinued slightly odd "browser_info_remote" -- it could point to a completely different version of the Isabelle library;
wenzelm
parents:
48512
diff
changeset
|
75 |
"" verbose; |
48465 | 76 |
val _ = Session.with_timing name timing (List.app use_theories) theories; |
48418 | 77 |
val _ = Session.finish (); |
48511
37999ee01156
remove old output heaps, to ensure that result is valid wrt. check_stamps;
wenzelm
parents:
48500
diff
changeset
|
78 |
val _ = if do_output then () else quit (); |
48418 | 79 |
in () end |
80 |
handle exn => (Output.error_msg (ML_Compiler.exn_message exn); exit 1); |
|
81 |
||
82 |
end; |
|
48465 | 83 |
|
84 |
end; |