| author | wenzelm |
| Tue, 24 Sep 2024 21:24:44 +0200 | |
| changeset 80945 | 584828fa7a97 |
| parent 78795 | f7e972d567f3 |
| permissions | -rw-r--r-- |
| 51551 | 1 |
(* Title: Pure/skip_proof.ML |
2 |
Author: Makarius |
|
|
6888
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
3 |
|
| 51551 | 4 |
Skip proof via oracle invocation. |
|
6888
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
5 |
*) |
|
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
6 |
|
|
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
7 |
signature SKIP_PROOF = |
|
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
8 |
sig |
| 51551 | 9 |
val report: Proof.context -> unit |
| 42409 | 10 |
val make_thm_cterm: cterm -> thm |
| 11892 | 11 |
val make_thm: theory -> term -> thm |
|
59498
50b60f501b05
proper context for resolve_tac, eresolve_tac, dresolve_tac, forward_tac etc.;
wenzelm
parents:
58837
diff
changeset
|
12 |
val cheat_tac: Proof.context -> int -> tactic |
|
6888
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
13 |
end; |
|
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
14 |
|
|
32970
fbd2bb2489a8
operations of structure Skip_Proof (formerly SkipProof) no longer require quick_and_dirty mode;
wenzelm
parents:
32966
diff
changeset
|
15 |
structure Skip_Proof: SKIP_PROOF = |
|
6888
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
16 |
struct |
|
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
17 |
|
| 51551 | 18 |
(* report *) |
19 |
||
20 |
fun report ctxt = |
|
| 71675 | 21 |
if Context_Position.reports_enabled ctxt then |
|
64677
8dc24130e8fe
more uniform treatment of "bad" like other messages (with serial number);
wenzelm
parents:
64556
diff
changeset
|
22 |
Output.report [Markup.markup (Markup.bad ()) "Skipped proof"] |
|
56294
85911b8a6868
prefer Context_Position where a context is available;
wenzelm
parents:
51552
diff
changeset
|
23 |
else (); |
| 51551 | 24 |
|
25 |
||
| 11892 | 26 |
(* oracle setup *) |
|
6888
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
27 |
|
| 42409 | 28 |
val (_, make_thm_cterm) = |
|
78795
f7e972d567f3
clarified signature: more concise variations on implicit theory setup;
wenzelm
parents:
71675
diff
changeset
|
29 |
Theory.setup_result (Thm.add_oracle (Binding.make ("skip_proof", \<^here>), I));
|
| 42409 | 30 |
|
|
59621
291934bac95e
Thm.cterm_of and Thm.ctyp_of operate on local context;
wenzelm
parents:
59498
diff
changeset
|
31 |
fun make_thm thy prop = make_thm_cterm (Thm.global_cterm_of thy prop); |
|
6888
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
32 |
|
| 11892 | 33 |
|
| 70563 | 34 |
(* cheat_tac -- 'sorry' *) |
| 11892 | 35 |
|
|
70561
0c1b08d0b1fe
more accurate proposition for cheat_tac (command 'sorry');
wenzelm
parents:
64677
diff
changeset
|
36 |
fun cheat_tac ctxt = SUBGOAL (fn (goal, i) => |
|
0c1b08d0b1fe
more accurate proposition for cheat_tac (command 'sorry');
wenzelm
parents:
64677
diff
changeset
|
37 |
let |
|
0c1b08d0b1fe
more accurate proposition for cheat_tac (command 'sorry');
wenzelm
parents:
64677
diff
changeset
|
38 |
val thy = Proof_Context.theory_of ctxt; |
|
0c1b08d0b1fe
more accurate proposition for cheat_tac (command 'sorry');
wenzelm
parents:
64677
diff
changeset
|
39 |
val assms = Assumption.all_assms_of ctxt; |
|
0c1b08d0b1fe
more accurate proposition for cheat_tac (command 'sorry');
wenzelm
parents:
64677
diff
changeset
|
40 |
val cheat = make_thm thy (Logic.list_implies (map Thm.term_of assms, goal)); |
|
0c1b08d0b1fe
more accurate proposition for cheat_tac (command 'sorry');
wenzelm
parents:
64677
diff
changeset
|
41 |
val thm = Drule.implies_elim_list cheat (map Thm.assume assms); |
|
0c1b08d0b1fe
more accurate proposition for cheat_tac (command 'sorry');
wenzelm
parents:
64677
diff
changeset
|
42 |
in PRIMITIVE (Drule.with_subgoal i (Thm.elim_implies thm)) end); |
| 26530 | 43 |
|
|
6888
d0c68ebdabc5
skip_proof feature 'sorry' (for quick_and_dirty mode only);
wenzelm
parents:
diff
changeset
|
44 |
end; |