# HG changeset patch # User wenzelm # Date 1703004895 -3600 # Node ID c9f253e9125731dfc094bf11fc962c132f5bdf3c # Parent 3114c98738e631c0eb42630fad2c7eea785289fe more robust: avoid assumption about Context.certificate_theory; diff -r 3114c98738e6 -r c9f253e91257 src/Pure/thm.ML --- a/src/Pure/thm.ML Tue Dec 19 17:31:12 2023 +0100 +++ b/src/Pure/thm.ML Tue Dec 19 17:54:55 2023 +0100 @@ -1001,23 +1001,22 @@ type_variable = fn T => map (pair ([], [])) (Type.sort_of_atyp T)} (typ, sort); +fun bad_constraint_theory cert ({theory = thy, ...}: constraint) = + if Context.eq_thy_id (Context.certificate_theory_id cert, Context.theory_id thy) + then NONE else SOME thy; + in -fun solve_constraints (thm as Thm (_, {constraints = [], ...})) = thm - | solve_constraints (thm as Thm (der, args)) = +fun solve_constraints (thm as Thm (der, args)) = let val {cert, tags, maxidx, constraints, shyps, hyps, tpairs, prop} = args; - val thy = Context.certificate_theory cert - handle ERROR msg => raise CONTEXT (msg, [], [], [thm], NONE); - val bad_thys = - constraints |> map_filter (fn {theory = thy', ...} => - if Context.eq_thy (thy, thy') then NONE else SOME thy'); - val () = + val bad_thys = map_filter (bad_constraint_theory cert) constraints; + val _ = if null bad_thys then () else raise THEORY ("solve_constraints: bad theories for theorem\n" ^ - Syntax.string_of_term_global thy (prop_of thm), thy :: bad_thys); + Syntax.string_of_term_global (hd bad_thys) (prop_of thm), bad_thys); val Deriv {promises, body = PBody {oracles, thms, zboxes, zproof, proof}} = der; val (oracles', thms') = (oracles, thms)