--- a/CookBook/FirstSteps.thy Tue Feb 24 14:35:07 2009 +0100
+++ b/CookBook/FirstSteps.thy Tue Feb 24 13:57:14 2009 +0000
@@ -890,10 +890,10 @@
text {*
Theorem attributes are @{text "[simp]"}, @{text "[OF \<dots>]"}, @{text
- "[symmetric]"} and so on. Such attributes are \emph{neither} tags \emph{or} flags
- annotated to theorems, but functions that do further processing once the
- theorems are proven. In particular, it is not possible to find out
- what are all theorems that have an given attribute in common, unless of course
+ "[symmetric]"} and so on. Such attributes are \emph{neither} tags \emph{nor} flags
+ annotated to theorems, but functions that do further processing once a
+ theorem is proven. In particular, it is not possible to find out
+ what are all theorems that have a given attribute in common, unless of course
the function behind the attribute stores the theorems in a retrivable
datastructure. This can be easily done by the recipe described in
\ref{rec:named}.
@@ -907,12 +907,23 @@
HOL.elim: declaration of Classical elimination rule
\<dots>"}
+ To explain how to write your own attribute, let us start with an extremely simple
+ version of the attribute @{text "[symmetric]"}. The purpose of this attribute is
+ to produce the ``symmetric'' version of an equation. The main function behind
+ this attribute is
*}
ML{*val my_symmetric = Thm.rule_attribute (fn _ => fn thm => thm RS @{thm sym})*}
text {*
- the setup
+ where the function @{ML "Thm.rule_attribute"} expects a function taking a
+ context (we ignore it in the code above) and a theorem (@{text thm}) and
+ returns another theorem (namely @{text thm} resolved with the rule
+ @{thm sym[no_vars]}). The function @{ML "Thm.rule_attribute"} then returns
+ an attribute (of type @{ML_type "attribute"}).
+
+ Before we can use the attribute, we need to set it up. This can be done
+ using the function @{ML Attrib.add_attributes} as follows.
*}
setup {*
@@ -920,16 +931,29 @@
[("my_sym", Attrib.no_args my_symmetric, "applying the sym rule")]
*}
-lemma test: "1 = Suc 0" by simp
+text {*
+ The attribute does not expect any further arguments (like @{text "[OF \<dots>]"} that
+ can take a list of theorems as argument). Therefore we use the function
+ @{ML Attrib.no_args}. Later on we will also consider attributes taking further
+ arguments. An example for the attribute @{text "[my_sym]"} is the proof
+*}
+
+lemma test[my_sym]: "2 = Suc (Suc 0)" by simp
text {*
- @{thm test[my_sym]}
+ which stores the theorem @{thm test} under the name @{thm [source] test}. We
+ can also use the attribute when referring to this theorem.
+
+ \begin{isabelle}
+ \isacommand{thm}~@{text "test[my_sym]"}\\
+ @{text "> "}~@{thm test[my_sym]}
+ \end{isabelle}
+
*}
text {*
What are:
-@{text "rule_attribute"}
@{text "declaration_attribute"}