protect simplifier operation against spurious exceptions from simprocs;
authorwenzelm
Mon, 05 Aug 2002 21:17:45 +0200
changeset 13458 a73823f70159
parent 13457 7ddcf40a80b3
child 13459 83f41b047a39
protect simplifier operation against spurious exceptions from simprocs;
src/Pure/meta_simplifier.ML
--- a/src/Pure/meta_simplifier.ML	Mon Aug 05 21:17:04 2002 +0200
+++ b/src/Pure/meta_simplifier.ML	Mon Aug 05 21:17:45 2002 +0200
@@ -651,9 +651,10 @@
       | proc_rews ({name, proc, lhs, ...} :: ps) =
           if Pattern.matches tsigt (term_of lhs, term_of t) then
             (debug_term false ("Trying procedure " ^ quote name ^ " on:") signt eta_t;
-             case proc signt prems eta_t of
-               None => (debug false "FAILED"; proc_rews ps)
-             | Some raw_thm =>
+             case try (fn () => proc signt prems eta_t) () of
+               None => (debug true "EXCEPTION in simproc"; proc_rews ps)
+             | Some None => (debug false "FAILED"; proc_rews ps)
+             | Some (Some raw_thm) =>
                  (trace_thm false ("Procedure " ^ quote name ^ " produced rewrite rule:") raw_thm;
                   (case rews (mk_procrule raw_thm) of
                     None => (trace_cterm false "IGNORED - does not match" t; proc_rews ps)