"prepare_proof" has been simplified because
authorpaulson
Fri, 22 Dec 1995 10:26:57 +0100
changeset 1413 73fac49f608f
parent 1412 2ab32768c996
child 1414 036e072b215a
"prepare_proof" has been simplified because rewrite_rule and rewrite_goals_rule check for empty lists. The list of premises is *not* passed to Thm.compress; this was tried, but the potential storage gains seemed not to justify the cpu time required.
src/Pure/goals.ML
--- a/src/Pure/goals.ML	Fri Dec 22 10:19:55 1995 +0100
+++ b/src/Pure/goals.ML	Fri Dec 22 10:26:57 1995 +0100
@@ -128,10 +128,8 @@
   let val {sign, t=horn,...} = rep_cterm chorn;
       val (_,As,B) = Logic.strip_horn(horn);
       val cAs = map (cterm_of sign) As;
-      val p_rew = if null rths then I else rewrite_rule rths;
-      val c_rew = if null rths then I else rewrite_goals_rule rths;
-      val prems = map (p_rew o forall_elim_vars(0) o assume) cAs
-      and st0 = c_rew (trivial (cterm_of sign B))
+      val prems = map (rewrite_rule rths o forall_elim_vars(0) o assume) cAs
+      and st0 = (rewrite_goals_rule rths o trivial) (cterm_of sign B)
       fun result_error state msg = 
         (writeln ("Bad final proof state:");
  	 !print_goals_ref (!goals_limit) state;