@{lemma}: allow terminal method;
authorwenzelm
Thu, 10 Jul 2008 13:37:35 +0200
changeset 27522 b819d3b263a0
parent 27521 44081396d735
child 27523 56eb04c7b6b2
@{lemma}: allow terminal method;
src/Pure/Thy/thy_output.ML
--- a/src/Pure/Thy/thy_output.ML	Thu Jul 10 13:37:34 2008 +0200
+++ b/src/Pure/Thy/thy_output.ML	Thu Jul 10 13:37:35 2008 +0200
@@ -463,13 +463,6 @@
     val t' = Term.betapplys (Envir.expand_atom T (U, u), args);
   in pretty_term_abbrev ctxt (Logic.mk_equals (t, t')) end;
 
-fun pretty_lemma ctxt (prop, method_text) =
-  let
-    val _ = ctxt
-      |> Proof.theorem_i NONE (K I) [[(prop, [])]]
-      |> Proof.global_terminal_proof (method_text, NONE);
-  in pretty_term ctxt prop end;
-
 fun pretty_thm ctxt = pretty_term ctxt o Thm.full_prop_of;
 
 fun pretty_term_style ctxt (name, t) =
@@ -525,12 +518,22 @@
     #> space_implode "\\isasep\\isanewline%\n"));
 
 
-(* commands *)
+(* embedded lemmas *)
+
+fun pretty_lemma ctxt (prop, methods) =
+  let
+    val _ = ctxt
+      |> Proof.theorem_i NONE (K I) [[(prop, [])]]
+      |> Proof.global_terminal_proof methods;
+  in pretty_term ctxt prop end;
 
 val embedded_lemma =
-  args (Args.prop -- Scan.lift (Args.$$$ "by" |-- Method.parse_args))
+  args (Args.prop -- Scan.lift (Args.$$$ "by" |-- Method.parse_args -- Scan.option Method.parse_args))
     (output pretty_lemma o (fn ((a, arg :: _), p) => (Args.src ((a, [arg]), p))) o Args.dest_src);
 
+
+(* commands *)
+
 val _ = OuterKeyword.keyword "by";
 
 val _ = add_commands