Added check for axioms with "realizes Null A = A".
authorberghofe
Mon, 30 Sep 2002 16:42:46 +0200
changeset 13609 73c3915553b4
parent 13608 9a6f43b8eae1
child 13610 d4a2ac255447
Added check for axioms with "realizes Null A = A".
src/Pure/Proof/extraction.ML
--- a/src/Pure/Proof/extraction.ML	Mon Sep 30 16:40:57 2002 +0200
+++ b/src/Pure/Proof/extraction.ML	Mon Sep 30 16:42:46 2002 +0200
@@ -445,7 +445,7 @@
             val defs' = if T = nullT then defs
               else fst (extr d defs vs ts Ts hs prf0)
           in
-            if T = nullT andalso realizes_null vs' prop = prop then (defs, prf0)
+            if T = nullT andalso realizes_null vs' prop aconv prop then (defs, prf0)
             else case Symtab.lookup (realizers, name) of
               None => (case find vs' (find' name defs') of
                 None =>
@@ -476,7 +476,9 @@
             val (vs', tye) = find_inst prop Ts ts vs;
             val tye' = (map fst (term_tvars prop) ~~ Ts') @ tye
           in
-            case find vs' (Symtab.lookup_multi (realizers, s)) of
+            if etype_of sg vs' [] prop = nullT andalso
+              realizes_null vs' prop aconv prop then (defs, prf0)
+            else case find vs' (Symtab.lookup_multi (realizers, s)) of
               Some (_, prf) => (defs, prf_subst_TVars tye' prf)
             | None => error ("corr: no realizer for instance of axiom " ^
                 quote s ^ ":\n" ^ Sign.string_of_term sg (Envir.beta_norm
@@ -578,7 +580,7 @@
           in
             case find vs' (Symtab.lookup_multi (realizers, s)) of
               Some (t, _) => (defs, subst_TVars tye' t)
-            | None => error ("no realizer for instance of axiom " ^
+            | None => error ("extr: no realizer for instance of axiom " ^
                 quote s ^ ":\n" ^ Sign.string_of_term sg (Envir.beta_norm
                   (Reconstruct.prop_of (proof_combt (prf0, ts)))))
           end