CookBook/NamedThms.thy
author Christian Urban <urbanc@in.tum.de>
Fri, 05 Sep 2008 09:47:51 +0200
changeset 2 978a3c2ed7ce
parent 0 02503850a8cf
child 12 2f1736cb8f26
permissions -rw-r--r--
split the document into smaller pieces; made it standalone by copying antiquote_setup.ML into the repository added cover page


theory NamedThms
imports Main
begin


chapter {* Recipes *}

text_raw {* 

\section*{Accumulate a list of theorems under a name} 
*}

text {*
  \paragraph{Problem:} Your tool @{text foo} works with special rules, called @{text foo}-rules.

  Users should be able to declare @{text foo}-rules in the theory,
  which are then used by some method.

  \paragraph{Solution:}

  *}
ML {*
  structure FooRules = NamedThmsFun(
    val name = "foo" 
    val description = "Rules for foo"
  );
*}

setup FooRules.setup

text {*
  This declares a context data slot where the theorems are stored,
  an attribute @{attribute foo} (with the usual @{text add} and @{text del} options
  to declare new rules, and the internal ML interface to retrieve and 
  modify the facts.

  Furthermore, the facts are made available under the dynamic fact name
  @{text foo}:
*}

lemma rule1[foo]: "A" sorry
lemma rule2[foo]: "B" sorry

declare rule1[foo del]

thm foo

ML {* 
  FooRules.get @{context};
*}


text {* 
  \begin{readmore}
  XXX

  \end{readmore}
 *}


end