src/Pure/System/build.ML
author wenzelm
Thu, 26 Jul 2012 13:38:43 +0200
changeset 48513 ace120a2cb70
parent 48512 a69d7dc49f41
child 48516 c5d0f19ef7cb
permissions -rw-r--r--
discontinued slightly odd "browser_info_remote" -- it could point to a completely different version of the Isabelle library;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
48418
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/System/build.ML
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
     3
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
     4
Build Isabelle sessions.
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
     5
*)
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
     6
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
     7
signature BUILD =
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
     8
sig
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
     9
  val build: string -> unit
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    10
end;
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    11
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    12
structure Build: BUILD =
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    13
struct
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    14
48465
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    15
local
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    16
48500
bf7f434b91d7 clarified no_document situation;
wenzelm
parents: 48492
diff changeset
    17
fun no_document options =
bf7f434b91d7 clarified no_document situation;
wenzelm
parents: 48492
diff changeset
    18
  (case Options.string options "document" of "" => true | "false" => true | _ => false) andalso
bf7f434b91d7 clarified no_document situation;
wenzelm
parents: 48492
diff changeset
    19
  (Options.string options "document_dump" = "");
bf7f434b91d7 clarified no_document situation;
wenzelm
parents: 48492
diff changeset
    20
48465
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    21
fun use_thys options =
48457
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    22
  Thy_Info.use_thys
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    23
    |> Unsynchronized.setmp Proofterm.proofs (Options.int options "proofs")
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    24
    |> Unsynchronized.setmp print_mode
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    25
        (space_explode "," (Options.string options "print_mode") @ print_mode_value ())
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    26
    |> Unsynchronized.setmp Goal.parallel_proofs (Options.int options "parallel_proofs")
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    27
    |> Unsynchronized.setmp Goal.parallel_proofs_threshold
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    28
        (Options.int options "parallel_proofs_threshold")
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    29
    |> Unsynchronized.setmp Multithreading.trace (Options.int options "threads_trace")
48460
20170ae271a5 tuned options;
wenzelm
parents: 48459
diff changeset
    30
    |> Unsynchronized.setmp Multithreading.max_threads (Options.int options "threads")
48500
bf7f434b91d7 clarified no_document situation;
wenzelm
parents: 48492
diff changeset
    31
    |> no_document options ? Present.no_document
48486
691d0b44a793 more build options;
wenzelm
parents: 48482
diff changeset
    32
    |> Unsynchronized.setmp quick_and_dirty (Options.bool options "quick_and_dirty")
691d0b44a793 more build options;
wenzelm
parents: 48482
diff changeset
    33
    |> Unsynchronized.setmp Printer.show_question_marks_default
691d0b44a793 more build options;
wenzelm
parents: 48482
diff changeset
    34
        (Options.bool options "show_question_marks")
691d0b44a793 more build options;
wenzelm
parents: 48482
diff changeset
    35
    |> Unsynchronized.setmp Name_Space.names_long_default (Options.bool options "names_long")
691d0b44a793 more build options;
wenzelm
parents: 48482
diff changeset
    36
    |> Unsynchronized.setmp Name_Space.names_short_default (Options.bool options "names_short")
48492
03530cf284ca more build options;
wenzelm
parents: 48486
diff changeset
    37
    |> Unsynchronized.setmp Name_Space.names_unique_default (Options.bool options "names_unique")
03530cf284ca more build options;
wenzelm
parents: 48486
diff changeset
    38
    |> Unsynchronized.setmp Toplevel.timing (Options.bool options "timing");
48457
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    39
48465
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    40
fun use_theories (options, thys) =
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    41
  let val condition = space_explode "," (Options.string options "condition") in
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    42
    (case filter_out (can getenv_strict) condition of
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    43
      [] => use_thys options thys
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    44
    | conds =>
48512
wenzelm
parents: 48511
diff changeset
    45
        Output.physical_stderr ("Skipping theories " ^ commas_quote thys ^
48477
322fbf571782 tuned message;
wenzelm
parents: 48472
diff changeset
    46
          " (undefined " ^ commas conds ^ ")\n"))
48465
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    47
  end;
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    48
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    49
in
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    50
48418
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    51
fun build args_file =
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    52
  let
48511
37999ee01156 remove old output heaps, to ensure that result is valid wrt. check_stamps;
wenzelm
parents: 48500
diff changeset
    53
    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
    54
        (name, (base_name, theories)))))))) =
48418
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    55
      File.read (Path.explode args_file) |> YXML.parse_body |>
48457
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    56
        let open XML.Decode in
48459
375e45df6fdf timing is command line options, not system option;
wenzelm
parents: 48458
diff changeset
    57
          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
    58
            (pair string (pair string ((list (pair Options.decode (list string)))))))))))
48457
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    59
        end;
48418
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    60
48457
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    61
    val _ =
48511
37999ee01156 remove old output heaps, to ensure that result is valid wrt. check_stamps;
wenzelm
parents: 48500
diff changeset
    62
      Session.init do_output false
48457
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    63
        (Options.bool options "browser_info") browser_info
48458
09710d6fc3d1 clarified document options;
wenzelm
parents: 48457
diff changeset
    64
        (Options.string options "document")
48457
fd9e28d5a143 pass build options to ML;
wenzelm
parents: 48419
diff changeset
    65
        (Options.bool options "document_graph")
48466
3b2fb20df17d further imitation of ISABELLE_USEDIR_OPTIONS via options;
wenzelm
parents: 48465
diff changeset
    66
        (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
    67
        parent_base_name base_name
48468
7f2998b95249 added "document_dump_only" (cf. negated usedir -C);
wenzelm
parents: 48466
diff changeset
    68
        (not (Options.bool options "document_dump_only"), Options.string options "document_dump")
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
    69
        "" verbose;
48465
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    70
    val _ = Session.with_timing name timing (List.app use_theories) theories;
48418
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    71
    val _ = Session.finish ();
48511
37999ee01156 remove old output heaps, to ensure that result is valid wrt. check_stamps;
wenzelm
parents: 48500
diff changeset
    72
    val _ = if do_output then () else quit ();
48418
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    73
  in () end
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    74
  handle exn => (Output.error_msg (ML_Compiler.exn_message exn); exit 1);
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    75
1a634f9614fb some actual build function on ML side;
wenzelm
parents:
diff changeset
    76
end;
48465
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    77
a25daffda966 observe "condition";
wenzelm
parents: 48464
diff changeset
    78
end;