--- a/ProgTutorial/Advanced.thy Thu Nov 03 17:53:36 2011 +0000
+++ b/ProgTutorial/Advanced.thy Fri Nov 04 09:29:50 2011 +0000
@@ -73,26 +73,26 @@
section {* Setups (TBD) *}
text {*
- @{ML Sign.declare_const}
+ In the previous section we used \isacommand{setup}, for example, in
+ order to make a theorem attribute known to Isabelle. What happens
+ behind the scenes is that \isacommand{setup} expects a function of
+ type @{ML_type "theory -> theory"}: the input theory is the current
+ theory and the output the theory where the theory attribute has been
+ stored.
- In the previous section we used \isacommand{setup} in order to make
- a theorem attribute known to Isabelle. What happens behind the scenes
- is that \isacommand{setup} expects a function of type
- @{ML_type "theory -> theory"}: the input theory is the current theory and the
- output the theory where the theory attribute has been stored.
-
- This is a fundamental principle in Isabelle. A similar situation occurs
- for example with declaring constants. The function that declares a
- constant on the ML-level is @{ML_ind add_consts_i in Sign}.
- If you write\footnote{Recall that ML-code needs to be
+ This is a fundamental principle in Isabelle. A similar situation arises
+ with declaring constants. The function that declares a
+ constant on the ML-level is @{ML_ind declare_const in Sign}.
+ However, if you simply write\footnote{Recall that ML-code needs to be
enclosed in \isacommand{ML}~@{text "\<verbopen> \<dots> \<verbclose>"}.}
*}
-ML{*Sign.add_consts_i [(@{binding "BAR"}, @{typ "nat"}, NoSyn)] @{theory} *}
+ML{*Sign.declare_const @{context}
+ ((@{binding "BAR"}, @{typ "nat"}), NoSyn) @{theory} *}
text {*
- for declaring the constant @{text "BAR"} with type @{typ nat} and
- run the code, then you indeed obtain a theory as result. But if you
+ with the intention of declaring the constant @{text "BAR"} with type @{typ nat}
+ and run the code, then indeed you obtain a theory as result. But if you
query the constant on the Isabelle level using the command \isacommand{term}
\begin{isabelle}
@@ -100,13 +100,15 @@
@{text "> \"BAR\" :: \"'a\""}
\end{isabelle}
- you do not obtain a constant of type @{typ nat}, but a free variable (printed in
- blue) of polymorphic type. The problem is that the ML-expression above did
- not register the declaration with the current theory. This is what the command
- \isacommand{setup} is for. The constant is properly declared with
+ you can see that you do not obtain a constant of type @{typ nat}, but a free
+ variable (printed in blue) of polymorphic type. The problem is that the
+ ML-expression above did not ``register'' the declaration with the current theory.
+ This is what the command \isacommand{setup} is for. The constant is properly
+ declared with
*}
-setup %gray {* Sign.add_consts_i [(@{binding "BAR"}, @{typ "nat"}, NoSyn)] *}
+setup %gray {* Sign.declare_const @{context}
+ ((@{binding "BAR"}, @{typ "nat"}), NoSyn) #> snd *}
text {*
Now
@@ -116,7 +118,7 @@
@{text "> \"BAR\" :: \"nat\""}
\end{isabelle}
- returns a (black) constant with the type @{typ nat}.
+ returns a (black) constant with the type @{typ nat}, as expected.
A similar command is \isacommand{local\_setup}, which expects a function
of type @{ML_type "local_theory -> local_theory"}. Later on we will also