src/Pure/ML/ml_file.ML
author wenzelm
Thu, 15 Aug 2024 12:43:17 +0200
changeset 80712 05b16602a683
parent 78728 72631efa3821
permissions -rw-r--r--
clarified signature;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
62862
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/ML/ml_file.ML
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
     3
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
     4
Commands to load ML files.
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
     5
*)
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
     6
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
     7
signature ML_FILE =
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
     8
sig
78728
72631efa3821 explicitly reject 'handle' with catch-all patterns;
wenzelm
parents: 78035
diff changeset
     9
  val command: string -> bool -> bool option -> (theory -> Token.file) ->
68816
5a53724fe247 support named ML environments, notably "Isabelle", "SML";
wenzelm
parents: 67381
diff changeset
    10
    Toplevel.transition -> Toplevel.transition
72747
5f9d66155081 clarified theory keywords: loaded_files are determined statically in Scala, but ML needs to do it semantically;
wenzelm
parents: 69851
diff changeset
    11
  val ML: bool option -> (theory -> Token.file) -> Toplevel.transition -> Toplevel.transition
5f9d66155081 clarified theory keywords: loaded_files are determined statically in Scala, but ML needs to do it semantically;
wenzelm
parents: 69851
diff changeset
    12
  val SML: bool option -> (theory -> Token.file) -> Toplevel.transition -> Toplevel.transition
62862
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    13
end;
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    14
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    15
structure ML_File: ML_FILE =
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    16
struct
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    17
78728
72631efa3821 explicitly reject 'handle' with catch-all patterns;
wenzelm
parents: 78035
diff changeset
    18
fun command environment catch_all debug get_file = Toplevel.generic_theory (fn gthy =>
62862
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    19
  let
72747
5f9d66155081 clarified theory keywords: loaded_files are determined statically in Scala, but ML needs to do it semantically;
wenzelm
parents: 69851
diff changeset
    20
    val file = get_file (Context.theory_of gthy);
69851
29a4f633609e clarified signature;
wenzelm
parents: 68820
diff changeset
    21
    val provide = Resources.provide_file file;
29a4f633609e clarified signature;
wenzelm
parents: 68820
diff changeset
    22
    val source = Token.file_source file;
67377
143665524d8e check formal comments recursively, within arbitrary cartouches (unknown sublanguages);
wenzelm
parents: 62902
diff changeset
    23
73761
ef1a18e20ace clarified modules;
wenzelm
parents: 72747
diff changeset
    24
    val _ = Document_Output.check_comments (Context.proof_of gthy) (Input.source_explode source);
67377
143665524d8e check formal comments recursively, within arbitrary cartouches (unknown sublanguages);
wenzelm
parents: 62902
diff changeset
    25
68816
5a53724fe247 support named ML environments, notably "Isabelle", "SML";
wenzelm
parents: 67381
diff changeset
    26
    val flags: ML_Compiler.flags =
78728
72631efa3821 explicitly reject 'handle' with catch-all patterns;
wenzelm
parents: 78035
diff changeset
    27
      {environment = environment, redirect = true, verbose = true, catch_all = catch_all,
62902
3c0f53eae166 more conventional theory syntax for ML bootstrap, with 'ML_file' instead of 'use';
wenzelm
parents: 62873
diff changeset
    28
        debug = debug, writeln = writeln, warning = warning};
62862
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    29
  in
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    30
    gthy
78035
bd5f6cee8001 proper position for ML-like commands;
wenzelm
parents: 73761
diff changeset
    31
    |> Local_Theory.touch_ml_env
62862
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    32
    |> ML_Context.exec (fn () => ML_Context.eval_source flags source)
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    33
    |> Local_Theory.propagate_ml_env
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    34
    |> Context.mapping provide (Local_Theory.background_theory provide)
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    35
  end);
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    36
78728
72631efa3821 explicitly reject 'handle' with catch-all patterns;
wenzelm
parents: 78035
diff changeset
    37
val ML = command "" false;
72631efa3821 explicitly reject 'handle' with catch-all patterns;
wenzelm
parents: 78035
diff changeset
    38
val SML = command ML_Env.SML true;
62862
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    39
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    40
end;