author | wenzelm |
Tue, 24 Jul 2012 12:54:34 +0200 | |
changeset 48472 | 6ebb6cdd36a5 |
parent 48470 | 7483aa690b4f |
child 48477 | 322fbf571782 |
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 |
||
17 |
fun use_thys options = |
|
48457 | 18 |
Thy_Info.use_thys |
19 |
|> Unsynchronized.setmp Proofterm.proofs (Options.int options "proofs") |
|
20 |
|> Unsynchronized.setmp print_mode |
|
21 |
(space_explode "," (Options.string options "print_mode") @ print_mode_value ()) |
|
22 |
|> Unsynchronized.setmp Goal.parallel_proofs (Options.int options "parallel_proofs") |
|
23 |
|> Unsynchronized.setmp Goal.parallel_proofs_threshold |
|
24 |
(Options.int options "parallel_proofs_threshold") |
|
25 |
|> Unsynchronized.setmp Multithreading.trace (Options.int options "threads_trace") |
|
48460 | 26 |
|> Unsynchronized.setmp Multithreading.max_threads (Options.int options "threads") |
48472 | 27 |
|> (case Options.string options "document" of "" => true | "false" => true | _ => false) ? |
48470
7483aa690b4f
clarified "document" again, eliminated redundant "no_document";
wenzelm
parents:
48468
diff
changeset
|
28 |
Present.no_document |
48464 | 29 |
|> Unsynchronized.setmp quick_and_dirty (Options.bool options "quick_and_dirty"); |
48457 | 30 |
|
48465 | 31 |
fun use_theories (options, thys) = |
32 |
let val condition = space_explode "," (Options.string options "condition") in |
|
33 |
(case filter_out (can getenv_strict) condition of |
|
34 |
[] => use_thys options thys |
|
35 |
| conds => |
|
36 |
Output.physical_stderr ("Ignoring theories " ^ commas_quote thys ^ |
|
37 |
" (missing " ^ commas conds ^ ")\n")) |
|
38 |
end; |
|
39 |
||
40 |
in |
|
41 |
||
48418 | 42 |
fun build args_file = |
43 |
let |
|
48459
375e45df6fdf
timing is command line options, not system option;
wenzelm
parents:
48458
diff
changeset
|
44 |
val (save, (options, (timing, (verbose, (browser_info, (parent, |
375e45df6fdf
timing is command line options, not system option;
wenzelm
parents:
48458
diff
changeset
|
45 |
(name, (base_name, theories)))))))) = |
48418 | 46 |
File.read (Path.explode args_file) |> YXML.parse_body |> |
48457 | 47 |
let open XML.Decode in |
48459
375e45df6fdf
timing is command line options, not system option;
wenzelm
parents:
48458
diff
changeset
|
48 |
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
|
49 |
(pair string (pair string ((list (pair Options.decode (list string))))))))))) |
48457 | 50 |
end; |
48418 | 51 |
|
48457 | 52 |
val _ = |
48462
424fd5364f15
clarified "this_name" vs. former "reset" feature -- imitate the latter by loading other session sources directly;
wenzelm
parents:
48461
diff
changeset
|
53 |
Session.init save false |
48457 | 54 |
(Options.bool options "browser_info") browser_info |
48458 | 55 |
(Options.string options "document") |
48457 | 56 |
(Options.bool options "document_graph") |
48466
3b2fb20df17d
further imitation of ISABELLE_USEDIR_OPTIONS via options;
wenzelm
parents:
48465
diff
changeset
|
57 |
(space_explode ":" (Options.string options "document_variants")) |
48462
424fd5364f15
clarified "this_name" vs. former "reset" feature -- imitate the latter by loading other session sources directly;
wenzelm
parents:
48461
diff
changeset
|
58 |
parent base_name |
48468
7f2998b95249
added "document_dump_only" (cf. negated usedir -C);
wenzelm
parents:
48466
diff
changeset
|
59 |
(not (Options.bool options "document_dump_only"), Options.string options "document_dump") |
48463 | 60 |
(Options.string options "browser_info_remote") |
48457 | 61 |
verbose; |
48465 | 62 |
val _ = Session.with_timing name timing (List.app use_theories) theories; |
48418 | 63 |
val _ = Session.finish (); |
48419 | 64 |
val _ = if save then () else quit (); |
48418 | 65 |
in () end |
66 |
handle exn => (Output.error_msg (ML_Compiler.exn_message exn); exit 1); |
|
67 |
||
68 |
end; |
|
48465 | 69 |
|
70 |
end; |