src/Pure/ML/ml_file.ML
author wenzelm
Thu, 01 Sep 2016 16:05:22 +0200
changeset 63750 9c8a366778e1
parent 62902 3c0f53eae166
child 67377 143665524d8e
permissions -rw-r--r--
more robust persistent storage; tuned;
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
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
     9
  val ML: bool option -> (theory -> Token.file list) -> Toplevel.transition -> Toplevel.transition
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    10
  val SML: bool option -> (theory -> Token.file list) -> Toplevel.transition -> Toplevel.transition
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    11
end;
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    12
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    13
structure ML_File: ML_FILE =
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    14
struct
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    15
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    16
fun command SML debug files = Toplevel.generic_theory (fn gthy =>
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    17
  let
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    18
    val [{src_path, lines, digest, pos}: Token.file] = files (Context.theory_of gthy);
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    19
    val provide = Resources.provide (src_path, digest);
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    20
    val source = Input.source true (cat_lines lines) (pos, pos);
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    21
    val flags =
62902
3c0f53eae166 more conventional theory syntax for ML bootstrap, with 'ML_file' instead of 'use';
wenzelm
parents: 62873
diff changeset
    22
      {SML = SML, exchange = false, redirect = true, verbose = true,
3c0f53eae166 more conventional theory syntax for ML bootstrap, with 'ML_file' instead of 'use';
wenzelm
parents: 62873
diff changeset
    23
        debug = debug, writeln = writeln, warning = warning};
62862
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    24
  in
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    25
    gthy
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    26
    |> ML_Context.exec (fn () => ML_Context.eval_source flags source)
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    27
    |> Local_Theory.propagate_ml_env
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    28
    |> Context.mapping provide (Local_Theory.background_theory provide)
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    29
  end);
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    30
62902
3c0f53eae166 more conventional theory syntax for ML bootstrap, with 'ML_file' instead of 'use';
wenzelm
parents: 62873
diff changeset
    31
val ML = command false;
3c0f53eae166 more conventional theory syntax for ML bootstrap, with 'ML_file' instead of 'use';
wenzelm
parents: 62873
diff changeset
    32
val SML = command true;
62862
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    33
007c454d0d0f more uniform ML file commands;
wenzelm
parents:
diff changeset
    34
end;