| author | haftmann | 
| Wed, 28 Jan 2015 08:29:08 +0100 | |
| changeset 59456 | 180555df34ea | 
| parent 58999 | ed09ae4ea2d8 | 
| child 59901 | 840d03805755 | 
| permissions | -rw-r--r-- | 
| 48929 
05d4e5f660ae
entity markup for theory Pure, to enable hyperlinks etc.;
 wenzelm parents: 
48891diff
changeset | 1 | (* Title: Pure/Pure.thy | 
| 
05d4e5f660ae
entity markup for theory Pure, to enable hyperlinks etc.;
 wenzelm parents: 
48891diff
changeset | 2 | Author: Makarius | 
| 
05d4e5f660ae
entity markup for theory Pure, to enable hyperlinks etc.;
 wenzelm parents: 
48891diff
changeset | 3 | |
| 
05d4e5f660ae
entity markup for theory Pure, to enable hyperlinks etc.;
 wenzelm parents: 
48891diff
changeset | 4 | Final stage of bootstrapping Pure, based on implicit background theory. | 
| 
05d4e5f660ae
entity markup for theory Pure, to enable hyperlinks etc.;
 wenzelm parents: 
48891diff
changeset | 5 | *) | 
| 
05d4e5f660ae
entity markup for theory Pure, to enable hyperlinks etc.;
 wenzelm parents: 
48891diff
changeset | 6 | |
| 48638 | 7 | theory Pure | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 8 | keywords | 
| 58928 
23d0ffd48006
plain value Keywords.keywords, which might be used outside theory for bootstrap purposes;
 wenzelm parents: 
58918diff
changeset | 9 | "!!" "!" "+" "--" ":" ";" "<" "<=" "=" "=>" "?" "[" "\<equiv>" | 
| 
23d0ffd48006
plain value Keywords.keywords, which might be used outside theory for bootstrap purposes;
 wenzelm parents: 
58918diff
changeset | 10 | "\<leftharpoondown>" "\<rightharpoonup>" "\<rightleftharpoons>" | 
| 
23d0ffd48006
plain value Keywords.keywords, which might be used outside theory for bootstrap purposes;
 wenzelm parents: 
58918diff
changeset | 11 | "\<subseteq>" "]" "assumes" "attach" "binder" "constrains" | 
| 
23d0ffd48006
plain value Keywords.keywords, which might be used outside theory for bootstrap purposes;
 wenzelm parents: 
58918diff
changeset | 12 | "defines" "fixes" "for" "identifier" "if" "in" "includes" "infix" | 
| 
23d0ffd48006
plain value Keywords.keywords, which might be used outside theory for bootstrap purposes;
 wenzelm parents: 
58918diff
changeset | 13 | "infixl" "infixr" "is" "notes" "obtains" "open" "output" | 
| 51293 
05b1bbae748d
discontinued obsolete 'uses' within theory header;
 wenzelm parents: 
51274diff
changeset | 14 | "overloaded" "pervasive" "shows" "structure" "unchecked" "where" "|" | 
| 58999 
ed09ae4ea2d8
uniform treatment of all document markup commands: 'text' and 'txt' merely differ in LaTeX style;
 wenzelm parents: 
58928diff
changeset | 15 | and "text" "txt" :: document_body | 
| 
ed09ae4ea2d8
uniform treatment of all document markup commands: 'text' and 'txt' merely differ in LaTeX style;
 wenzelm parents: 
58928diff
changeset | 16 | and "text_raw" :: document_raw | 
| 57506 | 17 | and "default_sort" :: thy_decl == "" | 
| 18 | and "typedecl" "type_synonym" "nonterminal" "judgment" | |
| 55385 
169e12bbf9a3
discontinued axiomatic 'classes', 'classrel', 'arities';
 wenzelm parents: 
55152diff
changeset | 19 | "consts" "syntax" "no_syntax" "translations" "no_translations" "defs" | 
| 
169e12bbf9a3
discontinued axiomatic 'classes', 'classrel', 'arities';
 wenzelm parents: 
55152diff
changeset | 20 | "definition" "abbreviation" "type_notation" "no_type_notation" "notation" | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 21 | "no_notation" "axiomatization" "theorems" "lemmas" "declare" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 22 | "hide_class" "hide_type" "hide_const" "hide_fact" :: thy_decl | 
| 58918 | 23 | and "SML_file" :: thy_load % "ML" | 
| 56618 
874bdedb2313
added command 'SML_export' and 'SML_import' for exchange of toplevel bindings;
 wenzelm parents: 
56275diff
changeset | 24 | and "SML_import" "SML_export" :: thy_decl % "ML" | 
| 51295 | 25 | and "ML" :: thy_decl % "ML" | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 26 | and "ML_prf" :: prf_decl % "proof" (* FIXME % "ML" ?? *) | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 27 | and "ML_val" "ML_command" :: diag % "ML" | 
| 55762 
27a45aec67a0
suppress completion of obscure keyword, avoid confusion with plain "simp";
 wenzelm parents: 
55516diff
changeset | 28 | and "simproc_setup" :: thy_decl % "ML" == "" | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 29 | and "setup" "local_setup" "attribute_setup" "method_setup" | 
| 55762 
27a45aec67a0
suppress completion of obscure keyword, avoid confusion with plain "simp";
 wenzelm parents: 
55516diff
changeset | 30 | "declaration" "syntax_declaration" | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 31 | "parse_ast_translation" "parse_translation" "print_translation" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 32 | "typed_print_translation" "print_ast_translation" "oracle" :: thy_decl % "ML" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 33 | and "bundle" :: thy_decl | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 34 | and "include" "including" :: prf_decl | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 35 | and "print_bundles" :: diag | 
| 58800 
bfed1c26caed
explicit keyword category for commands that may start a block;
 wenzelm parents: 
58660diff
changeset | 36 | and "context" "locale" :: thy_decl_block | 
| 51224 
c3e99efacb67
back to non-schematic 'sublocale' and 'interpretation' (despite df8fc0567a3d) for more potential parallelism;
 wenzelm parents: 
50603diff
changeset | 37 | and "sublocale" "interpretation" :: thy_goal | 
| 
c3e99efacb67
back to non-schematic 'sublocale' and 'interpretation' (despite df8fc0567a3d) for more potential parallelism;
 wenzelm parents: 
50603diff
changeset | 38 | and "interpret" :: prf_goal % "proof" | 
| 58800 
bfed1c26caed
explicit keyword category for commands that may start a block;
 wenzelm parents: 
58660diff
changeset | 39 | and "class" :: thy_decl_block | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 40 | and "subclass" :: thy_goal | 
| 58800 
bfed1c26caed
explicit keyword category for commands that may start a block;
 wenzelm parents: 
58660diff
changeset | 41 | and "instantiation" :: thy_decl_block | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 42 | and "instance" :: thy_goal | 
| 58800 
bfed1c26caed
explicit keyword category for commands that may start a block;
 wenzelm parents: 
58660diff
changeset | 43 | and "overloading" :: thy_decl_block | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 44 | and "code_datatype" :: thy_decl | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 45 | and "theorem" "lemma" "corollary" :: thy_goal | 
| 51274 
cfc83ad52571
discontinued pointless command category "thy_schematic_goal" -- this is checked dynamically;
 wenzelm parents: 
51270diff
changeset | 46 | and "schematic_theorem" "schematic_lemma" "schematic_corollary" :: thy_goal | 
| 58800 
bfed1c26caed
explicit keyword category for commands that may start a block;
 wenzelm parents: 
58660diff
changeset | 47 | and "notepad" :: thy_decl_block | 
| 50128 
599c935aac82
alternative completion for outer syntax keywords;
 wenzelm parents: 
49569diff
changeset | 48 | and "have" :: prf_goal % "proof" | 
| 
599c935aac82
alternative completion for outer syntax keywords;
 wenzelm parents: 
49569diff
changeset | 49 | and "hence" :: prf_goal % "proof" == "then have" | 
| 
599c935aac82
alternative completion for outer syntax keywords;
 wenzelm parents: 
49569diff
changeset | 50 | and "show" :: prf_asm_goal % "proof" | 
| 
599c935aac82
alternative completion for outer syntax keywords;
 wenzelm parents: 
49569diff
changeset | 51 | and "thus" :: prf_asm_goal % "proof" == "then show" | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 52 | and "then" "from" "with" :: prf_chain % "proof" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 53 | and "note" "using" "unfolding" :: prf_decl % "proof" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 54 | and "fix" "assume" "presume" "def" :: prf_asm % "proof" | 
| 53371 
47b23c582127
more explicit indication of 'guess' as improper Isar (aka "script") element;
 wenzelm parents: 
52549diff
changeset | 55 | and "obtain" :: prf_asm_goal % "proof" | 
| 
47b23c582127
more explicit indication of 'guess' as improper Isar (aka "script") element;
 wenzelm parents: 
52549diff
changeset | 56 | and "guess" :: prf_asm_goal_script % "proof" | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 57 | and "let" "write" :: prf_decl % "proof" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 58 | and "case" :: prf_asm % "proof" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 59 |   and "{" :: prf_open % "proof"
 | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 60 | and "}" :: prf_close % "proof" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 61 | and "next" :: prf_block % "proof" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 62 | and "qed" :: qed_block % "proof" | 
| 53571 
e58ca0311c0f
more explicit indication of 'done' as proof script element;
 wenzelm parents: 
53371diff
changeset | 63 | and "by" ".." "." "sorry" :: "qed" % "proof" | 
| 
e58ca0311c0f
more explicit indication of 'done' as proof script element;
 wenzelm parents: 
53371diff
changeset | 64 | and "done" :: "qed_script" % "proof" | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 65 | and "oops" :: qed_global % "proof" | 
| 50128 
599c935aac82
alternative completion for outer syntax keywords;
 wenzelm parents: 
49569diff
changeset | 66 | and "defer" "prefer" "apply" :: prf_script % "proof" | 
| 
599c935aac82
alternative completion for outer syntax keywords;
 wenzelm parents: 
49569diff
changeset | 67 | and "apply_end" :: prf_script % "proof" == "" | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 68 | and "proof" :: prf_block % "proof" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 69 | and "also" "moreover" :: prf_decl % "proof" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 70 | and "finally" "ultimately" :: prf_chain % "proof" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 71 | and "back" :: prf_script % "proof" | 
| 56069 
451d5b73f8cf
simplified programming interface to define ML antiquotations -- NB: the transformed context ignores updates of the context parser;
 wenzelm parents: 
55762diff
changeset | 72 | and "help" "print_commands" "print_options" "print_context" | 
| 
451d5b73f8cf
simplified programming interface to define ML antiquotations -- NB: the transformed context ignores updates of the context parser;
 wenzelm parents: 
55762diff
changeset | 73 | "print_theory" "print_syntax" "print_abbrevs" "print_defn_rules" | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 74 | "print_theorems" "print_locales" "print_classes" "print_locale" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 75 | "print_interps" "print_dependencies" "print_attributes" | 
| 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 76 | "print_simpset" "print_rules" "print_trans_rules" "print_methods" | 
| 56069 
451d5b73f8cf
simplified programming interface to define ML antiquotations -- NB: the transformed context ignores updates of the context parser;
 wenzelm parents: 
55762diff
changeset | 77 | "print_antiquotations" "print_ML_antiquotations" "thy_deps" | 
| 58845 | 78 | "locale_deps" "class_deps" "thm_deps" "print_term_bindings" | 
| 57415 
e721124f1b1e
command 'print_term_bindings' supersedes 'print_binds';
 wenzelm parents: 
56864diff
changeset | 79 | "print_facts" "print_cases" "print_statement" "thm" "prf" "full_prf" | 
| 
e721124f1b1e
command 'print_term_bindings' supersedes 'print_binds';
 wenzelm parents: 
56864diff
changeset | 80 | "prop" "term" "typ" "print_codesetup" "unused_thms" :: diag | 
| 58845 | 81 | and "display_drafts" "print_state" :: diag | 
| 48646 
91281e9472d8
more official command specifications, including source position;
 wenzelm parents: 
48641diff
changeset | 82 | and "welcome" :: diag | 
| 48641 
92b48b8abfe4
more standard bootstrapping of Pure outer syntax;
 wenzelm parents: 
48638diff
changeset | 83 | and "end" :: thy_end % "theory" | 
| 56797 | 84 | and "realizers" :: thy_decl == "" | 
| 85 | and "realizability" :: thy_decl == "" | |
| 86 | and "extract_type" "extract" :: thy_decl | |
| 48646 
91281e9472d8
more official command specifications, including source position;
 wenzelm parents: 
48641diff
changeset | 87 | and "find_theorems" "find_consts" :: diag | 
| 57886 
7cae177c9084
support for named collections of theorems in canonical order;
 wenzelm parents: 
57506diff
changeset | 88 | and "named_theorems" :: thy_decl | 
| 48638 | 89 | begin | 
| 15803 | 90 | |
| 56205 | 91 | ML_file "ML/ml_antiquotations.ML" | 
| 55516 | 92 | ML_file "ML/ml_thms.ML" | 
| 56864 | 93 | ML_file "Tools/print_operation.ML" | 
| 48891 | 94 | ML_file "Isar/isar_syn.ML" | 
| 55141 | 95 | ML_file "Isar/calculation.ML" | 
| 58544 
340f130b3d38
bibtex support in ML: document antiquotation @{cite} with markup;
 wenzelm parents: 
58201diff
changeset | 96 | ML_file "Tools/bibtex.ML" | 
| 55030 | 97 | ML_file "Tools/rail.ML" | 
| 58860 | 98 | ML_file "Tools/rule_insts.ML" | 
| 99 | ML_file "Tools/thm_deps.ML" | |
| 58201 | 100 | ML_file "Tools/class_deps.ML" | 
| 48891 | 101 | ML_file "Tools/find_theorems.ML" | 
| 102 | ML_file "Tools/find_consts.ML" | |
| 54730 | 103 | ML_file "Tools/simplifier_trace.ML" | 
| 57886 
7cae177c9084
support for named collections of theorems in canonical order;
 wenzelm parents: 
57506diff
changeset | 104 | ML_file "Tools/named_theorems.ML" | 
| 48891 | 105 | |
| 106 | ||
| 58611 | 107 | section \<open>Basic attributes\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 108 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 109 | attribute_setup tagged = | 
| 58611 | 110 | \<open>Scan.lift (Args.name -- Args.name) >> Thm.tag\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 111 | "tagged theorem" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 112 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 113 | attribute_setup untagged = | 
| 58611 | 114 | \<open>Scan.lift Args.name >> Thm.untag\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 115 | "untagged theorem" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 116 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 117 | attribute_setup kind = | 
| 58611 | 118 | \<open>Scan.lift Args.name >> Thm.kind\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 119 | "theorem kind" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 120 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 121 | attribute_setup THEN = | 
| 58611 | 122 | \<open>Scan.lift (Scan.optional (Args.bracks Parse.nat) 1) -- Attrib.thm | 
| 123 | >> (fn (i, B) => Thm.rule_attribute (fn _ => fn A => A RSN (i, B)))\<close> | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 124 | "resolution with rule" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 125 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 126 | attribute_setup OF = | 
| 58611 | 127 | \<open>Attrib.thms >> (fn Bs => Thm.rule_attribute (fn _ => fn A => A OF Bs))\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 128 | "rule resolved with facts" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 129 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 130 | attribute_setup rename_abs = | 
| 58611 | 131 | \<open>Scan.lift (Scan.repeat (Args.maybe Args.name)) >> (fn vs => | 
| 132 | Thm.rule_attribute (K (Drule.rename_bvars' vs)))\<close> | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 133 | "rename bound variables in abstractions" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 134 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 135 | attribute_setup unfolded = | 
| 58611 | 136 | \<open>Attrib.thms >> (fn ths => | 
| 137 | Thm.rule_attribute (fn context => Local_Defs.unfold (Context.proof_of context) ths))\<close> | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 138 | "unfolded definitions" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 139 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 140 | attribute_setup folded = | 
| 58611 | 141 | \<open>Attrib.thms >> (fn ths => | 
| 142 | Thm.rule_attribute (fn context => Local_Defs.fold (Context.proof_of context) ths))\<close> | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 143 | "folded definitions" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 144 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 145 | attribute_setup consumes = | 
| 58611 | 146 | \<open>Scan.lift (Scan.optional Parse.int 1) >> Rule_Cases.consumes\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 147 | "number of consumed facts" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 148 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 149 | attribute_setup constraints = | 
| 58611 | 150 | \<open>Scan.lift Parse.nat >> Rule_Cases.constraints\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 151 | "number of equality constraints" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 152 | |
| 58611 | 153 | attribute_setup case_names = | 
| 154 | \<open>Scan.lift (Scan.repeat1 (Args.name -- | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 155 |     Scan.optional (@{keyword "["} |-- Scan.repeat1 (Args.maybe Args.name) --| @{keyword "]"}) []))
 | 
| 58611 | 156 | >> (fn cs => | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 157 | Rule_Cases.cases_hyp_names | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 158 | (map #1 cs) | 
| 58611 | 159 | (map (map (the_default Rule_Cases.case_hypsN) o #2) cs))\<close> | 
| 160 | "named rule cases" | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 161 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 162 | attribute_setup case_conclusion = | 
| 58611 | 163 | \<open>Scan.lift (Args.name -- Scan.repeat Args.name) >> Rule_Cases.case_conclusion\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 164 | "named conclusion of rule cases" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 165 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 166 | attribute_setup params = | 
| 58611 | 167 | \<open>Scan.lift (Parse.and_list1 (Scan.repeat Args.name)) >> Rule_Cases.params\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 168 | "named rule parameters" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 169 | |
| 58611 | 170 | attribute_setup rule_format = | 
| 171 | \<open>Scan.lift (Args.mode "no_asm") | |
| 172 | >> (fn true => Object_Logic.rule_format_no_asm | false => Object_Logic.rule_format)\<close> | |
| 173 | "result put into canonical rule format" | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 174 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 175 | attribute_setup elim_format = | 
| 58611 | 176 | \<open>Scan.succeed (Thm.rule_attribute (K Tactic.make_elim))\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 177 | "destruct rule turned into elimination rule format" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 178 | |
| 58611 | 179 | attribute_setup no_vars = | 
| 180 | \<open>Scan.succeed (Thm.rule_attribute (fn context => fn th => | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 181 | let | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 182 | val ctxt = Variable.set_body false (Context.proof_of context); | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 183 | val ((_, [th']), _) = Variable.import true [th] ctxt; | 
| 58611 | 184 | in th' end))\<close> | 
| 185 | "imported schematic variables" | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 186 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 187 | attribute_setup eta_long = | 
| 58611 | 188 | \<open>Scan.succeed (Thm.rule_attribute (fn _ => Conv.fconv_rule Drule.eta_long_conversion))\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 189 | "put theorem into eta long beta normal form" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 190 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 191 | attribute_setup atomize = | 
| 58611 | 192 | \<open>Scan.succeed Object_Logic.declare_atomize\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 193 | "declaration of atomize rule" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 194 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 195 | attribute_setup rulify = | 
| 58611 | 196 | \<open>Scan.succeed Object_Logic.declare_rulify\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 197 | "declaration of rulify rule" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 198 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 199 | attribute_setup rotated = | 
| 58611 | 200 | \<open>Scan.lift (Scan.optional Parse.int 1 | 
| 201 | >> (fn n => Thm.rule_attribute (fn _ => rotate_prems n)))\<close> | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 202 | "rotated theorem premises" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 203 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 204 | attribute_setup defn = | 
| 58611 | 205 | \<open>Attrib.add_del Local_Defs.defn_add Local_Defs.defn_del\<close> | 
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 206 | "declaration of definitional transformations" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 207 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 208 | attribute_setup abs_def = | 
| 58611 | 209 | \<open>Scan.succeed (Thm.rule_attribute (fn context => | 
| 210 | Local_Defs.meta_rewrite_rule (Context.proof_of context) #> Drule.abs_def))\<close> | |
| 55140 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 211 | "abstract over free variables of definitional theorem" | 
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 212 | |
| 
7eb0c04e4c40
define basic attributes in user-space Pure.thy -- which provides better hyperlinks and may serve as example;
 wenzelm parents: 
55030diff
changeset | 213 | |
| 58611 | 214 | section \<open>Further content for the Pure theory\<close> | 
| 20627 | 215 | |
| 58611 | 216 | subsection \<open>Meta-level connectives in assumptions\<close> | 
| 15803 | 217 | |
| 218 | lemma meta_mp: | |
| 58612 | 219 | assumes "PROP P \<Longrightarrow> PROP Q" and "PROP P" | 
| 15803 | 220 | shows "PROP Q" | 
| 58612 | 221 | by (rule \<open>PROP P \<Longrightarrow> PROP Q\<close> [OF \<open>PROP P\<close>]) | 
| 15803 | 222 | |
| 23432 | 223 | lemmas meta_impE = meta_mp [elim_format] | 
| 224 | ||
| 15803 | 225 | lemma meta_spec: | 
| 58612 | 226 | assumes "\<And>x. PROP P x" | 
| 26958 | 227 | shows "PROP P x" | 
| 58612 | 228 | by (rule \<open>\<And>x. PROP P x\<close>) | 
| 15803 | 229 | |
| 230 | lemmas meta_allE = meta_spec [elim_format] | |
| 231 | ||
| 26570 | 232 | lemma swap_params: | 
| 58612 | 233 | "(\<And>x y. PROP P x y) \<equiv> (\<And>y x. PROP P x y)" .. | 
| 26570 | 234 | |
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 235 | |
| 58611 | 236 | subsection \<open>Meta-level conjunction\<close> | 
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 237 | |
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 238 | lemma all_conjunction: | 
| 58612 | 239 | "(\<And>x. PROP A x &&& PROP B x) \<equiv> ((\<And>x. PROP A x) &&& (\<And>x. PROP B x))" | 
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 240 | proof | 
| 58612 | 241 | assume conj: "\<And>x. PROP A x &&& PROP B x" | 
| 242 | show "(\<And>x. PROP A x) &&& (\<And>x. PROP B x)" | |
| 19121 | 243 | proof - | 
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 244 | fix x | 
| 26958 | 245 | from conj show "PROP A x" by (rule conjunctionD1) | 
| 246 | from conj show "PROP B x" by (rule conjunctionD2) | |
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 247 | qed | 
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 248 | next | 
| 58612 | 249 | assume conj: "(\<And>x. PROP A x) &&& (\<And>x. PROP B x)" | 
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 250 | fix x | 
| 28856 
5e009a80fe6d
Pure syntax: more coherent treatment of aprop, permanent TERM and &&&;
 wenzelm parents: 
28699diff
changeset | 251 | show "PROP A x &&& PROP B x" | 
| 19121 | 252 | proof - | 
| 26958 | 253 | show "PROP A x" by (rule conj [THEN conjunctionD1, rule_format]) | 
| 254 | show "PROP B x" by (rule conj [THEN conjunctionD2, rule_format]) | |
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 255 | qed | 
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 256 | qed | 
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 257 | |
| 19121 | 258 | lemma imp_conjunction: | 
| 58612 | 259 | "(PROP A \<Longrightarrow> PROP B &&& PROP C) \<equiv> ((PROP A \<Longrightarrow> PROP B) &&& (PROP A \<Longrightarrow> PROP C))" | 
| 18836 | 260 | proof | 
| 58612 | 261 | assume conj: "PROP A \<Longrightarrow> PROP B &&& PROP C" | 
| 262 | show "(PROP A \<Longrightarrow> PROP B) &&& (PROP A \<Longrightarrow> PROP C)" | |
| 19121 | 263 | proof - | 
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 264 | assume "PROP A" | 
| 58611 | 265 | from conj [OF \<open>PROP A\<close>] show "PROP B" by (rule conjunctionD1) | 
| 266 | from conj [OF \<open>PROP A\<close>] show "PROP C" by (rule conjunctionD2) | |
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 267 | qed | 
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 268 | next | 
| 58612 | 269 | assume conj: "(PROP A \<Longrightarrow> PROP B) &&& (PROP A \<Longrightarrow> PROP C)" | 
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 270 | assume "PROP A" | 
| 28856 
5e009a80fe6d
Pure syntax: more coherent treatment of aprop, permanent TERM and &&&;
 wenzelm parents: 
28699diff
changeset | 271 | show "PROP B &&& PROP C" | 
| 19121 | 272 | proof - | 
| 58611 | 273 | from \<open>PROP A\<close> show "PROP B" by (rule conj [THEN conjunctionD1]) | 
| 274 | from \<open>PROP A\<close> show "PROP C" by (rule conj [THEN conjunctionD2]) | |
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 275 | qed | 
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 276 | qed | 
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 277 | |
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 278 | lemma conjunction_imp: | 
| 58612 | 279 | "(PROP A &&& PROP B \<Longrightarrow> PROP C) \<equiv> (PROP A \<Longrightarrow> PROP B \<Longrightarrow> PROP C)" | 
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 280 | proof | 
| 58612 | 281 | assume r: "PROP A &&& PROP B \<Longrightarrow> PROP C" | 
| 22933 | 282 | assume ab: "PROP A" "PROP B" | 
| 283 | show "PROP C" | |
| 284 | proof (rule r) | |
| 28856 
5e009a80fe6d
Pure syntax: more coherent treatment of aprop, permanent TERM and &&&;
 wenzelm parents: 
28699diff
changeset | 285 | from ab show "PROP A &&& PROP B" . | 
| 22933 | 286 | qed | 
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 287 | next | 
| 58612 | 288 | assume r: "PROP A \<Longrightarrow> PROP B \<Longrightarrow> PROP C" | 
| 28856 
5e009a80fe6d
Pure syntax: more coherent treatment of aprop, permanent TERM and &&&;
 wenzelm parents: 
28699diff
changeset | 289 | assume conj: "PROP A &&& PROP B" | 
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 290 | show "PROP C" | 
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 291 | proof (rule r) | 
| 19121 | 292 | from conj show "PROP A" by (rule conjunctionD1) | 
| 293 | from conj show "PROP B" by (rule conjunctionD2) | |
| 18466 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 294 | qed | 
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 295 | qed | 
| 
389a6f9c31f4
added locale meta_conjunction_syntax and various conjunction rules;
 wenzelm parents: 
18019diff
changeset | 296 | |
| 48638 | 297 | end | 
| 298 |