doc-src/IsarImplementation/Thy/document/Local_Theory.tex
author immler@in.tum.de
Sat, 14 Mar 2009 15:45:45 +0100
changeset 30535 db8b10fd51a4
parent 30121 5c7bcb296600
child 33672 8bde36ec8eb1
permissions -rw-r--r--
show certain errors to the user
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
18537
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
     1
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
     2
\begin{isabellebody}%
29756
df70c0291579 updated generated files;
wenzelm
parents: 29755
diff changeset
     3
\def\isabellecontext{Local{\isacharunderscore}Theory}%
18537
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
     4
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
     5
\isadelimtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
     6
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
     7
\endisadelimtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
     8
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
     9
\isatagtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    10
\isacommand{theory}\isamarkupfalse%
29756
df70c0291579 updated generated files;
wenzelm
parents: 29755
diff changeset
    11
\ Local{\isacharunderscore}Theory\isanewline
df70c0291579 updated generated files;
wenzelm
parents: 29755
diff changeset
    12
\isakeyword{imports}\ Base\isanewline
df70c0291579 updated generated files;
wenzelm
parents: 29755
diff changeset
    13
\isakeyword{begin}%
18537
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    14
\endisatagtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    15
{\isafoldtheory}%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    16
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    17
\isadelimtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    18
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    19
\endisadelimtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    20
%
29762
e5324b8b4df5 updated genereted files;
wenzelm
parents: 29756
diff changeset
    21
\isamarkupchapter{Local theory specifications%
18537
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    22
}
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    23
\isamarkuptrue%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    24
%
29767
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    25
\begin{isamarkuptext}%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    26
A \emph{local theory} combines aspects of both theory and proof
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    27
  context (cf.\ \secref{sec:context}), such that definitional
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    28
  specifications may be given relatively to parameters and
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    29
  assumptions.  A local theory is represented as a regular proof
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    30
  context, augmented by administrative data about the \emph{target
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    31
  context}.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    32
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    33
  The target is usually derived from the background theory by adding
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    34
  local \isa{{\isasymFIX}} and \isa{{\isasymASSUME}} elements, plus
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    35
  suitable modifications of non-logical context data (e.g.\ a special
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    36
  type-checking discipline).  Once initialized, the target is ready to
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    37
  absorb definitional primitives: \isa{{\isasymDEFINE}} for terms and
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    38
  \isa{{\isasymNOTE}} for theorems.  Such definitions may get
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    39
  transformed in a target-specific way, but the programming interface
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    40
  hides such details.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    41
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    42
  Isabelle/Pure provides target mechanisms for locales, type-classes,
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    43
  type-class instantiations, and general overloading.  In principle,
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    44
  users can implement new targets as well, but this rather arcane
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    45
  discipline is beyond the scope of this manual.  In contrast,
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    46
  implementing derived definitional packages to be used within a local
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    47
  theory context is quite easy: the interfaces are even simpler and
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    48
  more abstract than the underlying primitives for raw theories.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    49
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    50
  Many definitional packages for local theories are available in
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    51
  Isabelle.  Although a few old packages only work for global
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    52
  theories, the local theory interface is already the standard way of
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    53
  implementing definitional packages in Isabelle.%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    54
\end{isamarkuptext}%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    55
\isamarkuptrue%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    56
%
29762
e5324b8b4df5 updated genereted files;
wenzelm
parents: 29756
diff changeset
    57
\isamarkupsection{Definitional elements%
18537
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    58
}
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    59
\isamarkuptrue%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    60
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
    61
\begin{isamarkuptext}%
29767
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    62
There are separate elements \isa{{\isasymDEFINE}\ c\ {\isasymequiv}\ t} for terms, and
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    63
  \isa{{\isasymNOTE}\ b\ {\isacharequal}\ thm} for theorems.  Types are treated
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    64
  implicitly, according to Hindley-Milner discipline (cf.\
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    65
  \secref{sec:variables}).  These definitional primitives essentially
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    66
  act like \isa{let}-bindings within a local context that may
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    67
  already contain earlier \isa{let}-bindings and some initial
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    68
  \isa{{\isasymlambda}}-bindings.  Thus we gain \emph{dependent definitions}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    69
  that are relative to an initial axiomatic context.  The following
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    70
  diagram illustrates this idea of axiomatic elements versus
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    71
  definitional elements:
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    72
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    73
  \begin{center}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    74
  \begin{tabular}{|l|l|l|}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    75
  \hline
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    76
  & \isa{{\isasymlambda}}-binding & \isa{let}-binding \\
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    77
  \hline
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    78
  types & fixed \isa{{\isasymalpha}} & arbitrary \isa{{\isasymbeta}} \\
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    79
  terms & \isa{{\isasymFIX}\ x\ {\isacharcolon}{\isacharcolon}\ {\isasymtau}} & \isa{{\isasymDEFINE}\ c\ {\isasymequiv}\ t} \\
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    80
  theorems & \isa{{\isasymASSUME}\ a{\isacharcolon}\ A} & \isa{{\isasymNOTE}\ b\ {\isacharequal}\ \isactrlBG B\isactrlEN } \\
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    81
  \hline
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    82
  \end{tabular}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    83
  \end{center}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    84
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    85
  A user package merely needs to produce suitable \isa{{\isasymDEFINE}}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    86
  and \isa{{\isasymNOTE}} elements according to the application.  For
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    87
  example, a package for inductive definitions might first \isa{{\isasymDEFINE}} a certain predicate as some fixed-point construction,
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    88
  then \isa{{\isasymNOTE}} a proven result about monotonicity of the
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    89
  functor involved here, and then produce further derived concepts via
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    90
  additional \isa{{\isasymDEFINE}} and \isa{{\isasymNOTE}} elements.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    91
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    92
  The cumulative sequence of \isa{{\isasymDEFINE}} and \isa{{\isasymNOTE}}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    93
  produced at package runtime is managed by the local theory
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    94
  infrastructure by means of an \emph{auxiliary context}.  Thus the
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    95
  system holds up the impression of working within a fully abstract
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    96
  situation with hypothetical entities: \isa{{\isasymDEFINE}\ c\ {\isasymequiv}\ t}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    97
  always results in a literal fact \isa{\isactrlBG c\ {\isasymequiv}\ t\isactrlEN }, where
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    98
  \isa{c} is a fixed variable \isa{c}.  The details about
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
    99
  global constants, name spaces etc. are handled internally.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   100
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   101
  So the general structure of a local theory is a sandwich of three
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   102
  layers:
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   103
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   104
  \begin{center}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   105
  \framebox{\quad auxiliary context \quad\framebox{\quad target context \quad\framebox{\quad background theory\quad}}}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   106
  \end{center}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   107
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   108
  \noindent When a definitional package is finished, the auxiliary
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   109
  context is reset to the target context.  The target now holds
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   110
  definitions for terms and theorems that stem from the hypothetical
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   111
  \isa{{\isasymDEFINE}} and \isa{{\isasymNOTE}} elements, transformed by
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   112
  the particular target policy (see
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   113
  \cite[\S4--5]{Haftmann-Wenzel:2009} for details).%
18537
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   114
\end{isamarkuptext}%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   115
\isamarkuptrue%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   116
%
29767
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   117
\isadelimmlref
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   118
%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   119
\endisadelimmlref
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   120
%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   121
\isatagmlref
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   122
%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   123
\begin{isamarkuptext}%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   124
\begin{mldecls}
30121
5c7bcb296600 updated generated files;
wenzelm
parents: 29767
diff changeset
   125
  \indexdef{}{ML type}{local\_theory}\verb|type local_theory = Proof.context| \\
5c7bcb296600 updated generated files;
wenzelm
parents: 29767
diff changeset
   126
  \indexdef{}{ML}{TheoryTarget.init}\verb|TheoryTarget.init: string option -> theory -> local_theory| \\[1ex]
5c7bcb296600 updated generated files;
wenzelm
parents: 29767
diff changeset
   127
  \indexdef{}{ML}{LocalTheory.define}\verb|LocalTheory.define: string ->|\isasep\isanewline%
29767
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   128
\verb|    (binding * mixfix) * (Attrib.binding * term) -> local_theory ->|\isasep\isanewline%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   129
\verb|    (term * (string * thm)) * local_theory| \\
30121
5c7bcb296600 updated generated files;
wenzelm
parents: 29767
diff changeset
   130
  \indexdef{}{ML}{LocalTheory.note}\verb|LocalTheory.note: string ->|\isasep\isanewline%
29767
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   131
\verb|    Attrib.binding * thm list -> local_theory ->|\isasep\isanewline%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   132
\verb|    (string * thm list) * local_theory| \\
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   133
  \end{mldecls}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   134
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   135
  \begin{description}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   136
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   137
  \item \verb|local_theory| represents local theories.  Although
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   138
  this is merely an alias for \verb|Proof.context|, it is
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   139
  semantically a subtype of the same: a \verb|local_theory| holds
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   140
  target information as special context data.  Subtyping means that
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   141
  any value \isa{lthy{\isacharcolon}}~\verb|local_theory| can be also used
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   142
  with operations on expecting a regular \isa{ctxt{\isacharcolon}}~\verb|Proof.context|.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   143
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   144
  \item \verb|TheoryTarget.init|~\isa{NONE\ thy} initializes a
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   145
  trivial local theory from the given background theory.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   146
  Alternatively, \isa{SOME\ name} may be given to initialize a
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   147
  \hyperlink{command.locale}{\mbox{\isa{\isacommand{locale}}}} or \hyperlink{command.class}{\mbox{\isa{\isacommand{class}}}} context (a fully-qualified
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   148
  internal name is expected here).  This is useful for experimentation
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   149
  --- normally the Isar toplevel already takes care to initialize the
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   150
  local theory context.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   151
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   152
  \item \verb|LocalTheory.define|~\isa{kind\ {\isacharparenleft}{\isacharparenleft}b{\isacharcomma}\ mx{\isacharparenright}{\isacharcomma}\ {\isacharparenleft}a{\isacharcomma}\ rhs{\isacharparenright}{\isacharparenright}\ lthy} defines a local entity according to the specification that is
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   153
  given relatively to the current \isa{lthy} context.  In
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   154
  particular the term of the RHS may refer to earlier local entities
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   155
  from the auxiliary context, or hypothetical parameters from the
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   156
  target context.  The result is the newly defined term (which is
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   157
  always a fixed variable with exactly the same name as specified for
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   158
  the LHS), together with an equational theorem that states the
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   159
  definition as a hypothetical fact.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   160
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   161
  Unless an explicit name binding is given for the RHS, the resulting
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   162
  fact will be called \isa{b{\isacharunderscore}def}.  Any given attributes are
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   163
  applied to that same fact --- immediately in the auxiliary context
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   164
  \emph{and} in any transformed versions stemming from target-specific
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   165
  policies or any later interpretations of results from the target
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   166
  context (think of \hyperlink{command.locale}{\mbox{\isa{\isacommand{locale}}}} and \hyperlink{command.interpretation}{\mbox{\isa{\isacommand{interpretation}}}},
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   167
  for example).  This means that attributes should be usually plain
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   168
  declarations such as \hyperlink{attribute.simp}{\mbox{\isa{simp}}}, while non-trivial rules like
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   169
  \hyperlink{attribute.simplified}{\mbox{\isa{simplified}}} are better avoided.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   170
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   171
  The \isa{kind} determines the theorem kind tag of the resulting
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   172
  fact.  Typical examples are \verb|Thm.definitionK|, \verb|Thm.theoremK|, or \verb|Thm.internalK|.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   173
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   174
  \item \verb|LocalTheory.note|~\isa{kind\ {\isacharparenleft}a{\isacharcomma}\ ths{\isacharparenright}\ lthy} is
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   175
  analogous to \verb|LocalTheory.define|, but defines facts instead of
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   176
  terms.  There is also a slightly more general variant \verb|LocalTheory.notes| that defines several facts (with attribute
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   177
  expressions) simultaneously.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   178
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   179
  This is essentially the internal version of the \hyperlink{command.lemmas}{\mbox{\isa{\isacommand{lemmas}}}}
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   180
  command, or \hyperlink{command.declare}{\mbox{\isa{\isacommand{declare}}}} if an empty name binding is given.
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   181
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   182
  \end{description}%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   183
\end{isamarkuptext}%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   184
\isamarkuptrue%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   185
%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   186
\endisatagmlref
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   187
{\isafoldmlref}%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   188
%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   189
\isadelimmlref
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   190
%
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   191
\endisadelimmlref
07bf5dd48c9f updated generated files;
wenzelm
parents: 29762
diff changeset
   192
%
29762
e5324b8b4df5 updated genereted files;
wenzelm
parents: 29756
diff changeset
   193
\isamarkupsection{Morphisms and declarations%
18537
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   194
}
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   195
\isamarkuptrue%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   196
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   197
\begin{isamarkuptext}%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   198
FIXME%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   199
\end{isamarkuptext}%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   200
\isamarkuptrue%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   201
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   202
\isadelimtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   203
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   204
\endisadelimtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   205
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   206
\isatagtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   207
\isacommand{end}\isamarkupfalse%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   208
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   209
\endisatagtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   210
{\isafoldtheory}%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   211
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   212
\isadelimtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   213
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   214
\endisadelimtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   215
\isanewline
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   216
\end{isabellebody}%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   217
%%% Local Variables:
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   218
%%% mode: latex
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   219
%%% TeX-master: "root"
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
   220
%%% End: