local_abbrev: proper fix/declare of local entities;
authorwenzelm
Wed, 13 Dec 2006 14:52:30 +0100
changeset 21814 d7bb902beb07
parent 21813 06a06f6d3166
child 21815 0fba71f35a9c
local_abbrev: proper fix/declare of local entities;
src/Pure/Isar/proof_context.ML
--- a/src/Pure/Isar/proof_context.ML	Wed Dec 13 12:42:26 2006 +0100
+++ b/src/Pure/Isar/proof_context.ML	Wed Dec 13 14:52:30 2006 +0100
@@ -921,10 +921,16 @@
   end;
 
 fun local_abbrev (x, rhs) =
-  let
-    val T = Term.fastype_of rhs;
-    val export = Envir.expand_term_frees [((x, T), rhs)];
-  in Assumption.add_assms (K (K (I, export))) [] #> snd #> pair (Free (x, T), rhs) end;
+  Variable.add_fixes [x] #-> (fn [x'] =>
+    let
+      val T = Term.fastype_of rhs;
+      val lhs = Free (x', T);
+    in
+      Variable.declare_term lhs #>
+      Variable.declare_term rhs #>
+      Assumption.add_assms (K (K (I, Envir.expand_term_frees [((x', T), rhs)]))) [] #> snd #>
+      pair (lhs, rhs)
+    end);
 
 
 (* fixes *)