Changed function cabs to also allow abstraction over Vars.
authorberghofe
Tue, 26 Oct 2004 16:34:19 +0200
changeset 15264 a881ad2e9edc
parent 15263 b40e91201039
child 15265 a1547232fedd
Changed function cabs to also allow abstraction over Vars.
src/Pure/thm.ML
--- a/src/Pure/thm.ML	Tue Oct 26 16:33:35 2004 +0200
+++ b/src/Pure/thm.ML	Tue Oct 26 16:34:19 2004 +0200
@@ -226,11 +226,11 @@
       else raise CTERM "capply: types don't agree"
   | capply _ _ = raise CTERM "capply: first arg is not a function"
 
-fun cabs (Cterm {t=Free(a,ty), sign_ref=sign_ref1, T=T1, maxidx=maxidx1})
+fun cabs (Cterm {t=t1, sign_ref=sign_ref1, T=T1, maxidx=maxidx1})
          (Cterm {t=t2, sign_ref=sign_ref2, T=T2, maxidx=maxidx2}) =
-      Cterm {t=Sign.nodup_vars (absfree(a,ty,t2)), sign_ref=Sign.merge_refs(sign_ref1,sign_ref2),
-             T = ty --> T2, maxidx=Int.max(maxidx1, maxidx2)}
-  | cabs _ _ = raise CTERM "cabs: first arg is not a free variable";
+      Cterm {t=Sign.nodup_vars (lambda t1 t2), sign_ref=Sign.merge_refs(sign_ref1,sign_ref2),
+             T = T1 --> T2, maxidx=Int.max(maxidx1, maxidx2)}
+      handle TERM _ => raise CTERM "cabs: first arg is not a variable";
 
 (*Matching of cterms*)
 fun gen_cterm_match mtch