src/Pure/System/build.ML
author wenzelm
Tue Jul 24 21:54:49 2012 +0200 (2012-07-24)
changeset 48492 03530cf284ca
parent 48486 691d0b44a793
child 48500 bf7f434b91d7
permissions -rw-r--r--
more build options;
wenzelm@48418
     1
(*  Title:      Pure/System/build.ML
wenzelm@48418
     2
    Author:     Makarius
wenzelm@48418
     3
wenzelm@48418
     4
Build Isabelle sessions.
wenzelm@48418
     5
*)
wenzelm@48418
     6
wenzelm@48418
     7
signature BUILD =
wenzelm@48418
     8
sig
wenzelm@48418
     9
  val build: string -> unit
wenzelm@48418
    10
end;
wenzelm@48418
    11
wenzelm@48418
    12
structure Build: BUILD =
wenzelm@48418
    13
struct
wenzelm@48418
    14
wenzelm@48465
    15
local
wenzelm@48465
    16
wenzelm@48465
    17
fun use_thys options =
wenzelm@48457
    18
  Thy_Info.use_thys
wenzelm@48457
    19
    |> Unsynchronized.setmp Proofterm.proofs (Options.int options "proofs")
wenzelm@48457
    20
    |> Unsynchronized.setmp print_mode
wenzelm@48457
    21
        (space_explode "," (Options.string options "print_mode") @ print_mode_value ())
wenzelm@48457
    22
    |> Unsynchronized.setmp Goal.parallel_proofs (Options.int options "parallel_proofs")
wenzelm@48457
    23
    |> Unsynchronized.setmp Goal.parallel_proofs_threshold
wenzelm@48457
    24
        (Options.int options "parallel_proofs_threshold")
wenzelm@48457
    25
    |> Unsynchronized.setmp Multithreading.trace (Options.int options "threads_trace")
wenzelm@48460
    26
    |> Unsynchronized.setmp Multithreading.max_threads (Options.int options "threads")
wenzelm@48472
    27
    |> (case Options.string options "document" of "" => true | "false" => true | _ => false) ?
wenzelm@48470
    28
        Present.no_document
wenzelm@48486
    29
    |> Unsynchronized.setmp quick_and_dirty (Options.bool options "quick_and_dirty")
wenzelm@48486
    30
    |> Unsynchronized.setmp Printer.show_question_marks_default
wenzelm@48486
    31
        (Options.bool options "show_question_marks")
wenzelm@48486
    32
    |> Unsynchronized.setmp Name_Space.names_long_default (Options.bool options "names_long")
wenzelm@48486
    33
    |> Unsynchronized.setmp Name_Space.names_short_default (Options.bool options "names_short")
wenzelm@48492
    34
    |> Unsynchronized.setmp Name_Space.names_unique_default (Options.bool options "names_unique")
wenzelm@48492
    35
    |> Unsynchronized.setmp Toplevel.timing (Options.bool options "timing");
wenzelm@48457
    36
wenzelm@48465
    37
fun use_theories (options, thys) =
wenzelm@48465
    38
  let val condition = space_explode "," (Options.string options "condition") in
wenzelm@48465
    39
    (case filter_out (can getenv_strict) condition of
wenzelm@48465
    40
      [] => use_thys options thys
wenzelm@48465
    41
    | conds =>
wenzelm@48465
    42
        Output.physical_stderr ("Ignoring theories " ^ commas_quote thys ^
wenzelm@48477
    43
          " (undefined " ^ commas conds ^ ")\n"))
wenzelm@48465
    44
  end;
wenzelm@48465
    45
wenzelm@48465
    46
in
wenzelm@48465
    47
wenzelm@48418
    48
fun build args_file =
wenzelm@48418
    49
  let
wenzelm@48482
    50
    val (save, (options, (timing, (verbose, (browser_info, (parent_base_name,
wenzelm@48459
    51
        (name, (base_name, theories)))))))) =
wenzelm@48418
    52
      File.read (Path.explode args_file) |> YXML.parse_body |>
wenzelm@48457
    53
        let open XML.Decode in
wenzelm@48459
    54
          pair bool (pair Options.decode (pair bool (pair bool (pair string (pair string
wenzelm@48459
    55
            (pair string (pair string ((list (pair Options.decode (list string)))))))))))
wenzelm@48457
    56
        end;
wenzelm@48418
    57
wenzelm@48457
    58
    val _ =
wenzelm@48462
    59
      Session.init save false
wenzelm@48457
    60
        (Options.bool options "browser_info") browser_info
wenzelm@48458
    61
        (Options.string options "document")
wenzelm@48457
    62
        (Options.bool options "document_graph")
wenzelm@48466
    63
        (space_explode ":" (Options.string options "document_variants"))
wenzelm@48482
    64
        parent_base_name base_name
wenzelm@48468
    65
        (not (Options.bool options "document_dump_only"), Options.string options "document_dump")
wenzelm@48463
    66
        (Options.string options "browser_info_remote")
wenzelm@48457
    67
        verbose;
wenzelm@48465
    68
    val _ = Session.with_timing name timing (List.app use_theories) theories;
wenzelm@48418
    69
    val _ = Session.finish ();
wenzelm@48419
    70
    val _ = if save then () else quit ();
wenzelm@48418
    71
  in () end
wenzelm@48418
    72
  handle exn => (Output.error_msg (ML_Compiler.exn_message exn); exit 1);
wenzelm@48418
    73
wenzelm@48418
    74
end;
wenzelm@48465
    75
wenzelm@48465
    76
end;