updated to new Isabelle
authorChristian Urban <urbanc@in.tum.de>
Sun, 18 Oct 2009 21:22:44 +0200 (2009-10-18)
changeset 351 f118240ab44a
parent 350 364fffa80794
child 352 9f12e53eb121
updated to new Isabelle
ProgTutorial/FirstSteps.thy
ProgTutorial/General.thy
ProgTutorial/Solutions.thy
ProgTutorial/Tactical.thy
ProgTutorial/output_tutorial.ML
progtutorial.pdf
--- a/ProgTutorial/FirstSteps.thy	Sun Oct 18 08:44:39 2009 +0200
+++ b/ProgTutorial/FirstSteps.thy	Sun Oct 18 21:22:44 2009 +0200
@@ -822,8 +822,8 @@
   @{ML_file "Pure/General/binding.ML"}.
   \end{readmore}
 
-  \footnote{\bf FIXME give a better example why bindings are important; maybe
-  give a pointer to \isacommand{local\_setup}; if not, then explain
+  \footnote{\bf FIXME give a better example why bindings are important}
+  \footnote{\bf FIXME give a pointer to \isacommand{local\_setup}; if not, then explain
   why @{ML snd} is needed.}
   \footnote{\bf FIXME: There should probably a separate section on binding, long-names
   and sign.}
--- a/ProgTutorial/General.thy	Sun Oct 18 08:44:39 2009 +0200
+++ b/ProgTutorial/General.thy	Sun Oct 18 21:22:44 2009 +0200
@@ -16,7 +16,8 @@
 text {*
   Isabelle is build around a few central ideas. One central idea is the
   LCF-approach to theorem proving where there is a small trusted core and
-  everything else is build on top of this trusted core. The fundamental data
+  everything else is build on top of this trusted core 
+  \cite{GordonMilnerWadsworth79}. The fundamental data
   structures involved in this core are certified terms and certified types, 
   as well as theorems.
 *}
@@ -720,7 +721,8 @@
   "Thm.capply @{cterm \"P::nat \<Rightarrow> bool\"} @{cterm \"3::nat\"}"
   "P 3"}
 
-  Similarly @{ML_ind list_comb in Drule} applies a list of @{ML_type cterm}s.
+  Similarly the function @{ML_ind list_comb in Drule} from the structure @{ML_struct Drule}
+  applies a list of @{ML_type cterm}s.
 
   @{ML_response_fake [display,gray]
   "let
@@ -743,8 +745,7 @@
 text {*
   Just like @{ML_type cterm}s, theorems are abstract objects of type @{ML_type thm} 
   that can only be built by going through interfaces. As a consequence, every proof 
-  in Isabelle is correct by construction. This follows the tradition of the LCF approach
-  \cite{GordonMilnerWadsworth79}.
+  in Isabelle is correct by construction. This follows the tradition of the LCF approach.
 
 
   To see theorems in ``action'', let us give a proof on the ML-level for the following 
@@ -752,9 +753,9 @@
 *}
 
   lemma 
-   assumes assm\<^isub>1: "\<And>(x::nat). P x \<Longrightarrow> Q x" 
-   and     assm\<^isub>2: "P t"
-   shows "Q t" (*<*)oops(*>*) 
+    assumes assm\<^isub>1: "\<And>(x::nat). P x \<Longrightarrow> Q x" 
+    and     assm\<^isub>2: "P t"
+    shows "Q t"(*<*)oops(*>*) 
 
 text {*
   The corresponding ML-code is as follows:
@@ -803,7 +804,8 @@
   While we obtained a theorem as result, this theorem is not
   yet stored in Isabelle's theorem database. Consequently, it cannot be 
   referenced on the user level. One way to store it in the theorem database is
-  by using the function @{ML_ind note in LocalTheory}.
+  by using the function @{ML_ind note in LocalTheory}.\footnote{\bf FIXME: make sure a pointer
+  to the section about local-setup is given eralier.}
 *}
 
 local_setup %gray {*
@@ -814,12 +816,12 @@
   The first argument @{ML_ind theoremK in Thm} is a kind indicator, which
   classifies the theorem. There are several such kind indicators: for a
   theorem arising from a definition we should use @{ML_ind definitionK in
-  Thm}, for an axiom @{ML_ind axiomK in Thm}, for ``normal'' theorems the
+  Thm}, for an axiom @{ML_ind axiomK in Thm}, and for ``normal'' theorems the
   kinds @{ML_ind theoremK in Thm} or @{ML_ind lemmaK in Thm}.  The second
   argument of @{ML note in LocalTheory} is the name under which we store the
-  theorem or theorems. The third argument can contain a list of (theorem)
-  attributes. We will explain them in detail in
-  Section~\ref{sec:attributes}. Below we just use one such attribute in order add
+  theorem or theorems. The third argument can contain a list of theorem
+  attributes, which we will explain in detail in Section~\ref{sec:attributes}. 
+  Below we just use one such attribute in order add
   the theorem to the simpset:
 *}
 
@@ -830,7 +832,7 @@
 
 text {*
   Note that we have to use another name under which the theorem is stored,
-  since Isabelle does not allow us to store another theorem under the same
+  since Isabelle does not allow us to store two theorems under the same
   name. The attribute needs to be wrapped inside the function @{ML_ind
   internal in Attrib}. If we use the function @{ML get_thm_names_from_ss} from
   the previous chapter, we can check whether the theorem has actually been
@@ -855,16 +857,17 @@
    @{text ">"}~@{prop "\<lbrakk>\<And>x. P x \<Longrightarrow> Q x; P t\<rbrakk> \<Longrightarrow> Q t"}
   \end{isabelle}
 
-  or with the @{text "@{thm \<dots>}"}-antiquotation on the ML-level. As can be seen
+  or with the @{text "@{thm \<dots>}"}-antiquotation on the ML-level. As can be seen,
   the theorem does not have any meta-variables that would be present if we proved
-  this theorem on the user-level. We will see later on that usually we have to 
+  this theorem on the user-level. We will see later on that we have to 
   construct meta-variables in theorems explicitly.
 
   \footnote{\bf FIXME say something about @{ML_ind add_thms_dynamic in PureThy}}
 *}
 
 text {*
-  There is a multitude of functions that manage or manipulate theorems. For example 
+  There is a multitude of functions that manage or manipulate theorems in the 
+  structures @{ML_struct Thm} and @{ML_struct Drule}. For example 
   we can test theorems for alpha equality. Suppose you proved the following three 
   theorems.
 *}
--- a/ProgTutorial/Solutions.thy	Sun Oct 18 08:44:39 2009 +0200
+++ b/ProgTutorial/Solutions.thy	Sun Oct 18 21:22:44 2009 +0200
@@ -272,7 +272,7 @@
   simplified. We have to be careful to set up the goal so that
   other parts of the simplifier do not interfere. For this we construct an
   unprovable goal which, after simplification, we are going to ``prove'' with
-  the help of ``\isacommand{sorry}'', that is the method @{ML SkipProof.cheat_tac}
+  the help of ``\isacommand{sorry}'', that is the method @{ML Skip_Proof.cheat_tac}
 
   For constructing test cases, we first define a function that returns a 
   complete binary tree whose leaves are numbers and the nodes are 
@@ -309,12 +309,12 @@
   Note that the goal needs to be wrapped in a @{term "Trueprop"}. Next we define
   two tactics, @{text "c_tac"} and @{text "s_tac"}, for the conversion and simproc,
   respectively. The idea is to first apply the conversion (respectively simproc) and 
-  then prove the remaining goal using @{ML "cheat_tac" in SkipProof}.
+  then prove the remaining goal using @{ML "cheat_tac" in Skip_Proof}.
 *}
 
 ML{*local
   fun mk_tac tac = 
-        timing_wrapper (EVERY1 [tac, K (SkipProof.cheat_tac @{theory})])
+        timing_wrapper (EVERY1 [tac, K (Skip_Proof.cheat_tac @{theory})])
 in
 val c_tac = mk_tac (add_tac @{context}) 
 val s_tac = mk_tac (simp_tac (HOL_basic_ss addsimprocs [@{simproc add_sp}]))
--- a/ProgTutorial/Tactical.thy	Sun Oct 18 08:44:39 2009 +0200
+++ b/ProgTutorial/Tactical.thy	Sun Oct 18 21:22:44 2009 +0200
@@ -363,13 +363,13 @@
 
 text {*
   A simple tactic for easy discharge of any proof obligations is 
-  @{ML_ind  cheat_tac in SkipProof}. This tactic corresponds to
+  @{ML_ind  cheat_tac in Skip_Proof}. This tactic corresponds to
   the Isabelle command \isacommand{sorry} and is sometimes useful  
   during the development of tactics.
 *}
 
 lemma shows "False" and "Goldbach_conjecture"  
-apply(tactic {* SkipProof.cheat_tac @{theory} *})
+apply(tactic {* Skip_Proof.cheat_tac @{theory} *})
 txt{*\begin{minipage}{\textwidth}
      @{subgoals [display]}
      \end{minipage}*}
--- a/ProgTutorial/output_tutorial.ML	Sun Oct 18 08:44:39 2009 +0200
+++ b/ProgTutorial/output_tutorial.ML	Sun Oct 18 21:22:44 2009 +0200
@@ -79,7 +79,7 @@
   | boolean s = error ("Bad boolean value: " ^ quote s);
 
 val _ = ThyOutput.add_options
- [("gray", Library.setmp gray o boolean),
-  ("linenos", Library.setmp linenos o boolean)]
+ [("gray", Library.setmp_CRITICAL gray o boolean),
+  ("linenos", Library.setmp_CRITICAL linenos o boolean)]
 
 end
\ No newline at end of file
Binary file progtutorial.pdf has changed