redundancy check: drop trailing Var arguments (avoids eta problems with equations)
authorhaftmann
Wed, 29 Sep 2010 15:28:29 +0200
changeset 39791 a91430778479
parent 39789 533dd8cda12c
child 39792 4b615e3ddef7
redundancy check: drop trailing Var arguments (avoids eta problems with equations)
src/HOL/Library/More_List.thy
src/Pure/Isar/code.ML
--- a/src/HOL/Library/More_List.thy	Wed Sep 29 11:55:08 2010 +0200
+++ b/src/HOL/Library/More_List.thy	Wed Sep 29 15:28:29 2010 +0200
@@ -100,8 +100,6 @@
   "fold plus xs = plus (listsum (rev xs))"
   by (induct xs) (simp_all add: add.assoc)
 
-declare listsum_foldl [code del]
-
 lemma (in monoid_add) listsum_conv_fold [code]:
   "listsum xs = fold (\<lambda>x y. y + x) xs 0"
   by (auto simp add: listsum_foldl foldl_fold fun_eq_iff)
--- a/src/Pure/Isar/code.ML	Wed Sep 29 11:55:08 2010 +0200
+++ b/src/Pure/Isar/code.ML	Wed Sep 29 15:28:29 2010 +0200
@@ -1049,8 +1049,8 @@
     val c = const_eqn thy thm;
     fun update_subsume thy (thm, proper) eqns = 
       let
-        val args_of = snd o strip_comb o map_types Type.strip_sorts
-          o fst o Logic.dest_equals o Thm.plain_prop_of;
+        val args_of = dropwhile is_Var o rev o snd o strip_comb
+          o map_types Type.strip_sorts o fst o Logic.dest_equals o Thm.plain_prop_of;
         val args = args_of thm;
         val incr_idx = Logic.incr_indexes ([], Thm.maxidx_of thm + 1);
         fun matches_args args' = length args <= length args' andalso