(* Title: Pure/skip_proof.ML Author: Makarius Skip proof via oracle invocation. *) signature SKIP_PROOF = sig val report: Proof.context -> unit val make_thm_cterm: cterm -> thm val make_thm: theory -> term -> thm val cheat_tac: Proof.context -> int -> tactic end; structure Skip_Proof: SKIP_PROOF = struct (* report *) fun report ctxt = if Context_Position.is_visible ctxt then Output.report [Markup.markup (Markup.bad ()) "Skipped proof"] else (); (* oracle setup *) val (_, make_thm_cterm) = Context.>>> (Context.map_theory_result (Thm.add_oracle (Binding.make ("skip_proof", \<^here>), I))); fun make_thm thy prop = make_thm_cterm (Thm.global_cterm_of thy prop); (* cheat_tac -- 'sorry' *) fun cheat_tac ctxt = SUBGOAL (fn (goal, i) => let val thy = Proof_Context.theory_of ctxt; val assms = Assumption.all_assms_of ctxt; val cheat = make_thm thy (Logic.list_implies (map Thm.term_of assms, goal)); val thm = Drule.implies_elim_list cheat (map Thm.assume assms); in PRIMITIVE (Drule.with_subgoal i (Thm.elim_implies thm)) end); end;