ProgTutorial/Base.thy
author Christian Urban <urbanc@in.tum.de>
Thu, 26 Mar 2009 19:00:51 +0000
changeset 210 db8e302f44c8
parent 189 069d525f8f1d
child 224 647cab4a72c2
permissions -rw-r--r--
more work on the simple inductive section

theory Base
imports Main
uses
  "chunks.ML"
  "antiquote_setup.ML"
begin

(* to have a special tag for text enclosed in ML *)
ML {*

fun inherit_env (context as Context.Proof lthy) =
      Context.Proof (LocalTheory.map_contexts (ML_Context.inherit_env context) lthy)
  | inherit_env context = context;

fun inherit_env_prf prf = Proof.map_contexts
  (Context.proof_map (ML_Context.inherit_env (Context.Proof (Proof.context_of prf)))) prf

val _ =
  OuterSyntax.command "ML" "eval ML text within theory"
    (OuterKeyword.tag "TutorialML" OuterKeyword.thy_decl)
    (OuterParse.ML_source >> (fn (txt, pos) =>
      Toplevel.generic_theory
        (ML_Context.exec (fn () => ML_Context.eval true pos txt) #> inherit_env)));


val _ =
  OuterSyntax.command "ML_prf" "ML text within proof" 
    (OuterKeyword.tag "TutorialML" OuterKeyword.prf_decl)
    (OuterParse.ML_source >> (fn (txt, pos) =>
      Toplevel.proof (Proof.map_context (Context.proof_map
        (ML_Context.exec (fn () => ML_Context.eval true pos txt))) #> inherit_env_prf)))

*}
(*
ML {*
  fun warning str = str
  fun tracing str = str
*}
*)
end