Changed function cabs to also allow abstraction over Vars.
--- 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