diff -r 8c31b729a5df -r 58277de8493c CookBook/FirstSteps.thy --- 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"}