src/Pure/pure_syn.ML
author wenzelm
Wed, 22 Aug 2012 12:47:49 +0200
changeset 48881 46e053eda5dd
parent 48879 cb5cdbb645cd
child 48896 bb1f461a7815
permissions -rw-r--r--
clarified Parse.path vs. Parse.explode -- prefer errors in proper transaction context;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
48879
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/pure_syn.ML
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
     3
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
     4
Minimal outer syntax for bootstrapping Pure.
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
     5
*)
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
     6
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
     7
structure Pure_Syn: sig end =
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
     8
struct
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
     9
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    10
val _ =
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    11
  Outer_Syntax.command
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    12
    (("theory", Keyword.tag_theory Keyword.thy_begin), Position.none) "begin theory context"
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    13
    (Thy_Header.args >> (fn header =>
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    14
      Toplevel.print o
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    15
        Toplevel.init_theory
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    16
          (fn () => Thy_Info.toplevel_begin_theory (Thy_Load.get_master_path ()) header)));
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    17
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    18
val _ =
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    19
  Outer_Syntax.command
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    20
    (("ML_file", Keyword.tag_ml Keyword.thy_load), Position.none) "ML text from file"
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    21
    (Scan.ahead Parse.path -- Thy_Load.parse_files "ML_file"
48881
46e053eda5dd clarified Parse.path vs. Parse.explode -- prefer errors in proper transaction context;
wenzelm
parents: 48879
diff changeset
    22
      >> (fn (name, files) => Toplevel.generic_theory (fn gthy =>
48879
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    23
        let
48881
46e053eda5dd clarified Parse.path vs. Parse.explode -- prefer errors in proper transaction context;
wenzelm
parents: 48879
diff changeset
    24
          val src_path = Path.explode name;
48879
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    25
          val (dir, [(txt, pos)]) = files (Context.theory_of gthy);
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    26
          val provide = Thy_Load.provide (src_path, (File.full_path dir src_path, SHA1.digest txt));
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    27
        in
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    28
          gthy
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    29
          |> ML_Context.exec (fn () => ML_Context.eval_text true pos txt)
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    30
          |> Local_Theory.propagate_ml_env
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    31
          |> Context.mapping provide (Local_Theory.background_theory provide)
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    32
        end)));
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    33
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    34
end;
cb5cdbb645cd clarified bootstrapping of Pure;
wenzelm
parents:
diff changeset
    35