doc-src/IsarImplementation/Thy/document/ML.tex
author wenzelm
Sat, 25 Feb 2012 13:17:38 +0100
changeset 46668 9034b44844bd
parent 46262 912b42e64fde
child 47186 9756bcb88829
permissions -rw-r--r--
tuned comments;
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}%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
     3
\def\isabellecontext{ML}%
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%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
    11
\ {\isaliteral{22}{\isachardoublequoteopen}}ML{\isaliteral{22}{\isachardoublequoteclose}}\isanewline
29756
df70c0291579 updated generated files;
wenzelm
parents: 29647
diff changeset
    12
\isakeyword{imports}\ Base\isanewline
df70c0291579 updated generated files;
wenzelm
parents: 29647
diff changeset
    13
\isakeyword{begin}%
18543
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
    14
\endisatagtheory
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
    15
{\isafoldtheory}%
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
    16
%
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
    17
\isadelimtheory
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
    18
%
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
    19
\endisadelimtheory
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
    20
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    21
\isamarkupchapter{Isabelle/ML%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    22
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    23
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    24
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    25
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    26
Isabelle/ML is best understood as a certain culture based on
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    27
  Standard ML.  Thus it is not a new programming language, but a
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    28
  certain way to use SML at an advanced level within the Isabelle
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    29
  environment.  This covers a variety of aspects that are geared
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    30
  towards an efficient and robust platform for applications of formal
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    31
  logic with fully foundational proof construction --- according to
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    32
  the well-known \emph{LCF principle}.  There is specific
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    33
  infrastructure with library modules to address the needs of this
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    34
  difficult task.  For example, the raw parallel programming model of
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    35
  Poly/ML is presented as considerably more abstract concept of
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    36
  \emph{future values}, which is then used to augment the inference
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    37
  kernel, proof interpreter, and theory loader accordingly.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    38
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    39
  The main aspects of Isabelle/ML are introduced below.  These
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    40
  first-hand explanations should help to understand how proper
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    41
  Isabelle/ML is to be read and written, and to get access to the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    42
  wealth of experience that is expressed in the source text and its
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    43
  history of changes.\footnote{See
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    44
  \url{http://isabelle.in.tum.de/repos/isabelle} for the full
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    45
  Mercurial history.  There are symbolic tags to refer to official
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    46
  Isabelle releases, as opposed to arbitrary \emph{tip} versions that
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    47
  merely reflect snapshots that are never really up-to-date.}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    48
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    49
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    50
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    51
\isamarkupsection{Style and orthography%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    52
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    53
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    54
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    55
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    56
The sources of Isabelle/Isar are optimized for
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    57
  \emph{readability} and \emph{maintainability}.  The main purpose is
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    58
  to tell an informed reader what is really going on and how things
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    59
  really work.  This is a non-trivial aim, but it is supported by a
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    60
  certain style of writing Isabelle/ML that has emerged from long
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    61
  years of system development.\footnote{See also the interesting style
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    62
  guide for OCaml
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    63
  \url{http://caml.inria.fr/resources/doc/guides/guidelines.en.html}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    64
  which shares many of our means and ends.}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    65
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    66
  The main principle behind any coding style is \emph{consistency}.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    67
  For a single author of a small program this merely means ``choose
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    68
  your style and stick to it''.  A complex project like Isabelle, with
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    69
  long years of development and different contributors, requires more
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    70
  standardization.  A coding style that is changed every few years or
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    71
  with every new contributor is no style at all, because consistency
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    72
  is quickly lost.  Global consistency is hard to achieve, though.
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    73
  Nonetheless, one should always strive at least for local consistency
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    74
  of modules and sub-systems, without deviating from some general
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    75
  principles how to write Isabelle/ML.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    76
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    77
  In a sense, good coding style is like an \emph{orthography} for the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    78
  sources: it helps to read quickly over the text and see through the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    79
  main points, without getting distracted by accidental presentation
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    80
  of free-style code.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    81
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    82
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    83
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    84
\isamarkupsubsection{Header and sectioning%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    85
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    86
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    87
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    88
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    89
Isabelle source files have a certain standardized header
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    90
  format (with precise spacing) that follows ancient traditions
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    91
  reaching back to the earliest versions of the system by Larry
40802
3cd23f676c5b updated generated files;
wenzelm
parents: 40508
diff changeset
    92
  Paulson.  See \verb|~~/src/Pure/thm.ML|, for example.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    93
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    94
  The header includes at least \verb|Title| and \verb|Author| entries, followed by a prose description of the purpose of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    95
  the module.  The latter can range from a single line to several
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    96
  paragraphs of explanations.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    97
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
    98
  The rest of the file is divided into sections, subsections,
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
    99
  subsubsections, paragraphs etc.\ using a simple layout via ML
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   100
  comments as follows.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   101
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   102
\begin{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   103
(*** section ***)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   104
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   105
(** subsection **)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   106
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   107
(* subsubsection *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   108
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   109
(*short paragraph*)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   110
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   111
(*
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   112
  long paragraph,
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   113
  with more text
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   114
*)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   115
\end{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   116
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   117
  As in regular typography, there is some extra space \emph{before}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   118
  section headings that are adjacent to plain text (not other headings
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   119
  as in the example above).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   120
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   121
  \medskip The precise wording of the prose text given in these
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   122
  headings is chosen carefully to introduce the main theme of the
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   123
  subsequent formal ML text.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   124
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   125
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   126
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   127
\isamarkupsubsection{Naming conventions%
18543
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
   128
}
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
   129
\isamarkuptrue%
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
   130
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   131
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   132
Since ML is the primary medium to express the meaning of the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   133
  source text, naming of ML entities requires special care.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   134
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   135
  \paragraph{Notation.}  A name consists of 1--3 \emph{words} (rarely
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   136
  4, but not more) that are separated by underscore.  There are three
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   137
  variants concerning upper or lower case letters, which are used for
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   138
  certain ML categories as follows:
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   139
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   140
  \medskip
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   141
  \begin{tabular}{lll}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   142
  variant & example & ML categories \\\hline
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   143
  lower-case & \verb|foo_bar| & values, types, record fields \\
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   144
  capitalized & \verb|Foo_Bar| & datatype constructors, structures, functors \\
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   145
  upper-case & \verb|FOO_BAR| & special values, exception constructors, signatures \\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   146
  \end{tabular}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   147
  \medskip
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   148
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   149
  For historical reasons, many capitalized names omit underscores,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   150
  e.g.\ old-style \verb|FooBar| instead of \verb|Foo_Bar|.
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   151
  Genuine mixed-case names are \emph{not} used, bacause clear division
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   152
  of words is essential for readability.\footnote{Camel-case was
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   153
  invented to workaround the lack of underscore in some early
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   154
  non-ASCII character sets.  Later it became habitual in some language
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   155
  communities that are now strong in numbers.}
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   156
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   157
  A single (capital) character does not count as ``word'' in this
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   158
  respect: some Isabelle/ML names are suffixed by extra markers like
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   159
  this: \verb|foo_barT|.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   160
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   161
  Name variants are produced by adding 1--3 primes, e.g.\ \verb|foo'|, \verb|foo''|, or \verb|foo'''|, but not \verb|foo''''| or more.  Decimal digits scale better to larger numbers,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   162
  e.g.\ \verb|foo0|, \verb|foo1|, \verb|foo42|.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   163
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   164
  \paragraph{Scopes.}  Apart from very basic library modules, ML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   165
  structures are not ``opened'', but names are referenced with
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   166
  explicit qualification, as in \verb|Syntax.string_of_term| for
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   167
  example.  When devising names for structures and their components it
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   168
  is important aim at eye-catching compositions of both parts, because
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   169
  this is how they are seen in the sources and documentation.  For the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   170
  same reasons, aliases of well-known library functions should be
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   171
  avoided.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   172
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   173
  Local names of function abstraction or case/let bindings are
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   174
  typically shorter, sometimes using only rudiments of ``words'',
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   175
  while still avoiding cryptic shorthands.  An auxiliary function
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   176
  called \verb|helper|, \verb|aux|, or \verb|f| is
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   177
  considered bad style.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   178
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   179
  Example:
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   180
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   181
  \begin{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   182
  (* RIGHT *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   183
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   184
  fun print_foo ctxt foo =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   185
    let
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   186
      fun print t = ... Syntax.string_of_term ctxt t ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   187
    in ... end;
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   188
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   189
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   190
  (* RIGHT *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   191
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   192
  fun print_foo ctxt foo =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   193
    let
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   194
      val string_of_term = Syntax.string_of_term ctxt;
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   195
      fun print t = ... string_of_term t ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   196
    in ... end;
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   197
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   198
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   199
  (* WRONG *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   200
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   201
  val string_of_term = Syntax.string_of_term;
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   202
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   203
  fun print_foo ctxt foo =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   204
    let
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   205
      fun aux t = ... string_of_term ctxt t ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   206
    in ... end;
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   207
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   208
  \end{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   209
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   210
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   211
  \paragraph{Specific conventions.} Here are some specific name forms
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   212
  that occur frequently in the sources.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   213
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   214
  \begin{itemize}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   215
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   216
  \item A function that maps \verb|foo| to \verb|bar| is
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   217
  called \verb|foo_to_bar| or \verb|bar_of_foo| (never
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   218
  \verb|foo2bar|, \verb|bar_from_foo|, \verb|bar_for_foo|, or \verb|bar4foo|).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   219
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   220
  \item The name component \verb|legacy| means that the operation
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   221
  is about to be discontinued soon.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   222
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   223
  \item The name component \verb|old| means that this is historic
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   224
  material that might disappear at some later stage.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   225
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   226
  \item The name component \verb|global| means that this works
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   227
  with the background theory instead of the regular local context
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   228
  (\secref{sec:context}), sometimes for historical reasons, sometimes
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   229
  due a genuine lack of locality of the concept involved, sometimes as
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   230
  a fall-back for the lack of a proper context in the application
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   231
  code.  Whenever there is a non-global variant available, the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   232
  application should be migrated to use it with a proper local
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   233
  context.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   234
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   235
  \item Variables of the main context types of the Isabelle/Isar
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   236
  framework (\secref{sec:context} and \chref{ch:local-theory}) have
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   237
  firm naming conventions as follows:
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   238
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   239
  \begin{itemize}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   240
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   241
  \item theories are called \verb|thy|, rarely \verb|theory|
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   242
  (never \verb|thry|)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   243
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   244
  \item proof contexts are called \verb|ctxt|, rarely \verb|context| (never \verb|ctx|)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   245
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   246
  \item generic contexts are called \verb|context|, rarely
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   247
  \verb|ctxt|
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   248
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   249
  \item local theories are called \verb|lthy|, except for local
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   250
  theories that are treated as proof context (which is a semantic
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   251
  super-type)
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   252
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   253
  \end{itemize}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   254
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   255
  Variations with primed or decimal numbers are always possible, as
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   256
  well as sematic prefixes like \verb|foo_thy| or \verb|bar_ctxt|, but the base conventions above need to be preserved.
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   257
  This allows to visualize the their data flow via plain regular
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   258
  expressions in the editor.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   259
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   260
  \item The main logical entities (\secref{ch:logic}) have established
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   261
  naming convention as follows:
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   262
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   263
  \begin{itemize}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   264
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   265
  \item sorts are called \verb|S|
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   266
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   267
  \item types are called \verb|T|, \verb|U|, or \verb|ty| (never \verb|t|)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   268
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   269
  \item terms are called \verb|t|, \verb|u|, or \verb|tm| (never \verb|trm|)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   270
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   271
  \item certified types are called \verb|cT|, rarely \verb|T|, with variants as for types
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   272
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   273
  \item certified terms are called \verb|ct|, rarely \verb|t|, with variants as for terms
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   274
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   275
  \item theorems are called \verb|th|, or \verb|thm|
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   276
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   277
  \end{itemize}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   278
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   279
  Proper semantic names override these conventions completely.  For
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   280
  example, the left-hand side of an equation (as a term) can be called
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   281
  \verb|lhs| (not \verb|lhs_tm|).  Or a term that is known
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   282
  to be a variable can be called \verb|v| or \verb|x|.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   283
40310
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   284
  \item Tactics (\secref{sec:tactics}) are sufficiently important to
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   285
  have specific naming conventions.  The name of a basic tactic
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   286
  definition always has a \verb|_tac| suffix, the subgoal index
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   287
  (if applicable) is always called \verb|i|, and the goal state
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   288
  (if made explicit) is usually called \verb|st| instead of the
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   289
  somewhat misleading \verb|thm|.  Any other arguments are given
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   290
  before the latter two, and the general context is given first.
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   291
  Example:
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   292
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   293
  \begin{verbatim}
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   294
  fun my_tac ctxt arg1 arg2 i st = ...
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   295
  \end{verbatim}
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   296
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   297
  Note that the goal state \verb|st| above is rarely made
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   298
  explicit, if tactic combinators (tacticals) are used as usual.
a0698ec82e6e more on naming tactics;
wenzelm
parents: 40302
diff changeset
   299
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   300
  \end{itemize}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   301
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   302
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   303
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   304
\isamarkupsubsection{General source layout%
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
   305
}
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
   306
\isamarkuptrue%
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
   307
%
18543
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
   308
\begin{isamarkuptext}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   309
The general Isabelle/ML source layout imitates regular
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   310
  type-setting to some extent, augmented by the requirements for
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   311
  deeply nested expressions that are commonplace in functional
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   312
  programming.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   313
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   314
  \paragraph{Line length} is 80 characters according to ancient
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   315
  standards, but we allow as much as 100 characters (not
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   316
  more).\footnote{Readability requires to keep the beginning of a line
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   317
  in view while watching its end.  Modern wide-screen displays do not
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   318
  change the way how the human brain works.  Sources also need to be
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   319
  printable on plain paper with reasonable font-size.} The extra 20
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   320
  characters acknowledge the space requirements due to qualified
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   321
  library references in Isabelle/ML.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   322
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   323
  \paragraph{White-space} is used to emphasize the structure of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   324
  expressions, following mostly standard conventions for mathematical
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   325
  typesetting, as can be seen in plain {\TeX} or {\LaTeX}.  This
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   326
  defines positioning of spaces for parentheses, punctuation, and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   327
  infixes as illustrated here:
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   328
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   329
  \begin{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   330
  val x = y + z * (a + b);
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   331
  val pair = (a, b);
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   332
  val record = {foo = 1, bar = 2};
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   333
  \end{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   334
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   335
  Lines are normally broken \emph{after} an infix operator or
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   336
  punctuation character.  For example:
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   337
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   338
  \begin{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   339
  val x =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   340
    a +
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   341
    b +
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   342
    c;
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   343
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   344
  val tuple =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   345
   (a,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   346
    b,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   347
    c);
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   348
  \end{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   349
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   350
  Some special infixes (e.g.\ \verb||\verb,|,\verb|>|) work better at the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   351
  start of the line, but punctuation is always at the end.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   352
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   353
  Function application follows the tradition of \isa{{\isaliteral{5C3C6C616D6264613E}{\isasymlambda}}}-calculus,
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   354
  not informal mathematics.  For example: \verb|f a b| for a
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   355
  curried function, or \verb|g (a, b)| for a tupled function.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   356
  Note that the space between \verb|g| and the pair \verb|(a, b)| follows the important principle of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   357
  \emph{compositionality}: the layout of \verb|g p| does not
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   358
  change when \verb|p| is refined to the concrete pair
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   359
  \verb|(a, b)|.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   360
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   361
  \paragraph{Indentation} uses plain spaces, never hard
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   362
  tabulators.\footnote{Tabulators were invented to move the carriage
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   363
  of a type-writer to certain predefined positions.  In software they
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   364
  could be used as a primitive run-length compression of consecutive
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   365
  spaces, but the precise result would depend on non-standardized
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   366
  editor configuration.}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   367
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   368
  Each level of nesting is indented by 2 spaces, sometimes 1, very
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   369
  rarely 4, never 8 or any other odd number.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   370
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   371
  Indentation follows a simple logical format that only depends on the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   372
  nesting depth, not the accidental length of the text that initiates
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   373
  a level of nesting.  Example:
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   374
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   375
  \begin{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   376
  (* RIGHT *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   377
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   378
  if b then
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   379
    expr1_part1
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   380
    expr1_part2
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   381
  else
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   382
    expr2_part1
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   383
    expr2_part2
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   384
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   385
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   386
  (* WRONG *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   387
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   388
  if b then expr1_part1
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   389
            expr1_part2
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   390
  else expr2_part1
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   391
       expr2_part2
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   392
  \end{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   393
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   394
  The second form has many problems: it assumes a fixed-width font
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   395
  when viewing the sources, it uses more space on the line and thus
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   396
  makes it hard to observe its strict length limit (working against
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   397
  \emph{readability}), it requires extra editing to adapt the layout
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   398
  to changes of the initial text (working against
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   399
  \emph{maintainability}) etc.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   400
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   401
  \medskip For similar reasons, any kind of two-dimensional or tabular
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   402
  layouts, ASCII-art with lines or boxes of asterisks etc.\ should be
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   403
  avoided.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   404
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   405
  \paragraph{Complex expressions} that consist of multi-clausal
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   406
  function definitions, \verb|handle|, \verb|case|,
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   407
  \verb|let| (and combinations) require special attention.  The
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   408
  syntax of Standard ML is quite ambitious and admits a lot of
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   409
  variance that can distort the meaning of the text.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   410
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   411
  Clauses of \verb|fun|, \verb|fn|, \verb|handle|,
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   412
  \verb|case| get extra indentation to indicate the nesting
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   413
  clearly.  Example:
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   414
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   415
  \begin{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   416
  (* RIGHT *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   417
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   418
  fun foo p1 =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   419
        expr1
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   420
    | foo p2 =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   421
        expr2
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   422
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   423
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   424
  (* WRONG *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   425
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   426
  fun foo p1 =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   427
    expr1
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   428
    | foo p2 =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   429
    expr2
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   430
  \end{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   431
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   432
  Body expressions consisting of \verb|case| or \verb|let|
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   433
  require care to maintain compositionality, to prevent loss of
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   434
  logical indentation where it is especially important to see the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   435
  structure of the text.  Example:
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   436
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   437
  \begin{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   438
  (* RIGHT *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   439
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   440
  fun foo p1 =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   441
        (case e of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   442
          q1 => ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   443
        | q2 => ...)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   444
    | foo p2 =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   445
        let
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   446
          ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   447
        in
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   448
          ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   449
        end
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   450
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   451
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   452
  (* WRONG *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   453
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   454
  fun foo p1 = case e of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   455
      q1 => ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   456
    | q2 => ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   457
    | foo p2 =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   458
    let
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   459
      ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   460
    in
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   461
      ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   462
    end
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   463
  \end{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   464
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   465
  Extra parentheses around \verb|case| expressions are optional,
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   466
  but help to analyse the nesting based on character matching in the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   467
  editor.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   468
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   469
  \medskip There are two main exceptions to the overall principle of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   470
  compositionality in the layout of complex expressions.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   471
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   472
  \begin{enumerate}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   473
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   474
  \item \verb|if| expressions are iterated as if there would be
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   475
  a multi-branch conditional in SML, e.g.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   476
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   477
  \begin{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   478
  (* RIGHT *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   479
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   480
  if b1 then e1
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   481
  else if b2 then e2
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   482
  else e3
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   483
  \end{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   484
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   485
  \item \verb|fn| abstractions are often layed-out as if they
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   486
  would lack any structure by themselves.  This traditional form is
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   487
  motivated by the possibility to shift function arguments back and
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   488
  forth wrt.\ additional combinators.  Example:
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   489
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   490
  \begin{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   491
  (* RIGHT *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   492
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   493
  fun foo x y = fold (fn z =>
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   494
    expr)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   495
  \end{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   496
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   497
  Here the visual appearance is that of three arguments \verb|x|,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   498
  \verb|y|, \verb|z|.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   499
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   500
  \end{enumerate}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   501
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   502
  Such weakly structured layout should be use with great care.  Here
40153
wenzelm
parents: 40126
diff changeset
   503
  are some counter-examples involving \verb|let| expressions:
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   504
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   505
  \begin{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   506
  (* WRONG *)
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   507
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   508
  fun foo x = let
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   509
      val y = ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   510
    in ... end
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   511
41162
2181c47a02fe more correct ML snippets that are unchecked;
wenzelm
parents: 40964
diff changeset
   512
2181c47a02fe more correct ML snippets that are unchecked;
wenzelm
parents: 40964
diff changeset
   513
  (* WRONG *)
2181c47a02fe more correct ML snippets that are unchecked;
wenzelm
parents: 40964
diff changeset
   514
40153
wenzelm
parents: 40126
diff changeset
   515
  fun foo x = let
wenzelm
parents: 40126
diff changeset
   516
    val y = ...
wenzelm
parents: 40126
diff changeset
   517
  in ... end
wenzelm
parents: 40126
diff changeset
   518
41162
2181c47a02fe more correct ML snippets that are unchecked;
wenzelm
parents: 40964
diff changeset
   519
2181c47a02fe more correct ML snippets that are unchecked;
wenzelm
parents: 40964
diff changeset
   520
  (* WRONG *)
2181c47a02fe more correct ML snippets that are unchecked;
wenzelm
parents: 40964
diff changeset
   521
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   522
  fun foo x =
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   523
  let
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   524
    val y = ...
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   525
  in ... end
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   526
  \end{verbatim}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   527
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   528
  \medskip In general the source layout is meant to emphasize the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   529
  structure of complex language expressions, not to pretend that SML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   530
  had a completely different syntax (say that of Haskell or Java).%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   531
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   532
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   533
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   534
\isamarkupsection{SML embedded into Isabelle/Isar%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   535
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   536
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   537
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   538
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   539
ML and Isar are intertwined via an open-ended bootstrap
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   540
  process that provides more and more programming facilities and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   541
  logical content in an alternating manner.  Bootstrapping starts from
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   542
  the raw environment of existing implementations of Standard ML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   543
  (mainly Poly/ML, but also SML/NJ).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   544
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   545
  Isabelle/Pure marks the point where the original ML toplevel is
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   546
  superseded by the Isar toplevel that maintains a uniform context for
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   547
  arbitrary ML values (see also \secref{sec:context}).  This formal
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   548
  environment holds ML compiler bindings, logical entities, and many
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   549
  other things.  Raw SML is never encountered again after the initial
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   550
  bootstrap of Isabelle/Pure.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   551
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   552
  Object-logics like Isabelle/HOL are built within the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   553
  Isabelle/ML/Isar environment by introducing suitable theories with
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   554
  associated ML modules, either inlined or as separate files.  Thus
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   555
  Isabelle/HOL is defined as a regular user-space application within
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   556
  the Isabelle framework.  Further add-on tools can be implemented in
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   557
  ML within the Isar context in the same manner: ML is part of the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   558
  standard repertoire of Isabelle, and there is no distinction between
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   559
  ``user'' and ``developer'' in this respect.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   560
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   561
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   562
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   563
\isamarkupsubsection{Isar ML commands%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   564
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   565
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   566
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   567
\begin{isamarkuptext}%
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   568
The primary Isar source language provides facilities to ``open
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   569
  a window'' to the underlying ML compiler.  Especially see the Isar
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   570
  commands \indexref{}{command}{use}\hyperlink{command.use}{\mbox{\isa{\isacommand{use}}}} and \indexref{}{command}{ML}\hyperlink{command.ML}{\mbox{\isa{\isacommand{ML}}}}: both work the
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   571
  same way, only the source text is provided via a file vs.\ inlined,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   572
  respectively.  Apart from embedding ML into the main theory
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   573
  definition like that, there are many more commands that refer to ML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   574
  source, such as \indexref{}{command}{setup}\hyperlink{command.setup}{\mbox{\isa{\isacommand{setup}}}} or \indexref{}{command}{declaration}\hyperlink{command.declaration}{\mbox{\isa{\isacommand{declaration}}}}.
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   575
  Even more fine-grained embedding of ML into Isar is encountered in
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   576
  the proof method \indexref{}{method}{tactic}\hyperlink{method.tactic}{\mbox{\isa{tactic}}}, which refines the pending
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   577
  goal state via a given expression of type \verb|tactic|.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   578
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   579
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   580
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   581
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   582
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   583
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   584
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   585
\isatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   586
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   587
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   588
The following artificial example demonstrates some ML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   589
  toplevel declarations within the implicit Isar theory context.  This
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   590
  is regular functional programming without referring to logical
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   591
  entities yet.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   592
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   593
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   594
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   595
\endisatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   596
{\isafoldmlex}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   597
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   598
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   599
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   600
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   601
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   602
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   603
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   604
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   605
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   606
\isatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   607
\isacommand{ML}\isamarkupfalse%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   608
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   609
\ \ fun\ factorial\ {\isadigit{0}}\ {\isaliteral{3D}{\isacharequal}}\ {\isadigit{1}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   610
\ \ \ \ {\isaliteral{7C}{\isacharbar}}\ factorial\ n\ {\isaliteral{3D}{\isacharequal}}\ n\ {\isaliteral{2A}{\isacharasterisk}}\ factorial\ {\isaliteral{28}{\isacharparenleft}}n\ {\isaliteral{2D}{\isacharminus}}\ {\isadigit{1}}{\isaliteral{29}{\isacharparenright}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   611
{\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   612
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   613
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   614
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   615
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   616
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   617
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   618
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   619
\begin{isamarkuptext}%
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   620
Here the ML environment is already managed by Isabelle, i.e.\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   621
  the \verb|factorial| function is not yet accessible in the preceding
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   622
  paragraph, nor in a different theory that is independent from the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   623
  current one in the import hierarchy.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   624
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   625
  Removing the above ML declaration from the source text will remove
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   626
  any trace of this definition as expected.  The Isabelle/ML toplevel
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   627
  environment is managed in a \emph{stateless} way: unlike the raw ML
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   628
  toplevel there are no global side-effects involved
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   629
  here.\footnote{Such a stateless compilation environment is also a
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   630
  prerequisite for robust parallel compilation within independent
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   631
  nodes of the implicit theory development graph.}
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   632
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   633
  \medskip The next example shows how to embed ML into Isar proofs, using
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   634
 \indexref{}{command}{ML\_prf}\hyperlink{command.ML-prf}{\mbox{\isa{\isacommand{ML{\isaliteral{5F}{\isacharunderscore}}prf}}}} instead of Instead of \indexref{}{command}{ML}\hyperlink{command.ML}{\mbox{\isa{\isacommand{ML}}}}.
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   635
  As illustrated below, the effect on the ML environment is local to
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   636
  the whole proof body, ignoring the block structure.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   637
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   638
\isamarkuptrue%
40964
482a8334ee9e prefer 'notepad' over 'example_proof';
wenzelm
parents: 40802
diff changeset
   639
\isacommand{notepad}\isamarkupfalse%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   640
\isanewline
40964
482a8334ee9e prefer 'notepad' over 'example_proof';
wenzelm
parents: 40802
diff changeset
   641
\isakeyword{begin}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   642
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   643
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   644
\ \ %
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   645
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   646
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   647
\isatagML
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   648
\isacommand{ML{\isaliteral{5F}{\isacharunderscore}}prf}\isamarkupfalse%
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   649
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\ val\ a\ {\isaliteral{3D}{\isacharequal}}\ {\isadigit{1}}\ {\isaliteral{2A7D}{\isacharverbatimclose}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   650
\ \ \isacommand{{\isaliteral{7B}{\isacharbraceleft}}}\isamarkupfalse%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   651
\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   652
\ \ \ \ \isacommand{ML{\isaliteral{5F}{\isacharunderscore}}prf}\isamarkupfalse%
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   653
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\ val\ b\ {\isaliteral{3D}{\isacharequal}}\ a\ {\isaliteral{2B}{\isacharplus}}\ {\isadigit{1}}\ {\isaliteral{2A7D}{\isacharverbatimclose}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   654
\ \ \isacommand{{\isaliteral{7D}{\isacharbraceright}}}\isamarkupfalse%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   655
\ %
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   656
\isamarkupcmt{Isar block structure ignored by ML environment%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   657
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   658
\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   659
\ \ \isacommand{ML{\isaliteral{5F}{\isacharunderscore}}prf}\isamarkupfalse%
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   660
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\ val\ c\ {\isaliteral{3D}{\isacharequal}}\ b\ {\isaliteral{2B}{\isacharplus}}\ {\isadigit{1}}\ {\isaliteral{2A7D}{\isacharverbatimclose}}\isanewline
40964
482a8334ee9e prefer 'notepad' over 'example_proof';
wenzelm
parents: 40802
diff changeset
   661
\isacommand{end}\isamarkupfalse%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   662
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   663
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   664
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   665
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   666
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   667
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   668
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   669
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   670
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   671
By side-stepping the normal scoping rules for Isar proof
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   672
  blocks, embedded ML code can refer to the different contexts and
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   673
  manipulate corresponding entities, e.g.\ export a fact from a block
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   674
  context.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   675
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   676
  \medskip Two further ML commands are useful in certain situations:
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   677
  \indexref{}{command}{ML\_val}\hyperlink{command.ML-val}{\mbox{\isa{\isacommand{ML{\isaliteral{5F}{\isacharunderscore}}val}}}} and \indexref{}{command}{ML\_command}\hyperlink{command.ML-command}{\mbox{\isa{\isacommand{ML{\isaliteral{5F}{\isacharunderscore}}command}}}} are
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   678
  \emph{diagnostic} in the sense that there is no effect on the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   679
  underlying environment, and can thus used anywhere (even outside a
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   680
  theory).  The examples below produce long strings of digits by
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   681
  invoking \verb|factorial|: \hyperlink{command.ML-val}{\mbox{\isa{\isacommand{ML{\isaliteral{5F}{\isacharunderscore}}val}}}} already takes care of
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   682
  printing the ML toplevel result, but \hyperlink{command.ML-command}{\mbox{\isa{\isacommand{ML{\isaliteral{5F}{\isacharunderscore}}command}}}} is silent
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   683
  so we produce an explicit output message.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   684
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   685
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   686
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   687
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   688
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   689
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   690
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   691
\isatagML
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   692
\isacommand{ML{\isaliteral{5F}{\isacharunderscore}}val}\isamarkupfalse%
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   693
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\ factorial\ {\isadigit{1}}{\isadigit{0}}{\isadigit{0}}\ {\isaliteral{2A7D}{\isacharverbatimclose}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   694
\isacommand{ML{\isaliteral{5F}{\isacharunderscore}}command}\isamarkupfalse%
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   695
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\ writeln\ {\isaliteral{28}{\isacharparenleft}}string{\isaliteral{5F}{\isacharunderscore}}of{\isaliteral{5F}{\isacharunderscore}}int\ {\isaliteral{28}{\isacharparenleft}}factorial\ {\isadigit{1}}{\isadigit{0}}{\isadigit{0}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   696
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   697
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   698
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   699
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   700
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   701
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   702
\isanewline
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   703
\isanewline
40964
482a8334ee9e prefer 'notepad' over 'example_proof';
wenzelm
parents: 40802
diff changeset
   704
\isacommand{notepad}\isamarkupfalse%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   705
\isanewline
40964
482a8334ee9e prefer 'notepad' over 'example_proof';
wenzelm
parents: 40802
diff changeset
   706
\isakeyword{begin}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   707
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   708
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   709
\ \ %
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   710
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   711
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   712
\isatagML
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   713
\isacommand{ML{\isaliteral{5F}{\isacharunderscore}}val}\isamarkupfalse%
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   714
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\ factorial\ {\isadigit{1}}{\isadigit{0}}{\isadigit{0}}\ {\isaliteral{2A7D}{\isacharverbatimclose}}\ \ \isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   715
\ \ \isacommand{ML{\isaliteral{5F}{\isacharunderscore}}command}\isamarkupfalse%
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   716
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\ writeln\ {\isaliteral{28}{\isacharparenleft}}string{\isaliteral{5F}{\isacharunderscore}}of{\isaliteral{5F}{\isacharunderscore}}int\ {\isaliteral{28}{\isacharparenleft}}factorial\ {\isadigit{1}}{\isadigit{0}}{\isadigit{0}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   717
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   718
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   719
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   720
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   721
\isanewline
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   722
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   723
\endisadelimML
40964
482a8334ee9e prefer 'notepad' over 'example_proof';
wenzelm
parents: 40802
diff changeset
   724
\isacommand{end}\isamarkupfalse%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   725
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   726
\isamarkupsubsection{Compile-time context%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   727
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   728
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   729
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   730
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   731
Whenever the ML compiler is invoked within Isabelle/Isar, the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   732
  formal context is passed as a thread-local reference variable.  Thus
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   733
  ML code may access the theory context during compilation, by reading
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   734
  or writing the (local) theory under construction.  Note that such
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   735
  direct access to the compile-time context is rare.  In practice it
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   736
  is typically done via some derived ML functions instead.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   737
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   738
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   739
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   740
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   741
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   742
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   743
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   744
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   745
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   746
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   747
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   748
  \indexdef{}{ML}{ML\_Context.the\_generic\_context}\verb|ML_Context.the_generic_context: unit -> Context.generic| \\
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   749
  \indexdef{}{ML}{Context.$>$$>$}\verb|Context.>> : (Context.generic -> Context.generic) -> unit| \\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   750
  \indexdef{}{ML}{bind\_thms}\verb|bind_thms: string * thm list -> unit| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   751
  \indexdef{}{ML}{bind\_thm}\verb|bind_thm: string * thm -> unit| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   752
  \end{mldecls}
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   753
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   754
  \begin{description}
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   755
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   756
  \item \verb|ML_Context.the_generic_context ()| refers to the theory
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   757
  context of the ML toplevel --- at compile time.  ML code needs to
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   758
  take care to refer to \verb|ML_Context.the_generic_context ()|
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   759
  correctly.  Recall that evaluation of a function body is delayed
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   760
  until actual run-time.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   761
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   762
  \item \verb|Context.>>|~\isa{f} applies context transformation
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   763
  \isa{f} to the implicit context of the ML toplevel.
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   764
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   765
  \item \verb|bind_thms|~\isa{{\isaliteral{28}{\isacharparenleft}}name{\isaliteral{2C}{\isacharcomma}}\ thms{\isaliteral{29}{\isacharparenright}}} stores a list of
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   766
  theorems produced in ML both in the (global) theory context and the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   767
  ML toplevel, associating it with the provided name.  Theorems are
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   768
  put into a global ``standard'' format before being stored.
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   769
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   770
  \item \verb|bind_thm| is similar to \verb|bind_thms| but refers to a
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   771
  singleton fact.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   772
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   773
  \end{description}
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   774
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   775
  It is important to note that the above functions are really
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   776
  restricted to the compile time, even though the ML compiler is
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   777
  invoked at run-time.  The majority of ML code either uses static
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   778
  antiquotations (\secref{sec:ML-antiq}) or refers to the theory or
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   779
  proof context at run-time, by explicit functional abstraction.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   780
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   781
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   782
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   783
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   784
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   785
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   786
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   787
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   788
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   789
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   790
\isamarkupsubsection{Antiquotations \label{sec:ML-antiq}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   791
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   792
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   793
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   794
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   795
A very important consequence of embedding SML into Isar is the
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   796
  concept of \emph{ML antiquotation}.  The standard token language of
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   797
  ML is augmented by special syntactic entities of the following form:
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   798
42510
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   799
  \begin{railoutput}
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   800
\rail@begin{3}{\indexdef{}{syntax}{antiquote}\hypertarget{syntax.antiquote}{\hyperlink{syntax.antiquote}{\mbox{\isa{antiquote}}}}}
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   801
\rail@bar
42665
e4c5c7ffceea more precise syntax diagram;
wenzelm
parents: 42662
diff changeset
   802
\rail@term{\isa{{\isaliteral{40}{\isacharat}}{\isaliteral{7B}{\isacharbraceleft}}}}[]
42510
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   803
\rail@nont{\isa{nameref}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   804
\rail@nont{\isa{args}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   805
\rail@term{\isa{{\isaliteral{7D}{\isacharbraceright}}}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   806
\rail@nextbar{1}
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   807
\rail@term{\isa{{\isaliteral{5C3C6C62726163653E}{\isasymlbrace}}}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   808
\rail@nextbar{2}
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   809
\rail@term{\isa{{\isaliteral{5C3C7262726163653E}{\isasymrbrace}}}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   810
\rail@endbar
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   811
\rail@end
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   812
\end{railoutput}
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   813
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   814
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   815
  Here \hyperlink{syntax.nameref}{\mbox{\isa{nameref}}} and \hyperlink{syntax.args}{\mbox{\isa{args}}} are regular outer syntax
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   816
  categories \cite{isabelle-isar-ref}.  Attributes and proof methods
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   817
  use similar syntax.
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   818
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   819
  \medskip A regular antiquotation \isa{{\isaliteral{40}{\isacharat}}{\isaliteral{7B}{\isacharbraceleft}}name\ args{\isaliteral{7D}{\isacharbraceright}}} processes
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   820
  its arguments by the usual means of the Isar source language, and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   821
  produces corresponding ML source text, either as literal
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   822
  \emph{inline} text (e.g. \isa{{\isaliteral{40}{\isacharat}}{\isaliteral{7B}{\isacharbraceleft}}term\ t{\isaliteral{7D}{\isacharbraceright}}}) or abstract
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   823
  \emph{value} (e.g. \isa{{\isaliteral{40}{\isacharat}}{\isaliteral{7B}{\isacharbraceleft}}thm\ th{\isaliteral{7D}{\isacharbraceright}}}).  This pre-compilation
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   824
  scheme allows to refer to formal entities in a robust manner, with
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   825
  proper static scoping and with some degree of logical checking of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   826
  small portions of the code.
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   827
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   828
  Special antiquotations like \isa{{\isaliteral{40}{\isacharat}}{\isaliteral{7B}{\isacharbraceleft}}let\ {\isaliteral{5C3C646F74733E}{\isasymdots}}{\isaliteral{7D}{\isacharbraceright}}} or \isa{{\isaliteral{40}{\isacharat}}{\isaliteral{7B}{\isacharbraceleft}}note\ {\isaliteral{5C3C646F74733E}{\isasymdots}}{\isaliteral{7D}{\isacharbraceright}}} augment the compilation context without generating code.  The
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   829
  non-ASCII braces \isa{{\isaliteral{5C3C6C62726163653E}{\isasymlbrace}}} and \isa{{\isaliteral{5C3C7262726163653E}{\isasymrbrace}}} allow to delimit the
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   830
  effect by introducing local blocks within the pre-compilation
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   831
  environment.
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   832
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   833
  \medskip See also \cite{Wenzel-Chaieb:2007b} for a broader
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   834
  perspective on Isabelle/ML antiquotations.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   835
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   836
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   837
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   838
\isadelimmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   839
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   840
\endisadelimmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   841
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   842
\isatagmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   843
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   844
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   845
\begin{matharray}{rcl}
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   846
  \indexdef{}{ML antiquotation}{let}\hypertarget{ML antiquotation.let}{\hyperlink{ML antiquotation.let}{\mbox{\isa{let}}}} & : & \isa{ML{\isaliteral{5F}{\isacharunderscore}}antiquotation} \\
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   847
  \indexdef{}{ML antiquotation}{note}\hypertarget{ML antiquotation.note}{\hyperlink{ML antiquotation.note}{\mbox{\isa{note}}}} & : & \isa{ML{\isaliteral{5F}{\isacharunderscore}}antiquotation} \\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   848
  \end{matharray}
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   849
42510
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   850
  \begin{railoutput}
42662
2080fe35abea updated generated files;
wenzelm
parents: 42517
diff changeset
   851
\rail@begin{3}{}
42510
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   852
\rail@term{\hyperlink{ML antiquotation.let}{\mbox{\isa{let}}}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   853
\rail@plus
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   854
\rail@plus
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   855
\rail@nont{\isa{term}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   856
\rail@nextplus{1}
42517
b68e1c27709a simplified keyword markup (without formal checking);
wenzelm
parents: 42510
diff changeset
   857
\rail@cterm{\isa{\isakeyword{and}}}[]
42510
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   858
\rail@endplus
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   859
\rail@term{\isa{{\isaliteral{3D}{\isacharequal}}}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   860
\rail@nont{\isa{term}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   861
\rail@nextplus{2}
42517
b68e1c27709a simplified keyword markup (without formal checking);
wenzelm
parents: 42510
diff changeset
   862
\rail@cterm{\isa{\isakeyword{and}}}[]
42510
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   863
\rail@endplus
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   864
\rail@end
42662
2080fe35abea updated generated files;
wenzelm
parents: 42517
diff changeset
   865
\rail@begin{3}{}
42510
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   866
\rail@term{\hyperlink{ML antiquotation.note}{\mbox{\isa{note}}}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   867
\rail@plus
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   868
\rail@bar
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   869
\rail@nextbar{1}
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   870
\rail@nont{\isa{thmdef}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   871
\rail@endbar
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   872
\rail@nont{\isa{thmrefs}}[]
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   873
\rail@nextplus{2}
42517
b68e1c27709a simplified keyword markup (without formal checking);
wenzelm
parents: 42510
diff changeset
   874
\rail@cterm{\isa{\isakeyword{and}}}[]
42510
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   875
\rail@endplus
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   876
\rail@end
b9c106763325 use @{rail} antiquotation (with some nested markup);
wenzelm
parents: 41162
diff changeset
   877
\end{railoutput}
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   878
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   879
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   880
  \begin{description}
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   881
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   882
  \item \isa{{\isaliteral{40}{\isacharat}}{\isaliteral{7B}{\isacharbraceleft}}let\ p\ {\isaliteral{3D}{\isacharequal}}\ t{\isaliteral{7D}{\isacharbraceright}}} binds schematic variables in the
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   883
  pattern \isa{p} by higher-order matching against the term \isa{t}.  This is analogous to the regular \indexref{}{command}{let}\hyperlink{command.let}{\mbox{\isa{\isacommand{let}}}} command
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   884
  in the Isar proof language.  The pre-compilation environment is
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   885
  augmented by auxiliary term bindings, without emitting ML source.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   886
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   887
  \item \isa{{\isaliteral{40}{\isacharat}}{\isaliteral{7B}{\isacharbraceleft}}note\ a\ {\isaliteral{3D}{\isacharequal}}\ b\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}\ {\isaliteral{5C3C646F74733E}{\isasymdots}}\ b\isaliteral{5C3C5E7375623E}{}\isactrlsub n{\isaliteral{7D}{\isacharbraceright}}} recalls existing facts \isa{b\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}{\isaliteral{2C}{\isacharcomma}}\ {\isaliteral{5C3C646F74733E}{\isasymdots}}{\isaliteral{2C}{\isacharcomma}}\ b\isaliteral{5C3C5E7375623E}{}\isactrlsub n}, binding the result as \isa{a}.  This is analogous to
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   888
  the regular \indexref{}{command}{note}\hyperlink{command.note}{\mbox{\isa{\isacommand{note}}}} command in the Isar proof language.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   889
  The pre-compilation environment is augmented by auxiliary fact
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   890
  bindings, without emitting ML source.
21148
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   891
3a64d58a9f49 first version of style guide
haftmann
parents: 20520
diff changeset
   892
  \end{description}%
18543
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
   893
\end{isamarkuptext}%
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
   894
\isamarkuptrue%
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
   895
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   896
\endisatagmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   897
{\isafoldmlantiq}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   898
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   899
\isadelimmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   900
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   901
\endisadelimmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   902
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   903
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   904
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   905
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   906
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   907
\isatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   908
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   909
\begin{isamarkuptext}%
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   910
The following artificial example gives some impression
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   911
  about the antiquotation elements introduced so far, together with
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   912
  the important \isa{{\isaliteral{40}{\isacharat}}{\isaliteral{7B}{\isacharbraceleft}}thm{\isaliteral{7D}{\isacharbraceright}}} antiquotation defined later.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   913
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   914
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   915
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   916
\endisatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   917
{\isafoldmlex}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   918
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   919
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   920
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   921
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   922
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   923
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   924
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   925
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   926
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   927
\isatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   928
\isacommand{ML}\isamarkupfalse%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   929
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   930
\ \ {\isaliteral{5C3C6C62726163653E}{\isaantiqopen}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   931
\ \ \ \ %
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   932
\isaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   933
let\ {\isaliteral{3F}{\isacharquery}}t\ {\isaliteral{3D}{\isacharequal}}\ my{\isaliteral{5F}{\isacharunderscore}}term{}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   934
\endisaantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   935
\isanewline
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   936
\ \ \ \ %
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   937
\isaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   938
note\ my{\isaliteral{5F}{\isacharunderscore}}refl\ {\isaliteral{3D}{\isacharequal}}\ reflexive\ {\isaliteral{5B}{\isacharbrackleft}}of\ {\isaliteral{3F}{\isacharquery}}t{\isaliteral{5D}{\isacharbrackright}}{}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   939
\endisaantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   940
\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   941
\ \ \ \ fun\ foo\ th\ {\isaliteral{3D}{\isacharequal}}\ Thm{\isaliteral{2E}{\isachardot}}transitive\ th\ %
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   942
\isaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   943
thm\ my{\isaliteral{5F}{\isacharunderscore}}refl{}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   944
\endisaantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   945
\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   946
\ \ {\isaliteral{5C3C7262726163653E}{\isaantiqclose}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   947
{\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   948
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   949
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   950
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   951
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   952
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   953
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   954
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   955
\begin{isamarkuptext}%
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   956
The extra block delimiters do not affect the compiled code
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   957
  itself, i.e.\ function \verb|foo| is available in the present context
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   958
  of this paragraph.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   959
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   960
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   961
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   962
\isamarkupsection{Canonical argument order \label{sec:canonical-argument-order}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   963
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   964
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   965
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   966
\begin{isamarkuptext}%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   967
Standard ML is a language in the tradition of \isa{{\isaliteral{5C3C6C616D6264613E}{\isasymlambda}}}-calculus and \emph{higher-order functional programming},
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   968
  similar to OCaml, Haskell, or Isabelle/Pure and HOL as logical
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   969
  languages.  Getting acquainted with the native style of representing
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   970
  functions in that setting can save a lot of extra boiler-plate of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   971
  redundant shuffling of arguments, auxiliary abstractions etc.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   972
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   973
  Functions are usually \emph{curried}: the idea of turning arguments
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   974
  of type \isa{{\isaliteral{5C3C7461753E}{\isasymtau}}\isaliteral{5C3C5E7375623E}{}\isactrlsub i} (for \isa{i\ {\isaliteral{5C3C696E3E}{\isasymin}}\ {\isaliteral{7B}{\isacharbraceleft}}{\isadigit{1}}{\isaliteral{2C}{\isacharcomma}}\ {\isaliteral{5C3C646F74733E}{\isasymdots}}\ n{\isaliteral{7D}{\isacharbraceright}}}) into a result of
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   975
  type \isa{{\isaliteral{5C3C7461753E}{\isasymtau}}} is represented by the iterated function space
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   976
  \isa{{\isaliteral{5C3C7461753E}{\isasymtau}}\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C646F74733E}{\isasymdots}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C7461753E}{\isasymtau}}\isaliteral{5C3C5E7375623E}{}\isactrlsub n\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C7461753E}{\isasymtau}}}.  This is isomorphic to the well-known
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   977
  encoding via tuples \isa{{\isaliteral{5C3C7461753E}{\isasymtau}}\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}\ {\isaliteral{5C3C74696D65733E}{\isasymtimes}}\ {\isaliteral{5C3C646F74733E}{\isasymdots}}\ {\isaliteral{5C3C74696D65733E}{\isasymtimes}}\ {\isaliteral{5C3C7461753E}{\isasymtau}}\isaliteral{5C3C5E7375623E}{}\isactrlsub n\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C7461753E}{\isasymtau}}}, but the curried
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   978
  version fits more smoothly into the basic calculus.\footnote{The
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   979
  difference is even more significant in higher-order logic, because
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   980
  the redundant tuple structure needs to be accommodated by formal
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   981
  reasoning.}
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   982
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   983
  Currying gives some flexiblity due to \emph{partial application}.  A
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   984
  function \isa{f{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C7461753E}{\isasymtau}}\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C7461753E}{\isasymtau}}\isaliteral{5C3C5E627375623E}{}\isactrlbsub {\isadigit{2}}\isaliteral{5C3C5E657375623E}{}\isactrlesub \ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C7461753E}{\isasymtau}}} can be applied to \isa{x{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C7461753E}{\isasymtau}}\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}}
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   985
  and the remaining \isa{{\isaliteral{28}{\isacharparenleft}}f\ x{\isaliteral{29}{\isacharparenright}}{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C7461753E}{\isasymtau}}\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{2}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C7461753E}{\isasymtau}}} passed to another function
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   986
  etc.  How well this works in practice depends on the order of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   987
  arguments.  In the worst case, arguments are arranged erratically,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   988
  and using a function in a certain situation always requires some
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   989
  glue code.  Thus we would get exponentially many oppurtunities to
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   990
  decorate the code with meaningless permutations of arguments.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   991
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   992
  This can be avoided by \emph{canonical argument order}, which
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
   993
  observes certain standard patterns and minimizes adhoc permutations
40229
wenzelm
parents: 40153
diff changeset
   994
  in their application.  In Isabelle/ML, large portions of text can be
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   995
  written without ever using \isa{swap{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C616C7068613E}{\isasymalpha}}\ {\isaliteral{5C3C74696D65733E}{\isasymtimes}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}\ {\isaliteral{5C3C74696D65733E}{\isasymtimes}}\ {\isaliteral{5C3C616C7068613E}{\isasymalpha}}}, or the
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
   996
  combinator \isa{C{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{5C3C616C7068613E}{\isasymalpha}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C67616D6D613E}{\isasymgamma}}{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{5C3C626574613E}{\isasymbeta}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C616C7068613E}{\isasymalpha}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C67616D6D613E}{\isasymgamma}}{\isaliteral{29}{\isacharparenright}}} that is not even
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   997
  defined in our library.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   998
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
   999
  \medskip The basic idea is that arguments that vary less are moved
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1000
  further to the left than those that vary more.  Two particularly
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1001
  important categories of functions are \emph{selectors} and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1002
  \emph{updates}.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1003
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1004
  The subsequent scheme is based on a hypothetical set-like container
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1005
  of type \isa{{\isaliteral{5C3C626574613E}{\isasymbeta}}} that manages elements of type \isa{{\isaliteral{5C3C616C7068613E}{\isasymalpha}}}.  Both
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1006
  the names and types of the associated operations are canonical for
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1007
  Isabelle/ML.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1008
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1009
  \medskip
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1010
  \begin{tabular}{ll}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1011
  kind & canonical name and type \\\hline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1012
  selector & \isa{member{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C616C7068613E}{\isasymalpha}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ bool} \\
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1013
  update & \isa{insert{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C616C7068613E}{\isasymalpha}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}} \\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1014
  \end{tabular}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1015
  \medskip
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1016
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1017
  Given a container \isa{B{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}}, the partially applied \isa{member\ B} is a predicate over elements \isa{{\isaliteral{5C3C616C7068613E}{\isasymalpha}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ bool}, and
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1018
  thus represents the intended denotation directly.  It is customary
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1019
  to pass the abstract predicate to further operations, not the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1020
  concrete container.  The argument order makes it easy to use other
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1021
  combinators: \isa{forall\ {\isaliteral{28}{\isacharparenleft}}member\ B{\isaliteral{29}{\isacharparenright}}\ list} will check a list of
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1022
  elements for membership in \isa{B} etc. Often the explicit
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1023
  \isa{list} is pointless and can be contracted to \isa{forall\ {\isaliteral{28}{\isacharparenleft}}member\ B{\isaliteral{29}{\isacharparenright}}} to get directly a predicate again.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1024
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1025
  In contrast, an update operation varies the container, so it moves
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1026
  to the right: \isa{insert\ a} is a function \isa{{\isaliteral{5C3C626574613E}{\isasymbeta}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}} to
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1027
  insert a value \isa{a}.  These can be composed naturally as
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1028
  \isa{insert\ c\ {\isaliteral{5C3C636972633E}{\isasymcirc}}\ insert\ b\ {\isaliteral{5C3C636972633E}{\isasymcirc}}\ insert\ a}.  The slightly awkward
40229
wenzelm
parents: 40153
diff changeset
  1029
  inversion of the composition order is due to conventional
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1030
  mathematical notation, which can be easily amended as explained
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1031
  below.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1032
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1033
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1034
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1035
\isamarkupsubsection{Forward application and composition%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1036
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1037
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1038
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1039
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1040
Regular function application and infix notation works best for
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1041
  relatively deeply structured expressions, e.g.\ \isa{h\ {\isaliteral{28}{\isacharparenleft}}f\ x\ y\ {\isaliteral{2B}{\isacharplus}}\ g\ z{\isaliteral{29}{\isacharparenright}}}.  The important special case of \emph{linear transformation}
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1042
  applies a cascade of functions \isa{f\isaliteral{5C3C5E7375623E}{}\isactrlsub n\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{5C3C646F74733E}{\isasymdots}}\ {\isaliteral{28}{\isacharparenleft}}f\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}\ x{\isaliteral{29}{\isacharparenright}}{\isaliteral{29}{\isacharparenright}}}.  This
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1043
  becomes hard to read and maintain if the functions are themselves
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1044
  given as complex expressions.  The notation can be significantly
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1045
  improved by introducing \emph{forward} versions of application and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1046
  composition as follows:
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1047
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1048
  \medskip
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1049
  \begin{tabular}{lll}
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1050
  \isa{x\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ f} & \isa{{\isaliteral{5C3C65717569763E}{\isasymequiv}}} & \isa{f\ x} \\
41162
2181c47a02fe more correct ML snippets that are unchecked;
wenzelm
parents: 40964
diff changeset
  1051
  \isa{{\isaliteral{28}{\isacharparenleft}}f\ {\isaliteral{23}{\isacharhash}}{\isaliteral{3E}{\isachargreater}}\ g{\isaliteral{29}{\isacharparenright}}\ x} & \isa{{\isaliteral{5C3C65717569763E}{\isasymequiv}}} & \isa{x\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ f\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ g} \\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1052
  \end{tabular}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1053
  \medskip
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1054
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1055
  This enables to write conveniently \isa{x\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ f\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ {\isaliteral{5C3C646F74733E}{\isasymdots}}\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ f\isaliteral{5C3C5E7375623E}{}\isactrlsub n} or
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1056
  \isa{f\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}\ {\isaliteral{23}{\isacharhash}}{\isaliteral{3E}{\isachargreater}}\ {\isaliteral{5C3C646F74733E}{\isasymdots}}\ {\isaliteral{23}{\isacharhash}}{\isaliteral{3E}{\isachargreater}}\ f\isaliteral{5C3C5E7375623E}{}\isactrlsub n} for its functional abstraction over \isa{x}.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1057
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1058
  \medskip There is an additional set of combinators to accommodate
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1059
  multiple results (via pairs) that are passed on as multiple
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1060
  arguments (via currying).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1061
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1062
  \medskip
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1063
  \begin{tabular}{lll}
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1064
  \isa{{\isaliteral{28}{\isacharparenleft}}x{\isaliteral{2C}{\isacharcomma}}\ y{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{2D}{\isacharminus}}{\isaliteral{3E}{\isachargreater}}\ f} & \isa{{\isaliteral{5C3C65717569763E}{\isasymequiv}}} & \isa{f\ x\ y} \\
41162
2181c47a02fe more correct ML snippets that are unchecked;
wenzelm
parents: 40964
diff changeset
  1065
  \isa{{\isaliteral{28}{\isacharparenleft}}f\ {\isaliteral{23}{\isacharhash}}{\isaliteral{2D}{\isacharminus}}{\isaliteral{3E}{\isachargreater}}\ g{\isaliteral{29}{\isacharparenright}}\ x} & \isa{{\isaliteral{5C3C65717569763E}{\isasymequiv}}} & \isa{x\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ f\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{2D}{\isacharminus}}{\isaliteral{3E}{\isachargreater}}\ g} \\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1066
  \end{tabular}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1067
  \medskip%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1068
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1069
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1070
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1071
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1072
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1073
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1074
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1075
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1076
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1077
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1078
\begin{mldecls}
46262
912b42e64fde tuned ML infixes;
wenzelm
parents: 42665
diff changeset
  1079
  \indexdef{}{ML infix}{$\mid$$>$}\verb|infix |\verb,|,\verb|>  : 'a * ('a -> 'b) -> 'b| \\
912b42e64fde tuned ML infixes;
wenzelm
parents: 42665
diff changeset
  1080
  \indexdef{}{ML infix}{$\mid$-$>$}\verb|infix |\verb,|,\verb|->  : ('c * 'a) * ('c -> 'a -> 'b) -> 'b| \\
912b42e64fde tuned ML infixes;
wenzelm
parents: 42665
diff changeset
  1081
  \indexdef{}{ML infix}{\#$>$}\verb|infix #>  : ('a -> 'b) * ('b -> 'c) -> 'a -> 'c| \\
912b42e64fde tuned ML infixes;
wenzelm
parents: 42665
diff changeset
  1082
  \indexdef{}{ML infix}{\#-$>$}\verb|infix #->  : ('a -> 'c * 'b) * ('c -> 'b -> 'd) -> 'a -> 'd| \\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1083
  \end{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1084
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1085
  %FIXME description!?%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1086
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1087
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1088
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1089
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1090
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1091
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1092
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1093
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1094
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1095
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1096
\isamarkupsubsection{Canonical iteration%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1097
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1098
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1099
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1100
\begin{isamarkuptext}%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1101
As explained above, a function \isa{f{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C616C7068613E}{\isasymalpha}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}} can be
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1102
  understood as update on a configuration of type \isa{{\isaliteral{5C3C626574613E}{\isasymbeta}}},
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1103
  parametrized by arguments of type \isa{{\isaliteral{5C3C616C7068613E}{\isasymalpha}}}.  Given \isa{a{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C616C7068613E}{\isasymalpha}}}
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1104
  the partial application \isa{{\isaliteral{28}{\isacharparenleft}}f\ a{\isaliteral{29}{\isacharparenright}}{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}} operates
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1105
  homogeneously on \isa{{\isaliteral{5C3C626574613E}{\isasymbeta}}}.  This can be iterated naturally over a
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1106
  list of parameters \isa{{\isaliteral{5B}{\isacharbrackleft}}a\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}{\isaliteral{2C}{\isacharcomma}}\ {\isaliteral{5C3C646F74733E}{\isasymdots}}{\isaliteral{2C}{\isacharcomma}}\ a\isaliteral{5C3C5E7375623E}{}\isactrlsub n{\isaliteral{5D}{\isacharbrackright}}} as \isa{f\ a\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}\ {\isaliteral{23}{\isacharhash}}{\isaliteral{3E}{\isachargreater}}\ {\isaliteral{5C3C646F74733E}{\isasymdots}}\ {\isaliteral{23}{\isacharhash}}{\isaliteral{3E}{\isachargreater}}\ f\ a\isaliteral{5C3C5E627375623E}{}\isactrlbsub n\isaliteral{5C3C5E657375623E}{}\isactrlesub \isaliteral{5C3C5E627375623E}{}\isactrlbsub \isaliteral{5C3C5E657375623E}{}\isactrlesub }.  The latter expression is again a function \isa{{\isaliteral{5C3C626574613E}{\isasymbeta}}\ {\isaliteral{5C3C72696768746172726F773E}{\isasymrightarrow}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}}.
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1107
  It can be applied to an initial configuration \isa{b{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{5C3C626574613E}{\isasymbeta}}} to
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1108
  start the iteration over the given list of arguments: each \isa{a} in \isa{a\isaliteral{5C3C5E7375623E}{}\isactrlsub {\isadigit{1}}{\isaliteral{2C}{\isacharcomma}}\ {\isaliteral{5C3C646F74733E}{\isasymdots}}{\isaliteral{2C}{\isacharcomma}}\ a\isaliteral{5C3C5E7375623E}{}\isactrlsub n} is applied consecutively by updating a
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1109
  cumulative configuration.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1110
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1111
  The \isa{fold} combinator in Isabelle/ML lifts a function \isa{f} as above to its iterated version over a list of arguments.
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1112
  Lifting can be repeated, e.g.\ \isa{{\isaliteral{28}{\isacharparenleft}}fold\ {\isaliteral{5C3C636972633E}{\isasymcirc}}\ fold{\isaliteral{29}{\isacharparenright}}\ f} iterates
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1113
  over a list of lists as expected.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1114
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1115
  The variant \isa{fold{\isaliteral{5F}{\isacharunderscore}}rev} works inside-out over the list of
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1116
  arguments, such that \isa{fold{\isaliteral{5F}{\isacharunderscore}}rev\ f\ {\isaliteral{5C3C65717569763E}{\isasymequiv}}\ fold\ f\ {\isaliteral{5C3C636972633E}{\isasymcirc}}\ rev} holds.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1117
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1118
  The \isa{fold{\isaliteral{5F}{\isacharunderscore}}map} combinator essentially performs \isa{fold} and \isa{map} simultaneously: each application of \isa{f} produces an updated configuration together with a side-result;
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1119
  the iteration collects all such side-results as a separate list.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1120
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1121
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1122
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1123
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1124
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1125
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1126
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1127
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1128
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1129
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1130
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1131
  \indexdef{}{ML}{fold}\verb|fold: ('a -> 'b -> 'b) -> 'a list -> 'b -> 'b| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1132
  \indexdef{}{ML}{fold\_rev}\verb|fold_rev: ('a -> 'b -> 'b) -> 'a list -> 'b -> 'b| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1133
  \indexdef{}{ML}{fold\_map}\verb|fold_map: ('a -> 'b -> 'c * 'b) -> 'a list -> 'b -> 'c list * 'b| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1134
  \end{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1135
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1136
  \begin{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1137
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1138
  \item \verb|fold|~\isa{f} lifts the parametrized update function
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1139
  \isa{f} to a list of parameters.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1140
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1141
  \item \verb|fold_rev|~\isa{f} is similar to \verb|fold|~\isa{f}, but works inside-out.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1142
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1143
  \item \verb|fold_map|~\isa{f} lifts the parametrized update
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1144
  function \isa{f} (with side-result) to a list of parameters and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1145
  cumulative side-results.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1146
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1147
  \end{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1148
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1149
  \begin{warn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1150
  The literature on functional programming provides a multitude of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1151
  combinators called \isa{foldl}, \isa{foldr} etc.  SML97
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1152
  provides its own variations as \verb|List.foldl| and \verb|List.foldr|, while the classic Isabelle library also has the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1153
  historic \verb|Library.foldl| and \verb|Library.foldr|.  To avoid
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1154
  further confusion, all of this should be ignored, and \verb|fold| (or
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1155
  \verb|fold_rev|) used exclusively.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1156
  \end{warn}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1157
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1158
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1159
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1160
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1161
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1162
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1163
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1164
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1165
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1166
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1167
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1168
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1169
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1170
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1171
\isatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1172
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1173
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1174
The following example shows how to fill a text buffer
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1175
  incrementally by adding strings, either individually or from a given
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1176
  list.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1177
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1178
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1179
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1180
\endisatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1181
{\isafoldmlex}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1182
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1183
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1184
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1185
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1186
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1187
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1188
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1189
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1190
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1191
\isatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1192
\isacommand{ML}\isamarkupfalse%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1193
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1194
\ \ val\ s\ {\isaliteral{3D}{\isacharequal}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1195
\ \ \ \ Buffer{\isaliteral{2E}{\isachardot}}empty\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1196
\ \ \ \ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ Buffer{\isaliteral{2E}{\isachardot}}add\ {\isaliteral{22}{\isachardoublequote}}digits{\isaliteral{3A}{\isacharcolon}}\ {\isaliteral{22}{\isachardoublequote}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1197
\ \ \ \ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ fold\ {\isaliteral{28}{\isacharparenleft}}Buffer{\isaliteral{2E}{\isachardot}}add\ o\ string{\isaliteral{5F}{\isacharunderscore}}of{\isaliteral{5F}{\isacharunderscore}}int{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{28}{\isacharparenleft}}{\isadigit{0}}\ upto\ {\isadigit{9}}{\isaliteral{29}{\isacharparenright}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1198
\ \ \ \ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ Buffer{\isaliteral{2E}{\isachardot}}content{\isaliteral{3B}{\isacharsemicolon}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1199
\isanewline
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1200
\ \ %
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1201
\isaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1202
assert{}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1203
\endisaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1204
\ {\isaliteral{28}{\isacharparenleft}}s\ {\isaliteral{3D}{\isacharequal}}\ {\isaliteral{22}{\isachardoublequote}}digits{\isaliteral{3A}{\isacharcolon}}\ {\isadigit{0}}{\isadigit{1}}{\isadigit{2}}{\isadigit{3}}{\isadigit{4}}{\isadigit{5}}{\isadigit{6}}{\isadigit{7}}{\isadigit{8}}{\isadigit{9}}{\isaliteral{22}{\isachardoublequote}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1205
{\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1206
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1207
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1208
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1209
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1210
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1211
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1212
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1213
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1214
Note how \verb|fold (Buffer.add o string_of_int)| above saves
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1215
  an extra \verb|map| over the given list.  This kind of peephole
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1216
  optimization reduces both the code size and the tree structures in
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1217
  memory (``deforestation''), but requires some practice to read and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1218
  write it fluently.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1219
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1220
  \medskip The next example elaborates the idea of canonical
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1221
  iteration, demonstrating fast accumulation of tree content using a
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1222
  text buffer.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1223
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1224
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1225
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1226
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1227
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1228
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1229
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1230
\isatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1231
\isacommand{ML}\isamarkupfalse%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1232
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1233
\ \ datatype\ tree\ {\isaliteral{3D}{\isacharequal}}\ Text\ of\ string\ {\isaliteral{7C}{\isacharbar}}\ Elem\ of\ string\ {\isaliteral{2A}{\isacharasterisk}}\ tree\ list{\isaliteral{3B}{\isacharsemicolon}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1234
\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1235
\ \ fun\ slow{\isaliteral{5F}{\isacharunderscore}}content\ {\isaliteral{28}{\isacharparenleft}}Text\ txt{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{3D}{\isacharequal}}\ txt\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1236
\ \ \ \ {\isaliteral{7C}{\isacharbar}}\ slow{\isaliteral{5F}{\isacharunderscore}}content\ {\isaliteral{28}{\isacharparenleft}}Elem\ {\isaliteral{28}{\isacharparenleft}}name{\isaliteral{2C}{\isacharcomma}}\ ts{\isaliteral{29}{\isacharparenright}}{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{3D}{\isacharequal}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1237
\ \ \ \ \ \ \ \ {\isaliteral{22}{\isachardoublequote}}{\isaliteral{3C}{\isacharless}}{\isaliteral{22}{\isachardoublequote}}\ {\isaliteral{5E}{\isacharcircum}}\ name\ {\isaliteral{5E}{\isacharcircum}}\ {\isaliteral{22}{\isachardoublequote}}{\isaliteral{3E}{\isachargreater}}{\isaliteral{22}{\isachardoublequote}}\ {\isaliteral{5E}{\isacharcircum}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1238
\ \ \ \ \ \ \ \ implode\ {\isaliteral{28}{\isacharparenleft}}map\ slow{\isaliteral{5F}{\isacharunderscore}}content\ ts{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{5E}{\isacharcircum}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1239
\ \ \ \ \ \ \ \ {\isaliteral{22}{\isachardoublequote}}{\isaliteral{3C}{\isacharless}}{\isaliteral{2F}{\isacharslash}}{\isaliteral{22}{\isachardoublequote}}\ {\isaliteral{5E}{\isacharcircum}}\ name\ {\isaliteral{5E}{\isacharcircum}}\ {\isaliteral{22}{\isachardoublequote}}{\isaliteral{3E}{\isachargreater}}{\isaliteral{22}{\isachardoublequote}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1240
\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1241
\ \ fun\ add{\isaliteral{5F}{\isacharunderscore}}content\ {\isaliteral{28}{\isacharparenleft}}Text\ txt{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{3D}{\isacharequal}}\ Buffer{\isaliteral{2E}{\isachardot}}add\ txt\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1242
\ \ \ \ {\isaliteral{7C}{\isacharbar}}\ add{\isaliteral{5F}{\isacharunderscore}}content\ {\isaliteral{28}{\isacharparenleft}}Elem\ {\isaliteral{28}{\isacharparenleft}}name{\isaliteral{2C}{\isacharcomma}}\ ts{\isaliteral{29}{\isacharparenright}}{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{3D}{\isacharequal}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1243
\ \ \ \ \ \ \ \ Buffer{\isaliteral{2E}{\isachardot}}add\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{22}{\isachardoublequote}}{\isaliteral{3C}{\isacharless}}{\isaliteral{22}{\isachardoublequote}}\ {\isaliteral{5E}{\isacharcircum}}\ name\ {\isaliteral{5E}{\isacharcircum}}\ {\isaliteral{22}{\isachardoublequote}}{\isaliteral{3E}{\isachargreater}}{\isaliteral{22}{\isachardoublequote}}{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{23}{\isacharhash}}{\isaliteral{3E}{\isachargreater}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1244
\ \ \ \ \ \ \ \ fold\ add{\isaliteral{5F}{\isacharunderscore}}content\ ts\ {\isaliteral{23}{\isacharhash}}{\isaliteral{3E}{\isachargreater}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1245
\ \ \ \ \ \ \ \ Buffer{\isaliteral{2E}{\isachardot}}add\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{22}{\isachardoublequote}}{\isaliteral{3C}{\isacharless}}{\isaliteral{2F}{\isacharslash}}{\isaliteral{22}{\isachardoublequote}}\ {\isaliteral{5E}{\isacharcircum}}\ name\ {\isaliteral{5E}{\isacharcircum}}\ {\isaliteral{22}{\isachardoublequote}}{\isaliteral{3E}{\isachargreater}}{\isaliteral{22}{\isachardoublequote}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1246
\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1247
\ \ fun\ fast{\isaliteral{5F}{\isacharunderscore}}content\ tree\ {\isaliteral{3D}{\isacharequal}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1248
\ \ \ \ Buffer{\isaliteral{2E}{\isachardot}}empty\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ add{\isaliteral{5F}{\isacharunderscore}}content\ tree\ {\isaliteral{7C}{\isacharbar}}{\isaliteral{3E}{\isachargreater}}\ Buffer{\isaliteral{2E}{\isachardot}}content{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1249
{\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1250
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1251
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1252
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1253
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1254
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1255
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1256
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1257
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1258
The slow part of \verb|slow_content| is the \verb|implode| of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1259
  the recursive results, because it copies previously produced strings
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1260
  again.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1261
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1262
  The incremental \verb|add_content| avoids this by operating on a
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1263
  buffer that is passed through in a linear fashion.  Using \verb|#>| and contraction over the actual buffer argument saves some
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1264
  additional boiler-plate.  Of course, the two \verb|Buffer.add|
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1265
  invocations with concatenated strings could have been split into
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1266
  smaller parts, but this would have obfuscated the source without
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1267
  making a big difference in allocations.  Here we have done some
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1268
  peephole-optimization for the sake of readability.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1269
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1270
  Another benefit of \verb|add_content| is its ``open'' form as a
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1271
  function on buffers that can be continued in further linear
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1272
  transformations, folding etc.  Thus it is more compositional than
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1273
  the naive \verb|slow_content|.  As realistic example, compare the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1274
  old-style \verb|Term.maxidx_of_term: term -> int| with the newer
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1275
  \verb|Term.maxidx_term: term -> int -> int| in Isabelle/Pure.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1276
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1277
  Note that \verb|fast_content| above is only defined as example.  In
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1278
  many practical situations, it is customary to provide the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1279
  incremental \verb|add_content| only and leave the initialization and
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1280
  termination to the concrete application by the user.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1281
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1282
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1283
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1284
\isamarkupsection{Message output channels \label{sec:message-channels}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1285
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1286
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1287
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1288
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1289
Isabelle provides output channels for different kinds of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1290
  messages: regular output, high-volume tracing information, warnings,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1291
  and errors.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1292
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1293
  Depending on the user interface involved, these messages may appear
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1294
  in different text styles or colours.  The standard output for
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1295
  terminal sessions prefixes each line of warnings by \verb|###| and errors by \verb|***|, but leaves anything else
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1296
  unchanged.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1297
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1298
  Messages are associated with the transaction context of the running
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1299
  Isar command.  This enables the front-end to manage commands and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1300
  resulting messages together.  For example, after deleting a command
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1301
  from a given theory document version, the corresponding message
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1302
  output can be retracted from the display.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1303
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1304
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1305
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1306
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1307
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1308
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1309
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1310
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1311
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1312
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1313
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1314
  \indexdef{}{ML}{writeln}\verb|writeln: string -> unit| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1315
  \indexdef{}{ML}{tracing}\verb|tracing: string -> unit| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1316
  \indexdef{}{ML}{warning}\verb|warning: string -> unit| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1317
  \indexdef{}{ML}{error}\verb|error: string -> 'a| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1318
  \end{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1319
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1320
  \begin{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1321
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1322
  \item \verb|writeln|~\isa{text} outputs \isa{text} as regular
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1323
  message.  This is the primary message output operation of Isabelle
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1324
  and should be used by default.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1325
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1326
  \item \verb|tracing|~\isa{text} outputs \isa{text} as special
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1327
  tracing message, indicating potential high-volume output to the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1328
  front-end (hundreds or thousands of messages issued by a single
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1329
  command).  The idea is to allow the user-interface to downgrade the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1330
  quality of message display to achieve higher throughput.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1331
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1332
  Note that the user might have to take special actions to see tracing
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1333
  output, e.g.\ switch to a different output window.  So this channel
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1334
  should not be used for regular output.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1335
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1336
  \item \verb|warning|~\isa{text} outputs \isa{text} as
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1337
  warning, which typically means some extra emphasis on the front-end
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1338
  side (color highlighting, icons, etc.).
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1339
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1340
  \item \verb|error|~\isa{text} raises exception \verb|ERROR|~\isa{text} and thus lets the Isar toplevel print \isa{text} on the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1341
  error channel, which typically means some extra emphasis on the
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1342
  front-end side (color highlighting, icons, etc.).
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1343
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1344
  This assumes that the exception is not handled before the command
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1345
  terminates.  Handling exception \verb|ERROR|~\isa{text} is a
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1346
  perfectly legal alternative: it means that the error is absorbed
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1347
  without any message output.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1348
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1349
  \begin{warn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1350
  The actual error channel is accessed via \verb|Output.error_msg|, but
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1351
  the interaction protocol of Proof~General \emph{crashes} if that
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1352
  function is used in regular ML code: error output and toplevel
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1353
  command failure always need to coincide.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1354
  \end{warn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1355
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1356
  \end{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1357
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1358
  \begin{warn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1359
  Regular Isabelle/ML code should output messages exclusively by the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1360
  official channels.  Using raw I/O on \emph{stdout} or \emph{stderr}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1361
  instead (e.g.\ via \verb|TextIO.output|) is apt to cause problems in
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1362
  the presence of parallel and asynchronous processing of Isabelle
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1363
  theories.  Such raw output might be displayed by the front-end in
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1364
  some system console log, with a low chance that the user will ever
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1365
  see it.  Moreover, as a genuine side-effect on global process
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1366
  channels, there is no proper way to retract output when Isar command
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1367
  transactions are reset by the system.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1368
  \end{warn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1369
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1370
  \begin{warn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1371
  The message channels should be used in a message-oriented manner.
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1372
  This means that multi-line output that logically belongs together is
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1373
  issued by a \emph{single} invocation of \verb|writeln| etc.\ with the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1374
  functional concatenation of all message constituents.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1375
  \end{warn}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1376
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1377
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1378
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1379
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1380
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1381
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1382
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1383
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1384
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1385
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1386
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1387
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1388
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1389
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1390
\isatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1391
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1392
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1393
The following example demonstrates a multi-line
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1394
  warning.  Note that in some situations the user sees only the first
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1395
  line, so the most important point should be made first.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1396
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1397
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1398
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1399
\endisatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1400
{\isafoldmlex}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1401
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1402
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1403
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1404
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1405
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1406
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1407
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1408
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1409
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1410
\isatagML
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1411
\isacommand{ML{\isaliteral{5F}{\isacharunderscore}}command}\isamarkupfalse%
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1412
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1413
\ \ warning\ {\isaliteral{28}{\isacharparenleft}}cat{\isaliteral{5F}{\isacharunderscore}}lines\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1414
\ \ \ {\isaliteral{5B}{\isacharbrackleft}}{\isaliteral{22}{\isachardoublequote}}Beware\ the\ Jabberwock{\isaliteral{2C}{\isacharcomma}}\ my\ son{\isaliteral{21}{\isacharbang}}{\isaliteral{22}{\isachardoublequote}}{\isaliteral{2C}{\isacharcomma}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1415
\ \ \ \ {\isaliteral{22}{\isachardoublequote}}The\ jaws\ that\ bite{\isaliteral{2C}{\isacharcomma}}\ the\ claws\ that\ catch{\isaliteral{21}{\isacharbang}}{\isaliteral{22}{\isachardoublequote}}{\isaliteral{2C}{\isacharcomma}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1416
\ \ \ \ {\isaliteral{22}{\isachardoublequote}}Beware\ the\ Jubjub\ Bird{\isaliteral{2C}{\isacharcomma}}\ and\ shun{\isaliteral{22}{\isachardoublequote}}{\isaliteral{2C}{\isacharcomma}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1417
\ \ \ \ {\isaliteral{22}{\isachardoublequote}}The\ frumious\ Bandersnatch{\isaliteral{21}{\isacharbang}}{\isaliteral{22}{\isachardoublequote}}{\isaliteral{5D}{\isacharbrackright}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1418
{\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1419
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1420
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1421
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1422
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1423
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1424
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1425
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1426
\isamarkupsection{Exceptions \label{sec:exceptions}%
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  1427
}
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  1428
\isamarkuptrue%
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  1429
%
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  1430
\begin{isamarkuptext}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1431
The Standard ML semantics of strict functional evaluation
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1432
  together with exceptions is rather well defined, but some delicate
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1433
  points need to be observed to avoid that ML programs go wrong
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1434
  despite static type-checking.  Exceptions in Isabelle/ML are
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1435
  subsequently categorized as follows.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1436
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1437
  \paragraph{Regular user errors.}  These are meant to provide
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1438
  informative feedback about malformed input etc.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1439
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1440
  The \emph{error} function raises the corresponding \emph{ERROR}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1441
  exception, with a plain text message as argument.  \emph{ERROR}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1442
  exceptions can be handled internally, in order to be ignored, turned
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1443
  into other exceptions, or cascaded by appending messages.  If the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1444
  corresponding Isabelle/Isar command terminates with an \emph{ERROR}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1445
  exception state, the toplevel will print the result on the error
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1446
  channel (see \secref{sec:message-channels}).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1447
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1448
  It is considered bad style to refer to internal function names or
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1449
  values in ML source notation in user error messages.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1450
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1451
  Grammatical correctness of error messages can be improved by
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1452
  \emph{omitting} final punctuation: messages are often concatenated
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1453
  or put into a larger context (e.g.\ augmented with source position).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1454
  By not insisting in the final word at the origin of the error, the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1455
  system can perform its administrative tasks more easily and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1456
  robustly.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1457
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1458
  \paragraph{Program failures.}  There is a handful of standard
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1459
  exceptions that indicate general failure situations, or failures of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1460
  core operations on logical entities (types, terms, theorems,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1461
  theories, see \chref{ch:logic}).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1462
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1463
  These exceptions indicate a genuine breakdown of the program, so the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1464
  main purpose is to determine quickly what has happened where.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1465
  Traditionally, the (short) exception message would include the name
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1466
  of an ML function, although this is no longer necessary, because the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1467
  ML runtime system prints a detailed source position of the
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1468
  corresponding \verb|raise| keyword.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1469
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1470
  \medskip User modules can always introduce their own custom
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1471
  exceptions locally, e.g.\ to organize internal failures robustly
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1472
  without overlapping with existing exceptions.  Exceptions that are
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1473
  exposed in module signatures require extra care, though, and should
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1474
  \emph{not} be introduced by default.  Surprise by users of a module
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1475
  can be often minimized by using plain user errors instead.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1476
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1477
  \paragraph{Interrupts.}  These indicate arbitrary system events:
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1478
  both the ML runtime system and the Isabelle/ML infrastructure signal
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1479
  various exceptional situations by raising the special
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1480
  \emph{Interrupt} exception in user code.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1481
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1482
  This is the one and only way that physical events can intrude an
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1483
  Isabelle/ML program.  Such an interrupt can mean out-of-memory,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1484
  stack overflow, timeout, internal signaling of threads, or the user
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1485
  producing a console interrupt manually etc.  An Isabelle/ML program
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1486
  that intercepts interrupts becomes dependent on physical effects of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1487
  the environment.  Even worse, exception handling patterns that are
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1488
  too general by accident, e.g.\ by mispelled exception constructors,
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1489
  will cover interrupts unintentionally and thus render the program
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1490
  semantics ill-defined.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1491
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1492
  Note that the Interrupt exception dates back to the original SML90
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1493
  language definition.  It was excluded from the SML97 version to
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1494
  avoid its malign impact on ML program semantics, but without
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1495
  providing a viable alternative.  Isabelle/ML recovers physical
40229
wenzelm
parents: 40153
diff changeset
  1496
  interruptibility (which is an indispensable tool to implement
wenzelm
parents: 40153
diff changeset
  1497
  managed evaluation of command transactions), but requires user code
wenzelm
parents: 40153
diff changeset
  1498
  to be strictly transparent wrt.\ interrupts.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1499
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1500
  \begin{warn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1501
  Isabelle/ML user code needs to terminate promptly on interruption,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1502
  without guessing at its meaning to the system infrastructure.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1503
  Temporary handling of interrupts for cleanup of global resources
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1504
  etc.\ needs to be followed immediately by re-raising of the original
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1505
  exception.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1506
  \end{warn}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1507
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1508
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1509
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1510
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1511
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1512
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1513
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1514
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1515
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1516
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1517
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1518
  \indexdef{}{ML}{try}\verb|try: ('a -> 'b) -> 'a -> 'b option| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1519
  \indexdef{}{ML}{can}\verb|can: ('a -> 'b) -> 'a -> bool| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1520
  \indexdef{}{ML}{ERROR}\verb|ERROR: string -> exn| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1521
  \indexdef{}{ML}{Fail}\verb|Fail: string -> exn| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1522
  \indexdef{}{ML}{Exn.is\_interrupt}\verb|Exn.is_interrupt: exn -> bool| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1523
  \indexdef{}{ML}{reraise}\verb|reraise: exn -> 'a| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1524
  \indexdef{}{ML}{exception\_trace}\verb|exception_trace: (unit -> 'a) -> 'a| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1525
  \end{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1526
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1527
  \begin{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1528
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1529
  \item \verb|try|~\isa{f\ x} makes the partiality of evaluating
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1530
  \isa{f\ x} explicit via the option datatype.  Interrupts are
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1531
  \emph{not} handled here, i.e.\ this form serves as safe replacement
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1532
  for the \emph{unsafe} version \verb|(SOME|~\isa{f\ x}~\verb|handle _ => NONE)| that is occasionally seen in
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1533
  books about SML.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1534
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1535
  \item \verb|can| is similar to \verb|try| with more abstract result.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1536
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1537
  \item \verb|ERROR|~\isa{msg} represents user errors; this
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1538
  exception is normally raised indirectly via the \verb|error| function
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1539
  (see \secref{sec:message-channels}).
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1540
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1541
  \item \verb|Fail|~\isa{msg} represents general program failures.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1542
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1543
  \item \verb|Exn.is_interrupt| identifies interrupts robustly, without
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1544
  mentioning concrete exception constructors in user code.  Handled
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1545
  interrupts need to be re-raised promptly!
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1546
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1547
  \item \verb|reraise|~\isa{exn} raises exception \isa{exn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1548
  while preserving its implicit position information (if possible,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1549
  depending on the ML platform).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1550
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1551
  \item \verb|exception_trace|~\verb|(fn () =>|~\isa{e}\verb|)| evaluates expression \isa{e} while printing
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1552
  a full trace of its stack of nested exceptions (if possible,
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1553
  depending on the ML platform).\footnote{In versions of Poly/ML the
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1554
  trace will appear on raw stdout of the Isabelle process.}
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1555
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1556
  Inserting \verb|exception_trace| into ML code temporarily is useful
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1557
  for debugging, but not suitable for production code.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1558
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1559
  \end{description}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1560
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1561
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1562
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1563
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1564
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1565
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1566
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1567
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1568
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1569
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1570
\isadelimmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1571
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1572
\endisadelimmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1573
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1574
\isatagmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1575
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1576
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1577
\begin{matharray}{rcl}
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1578
  \indexdef{}{ML antiquotation}{assert}\hypertarget{ML antiquotation.assert}{\hyperlink{ML antiquotation.assert}{\mbox{\isa{assert}}}} & : & \isa{ML{\isaliteral{5F}{\isacharunderscore}}antiquotation} \\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1579
  \end{matharray}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1580
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1581
  \begin{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1582
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1583
  \item \isa{{\isaliteral{40}{\isacharat}}{\isaliteral{7B}{\isacharbraceleft}}assert{\isaliteral{7D}{\isacharbraceright}}} inlines a function
40110
93e7935d4cb5 added ML antiquotation @{assert};
wenzelm
parents: 39885
diff changeset
  1584
  \verb|bool -> unit| that raises \verb|Fail| if the argument is
93e7935d4cb5 added ML antiquotation @{assert};
wenzelm
parents: 39885
diff changeset
  1585
  \verb|false|.  Due to inlining the source position of failed
93e7935d4cb5 added ML antiquotation @{assert};
wenzelm
parents: 39885
diff changeset
  1586
  assertions is included in the error output.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1587
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1588
  \end{description}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1589
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1590
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1591
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1592
\endisatagmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1593
{\isafoldmlantiq}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1594
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1595
\isadelimmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1596
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1597
\endisadelimmlantiq
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1598
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1599
\isamarkupsection{Basic data types%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1600
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1601
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1602
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1603
\begin{isamarkuptext}%
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1604
The basis library proposal of SML97 needs to be treated with
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1605
  caution.  Many of its operations simply do not fit with important
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1606
  Isabelle/ML conventions (like ``canonical argument order'', see
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1607
  \secref{sec:canonical-argument-order}), others cause problems with
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1608
  the parallel evaluation model of Isabelle/ML (such as \verb|TextIO.print| or \verb|OS.Process.system|).
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1609
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1610
  Subsequently we give a brief overview of important operations on
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1611
  basic ML data types.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1612
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1613
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1614
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1615
\isamarkupsubsection{Characters%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1616
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1617
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1618
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1619
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1620
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1621
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1622
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1623
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1624
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1625
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1626
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1627
  \indexdef{}{ML type}{char}\verb|type char| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1628
  \end{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1629
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1630
  \begin{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1631
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1632
  \item Type \verb|char| is \emph{not} used.  The smallest textual
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1633
  unit in Isabelle is represented as a ``symbol'' (see
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1634
  \secref{sec:symbols}).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1635
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1636
  \end{description}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1637
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1638
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1639
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1640
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1641
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1642
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1643
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1644
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1645
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1646
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1647
\isamarkupsubsection{Integers%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1648
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1649
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1650
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1651
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1652
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1653
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1654
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1655
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1656
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1657
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1658
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1659
  \indexdef{}{ML type}{int}\verb|type int| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1660
  \end{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1661
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1662
  \begin{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1663
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1664
  \item Type \verb|int| represents regular mathematical integers,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1665
  which are \emph{unbounded}.  Overflow never happens in
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1666
  practice.\footnote{The size limit for integer bit patterns in memory
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1667
  is 64\,MB for 32-bit Poly/ML, and much higher for 64-bit systems.}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1668
  This works uniformly for all supported ML platforms (Poly/ML and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1669
  SML/NJ).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1670
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1671
  Literal integers in ML text are forced to be of this one true
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1672
  integer type --- overloading of SML97 is disabled.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1673
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1674
  Structure \verb|IntInf| of SML97 is obsolete and superseded by
40802
3cd23f676c5b updated generated files;
wenzelm
parents: 40508
diff changeset
  1675
  \verb|Int|.  Structure \verb|Integer| in \verb|~~/src/Pure/General/integer.ML| provides some additional
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1676
  operations.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  1677
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1678
  \end{description}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1679
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1680
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1681
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1682
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1683
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1684
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1685
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1686
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1687
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1688
%
40302
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1689
\isamarkupsubsection{Time%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1690
}
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1691
\isamarkuptrue%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1692
%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1693
\isadelimmlref
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1694
%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1695
\endisadelimmlref
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1696
%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1697
\isatagmlref
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1698
%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1699
\begin{isamarkuptext}%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1700
\begin{mldecls}
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1701
  \indexdef{}{ML type}{Time.time}\verb|type Time.time| \\
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1702
  \indexdef{}{ML}{seconds}\verb|seconds: real -> Time.time| \\
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1703
  \end{mldecls}
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1704
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1705
  \begin{description}
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1706
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1707
  \item Type \verb|Time.time| represents time abstractly according
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1708
  to the SML97 basis library definition.  This is adequate for
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1709
  internal ML operations, but awkward in concrete time specifications.
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1710
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1711
  \item \verb|seconds|~\isa{s} turns the concrete scalar \isa{s} (measured in seconds) into an abstract time value.  Floating
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1712
  point numbers are easy to use as context parameters (e.g.\ via
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1713
  configuration options, see \secref{sec:config-options}) or
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1714
  preferences that are maintained by external tools as well.
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1715
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1716
  \end{description}%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1717
\end{isamarkuptext}%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1718
\isamarkuptrue%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1719
%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1720
\endisatagmlref
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1721
{\isafoldmlref}%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1722
%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1723
\isadelimmlref
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1724
%
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1725
\endisadelimmlref
2a33038d858b more on "Time" in Isabelle/ML;
wenzelm
parents: 40229
diff changeset
  1726
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1727
\isamarkupsubsection{Options%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1728
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1729
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1730
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1731
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1732
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1733
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1734
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1735
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1736
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1737
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1738
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1739
  \indexdef{}{ML}{Option.map}\verb|Option.map: ('a -> 'b) -> 'a option -> 'b option| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1740
  \indexdef{}{ML}{is\_some}\verb|is_some: 'a option -> bool| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1741
  \indexdef{}{ML}{is\_none}\verb|is_none: 'a option -> bool| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1742
  \indexdef{}{ML}{the}\verb|the: 'a option -> 'a| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1743
  \indexdef{}{ML}{these}\verb|these: 'a list option -> 'a list| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1744
  \indexdef{}{ML}{the\_list}\verb|the_list: 'a option -> 'a list| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1745
  \indexdef{}{ML}{the\_default}\verb|the_default: 'a -> 'a option -> 'a| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1746
  \end{mldecls}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1747
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1748
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1749
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1750
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1751
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1752
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1753
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1754
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1755
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1756
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1757
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1758
Apart from \verb|Option.map| most operations defined in
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1759
  structure \verb|Option| are alien to Isabelle/ML.  The
40802
3cd23f676c5b updated generated files;
wenzelm
parents: 40508
diff changeset
  1760
  operations shown above are defined in \verb|~~/src/Pure/General/basics.ML|, among others.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1761
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1762
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1763
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1764
\isamarkupsubsection{Lists%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1765
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1766
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1767
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1768
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1769
Lists are ubiquitous in ML as simple and light-weight
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1770
  ``collections'' for many everyday programming tasks.  Isabelle/ML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1771
  provides important additions and improvements over operations that
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1772
  are predefined in the SML97 library.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1773
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1774
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1775
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1776
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1777
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1778
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1779
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1780
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1781
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1782
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1783
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1784
  \indexdef{}{ML}{cons}\verb|cons: 'a -> 'a list -> 'a list| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1785
  \indexdef{}{ML}{member}\verb|member: ('b * 'a -> bool) -> 'a list -> 'b -> bool| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1786
  \indexdef{}{ML}{insert}\verb|insert: ('a * 'a -> bool) -> 'a -> 'a list -> 'a list| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1787
  \indexdef{}{ML}{remove}\verb|remove: ('b * 'a -> bool) -> 'b -> 'a list -> 'a list| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1788
  \indexdef{}{ML}{update}\verb|update: ('a * 'a -> bool) -> 'a -> 'a list -> 'a list| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1789
  \end{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1790
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1791
  \begin{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1792
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1793
  \item \verb|cons|~\isa{x\ xs} evaluates to \isa{x\ {\isaliteral{3A}{\isacharcolon}}{\isaliteral{3A}{\isacharcolon}}\ xs}.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1794
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1795
  Tupled infix operators are a historical accident in Standard ML.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1796
  The curried \verb|cons| amends this, but it should be only used when
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1797
  partial application is required.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1798
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1799
  \item \verb|member|, \verb|insert|, \verb|remove|, \verb|update| treat
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1800
  lists as a set-like container that maintains the order of elements.
40802
3cd23f676c5b updated generated files;
wenzelm
parents: 40508
diff changeset
  1801
  See \verb|~~/src/Pure/library.ML| for the full specifications
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1802
  (written in ML).  There are some further derived operations like
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1803
  \verb|union| or \verb|inter|.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1804
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1805
  Note that \verb|insert| is conservative about elements that are
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1806
  already a \verb|member| of the list, while \verb|update| ensures that
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1807
  the latest entry is always put in front.  The latter discipline is
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1808
  often more appropriate in declarations of context data
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1809
  (\secref{sec:context-data}) that are issued by the user in Isar
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1810
  source: more recent declarations normally take precedence over
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1811
  earlier ones.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  1812
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1813
  \end{description}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1814
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1815
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1816
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1817
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1818
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1819
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1820
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1821
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1822
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1823
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1824
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1825
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1826
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1827
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1828
\isatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1829
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1830
\begin{isamarkuptext}%
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1831
Using canonical \verb|fold| together with \verb|cons|, or
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1832
  similar standard operations, alternates the orientation of data.
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1833
  The is quite natural and should not be altered forcible by inserting
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1834
  extra applications of \verb|rev|.  The alternative \verb|fold_rev| can
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1835
  be used in the few situations, where alternation should be
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1836
  prevented.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1837
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1838
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1839
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1840
\endisatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1841
{\isafoldmlex}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1842
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1843
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1844
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1845
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1846
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1847
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1848
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1849
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1850
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1851
\isatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1852
\isacommand{ML}\isamarkupfalse%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1853
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1854
\ \ val\ items\ {\isaliteral{3D}{\isacharequal}}\ {\isaliteral{5B}{\isacharbrackleft}}{\isadigit{1}}{\isaliteral{2C}{\isacharcomma}}\ {\isadigit{2}}{\isaliteral{2C}{\isacharcomma}}\ {\isadigit{3}}{\isaliteral{2C}{\isacharcomma}}\ {\isadigit{4}}{\isaliteral{2C}{\isacharcomma}}\ {\isadigit{5}}{\isaliteral{2C}{\isacharcomma}}\ {\isadigit{6}}{\isaliteral{2C}{\isacharcomma}}\ {\isadigit{7}}{\isaliteral{2C}{\isacharcomma}}\ {\isadigit{8}}{\isaliteral{2C}{\isacharcomma}}\ {\isadigit{9}}{\isaliteral{2C}{\isacharcomma}}\ {\isadigit{1}}{\isadigit{0}}{\isaliteral{5D}{\isacharbrackright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1855
\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1856
\ \ val\ list{\isadigit{1}}\ {\isaliteral{3D}{\isacharequal}}\ fold\ cons\ items\ {\isaliteral{5B}{\isacharbrackleft}}{\isaliteral{5D}{\isacharbrackright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1857
\ \ %
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1858
\isaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1859
assert{}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1860
\endisaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1861
\ {\isaliteral{28}{\isacharparenleft}}list{\isadigit{1}}\ {\isaliteral{3D}{\isacharequal}}\ rev\ items{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1862
\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1863
\ \ val\ list{\isadigit{2}}\ {\isaliteral{3D}{\isacharequal}}\ fold{\isaliteral{5F}{\isacharunderscore}}rev\ cons\ items\ {\isaliteral{5B}{\isacharbrackleft}}{\isaliteral{5D}{\isacharbrackright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1864
\ \ %
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1865
\isaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1866
assert{}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1867
\endisaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1868
\ {\isaliteral{28}{\isacharparenleft}}list{\isadigit{2}}\ {\isaliteral{3D}{\isacharequal}}\ items{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1869
{\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1870
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1871
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1872
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1873
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1874
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1875
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1876
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1877
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1878
The subsequent example demonstrates how to \emph{merge} two
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1879
  lists in a natural way.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1880
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1881
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1882
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1883
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1884
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1885
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1886
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1887
\isatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1888
\isacommand{ML}\isamarkupfalse%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1889
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1890
\ \ fun\ merge{\isaliteral{5F}{\isacharunderscore}}lists\ eq\ {\isaliteral{28}{\isacharparenleft}}xs{\isaliteral{2C}{\isacharcomma}}\ ys{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{3D}{\isacharequal}}\ fold{\isaliteral{5F}{\isacharunderscore}}rev\ {\isaliteral{28}{\isacharparenleft}}insert\ eq{\isaliteral{29}{\isacharparenright}}\ ys\ xs{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1891
{\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1892
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1893
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1894
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1895
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1896
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1897
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1898
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1899
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1900
Here the first list is treated conservatively: only the new
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1901
  elements from the second list are inserted.  The inside-out order of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1902
  insertion via \verb|fold_rev| attempts to preserve the order of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1903
  elements in the result.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1904
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1905
  This way of merging lists is typical for context data
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1906
  (\secref{sec:context-data}).  See also \verb|merge| as defined in
40802
3cd23f676c5b updated generated files;
wenzelm
parents: 40508
diff changeset
  1907
  \verb|~~/src/Pure/library.ML|.%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1908
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1909
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1910
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1911
\isamarkupsubsection{Association lists%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1912
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1913
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1914
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1915
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1916
The operations for association lists interpret a concrete list
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1917
  of pairs as a finite function from keys to values.  Redundant
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1918
  representations with multiple occurrences of the same key are
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1919
  implicitly normalized: lookup and update only take the first
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1920
  occurrence into account.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1921
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1922
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1923
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1924
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1925
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1926
  \indexdef{}{ML}{AList.lookup}\verb|AList.lookup: ('a * 'b -> bool) -> ('b * 'c) list -> 'a -> 'c option| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1927
  \indexdef{}{ML}{AList.defined}\verb|AList.defined: ('a * 'b -> bool) -> ('b * 'c) list -> 'a -> bool| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1928
  \indexdef{}{ML}{AList.update}\verb|AList.update: ('a * 'a -> bool) -> 'a * 'b -> ('a * 'b) list -> ('a * 'b) list| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1929
  \end{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1930
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1931
  \begin{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1932
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1933
  \item \verb|AList.lookup|, \verb|AList.defined|, \verb|AList.update|
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1934
  implement the main ``framework operations'' for mappings in
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1935
  Isabelle/ML, following standard conventions for their names and
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  1936
  types.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1937
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1938
  Note that a function called \isa{lookup} is obliged to express its
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1939
  partiality via an explicit option element.  There is no choice to
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1940
  raise an exception, without changing the name to something like
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  1941
  \isa{the{\isaliteral{5F}{\isacharunderscore}}element} or \isa{get}.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1942
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1943
  The \isa{defined} operation is essentially a contraction of \verb|is_some| and \isa{lookup}, but this is sufficiently frequent to
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1944
  justify its independent existence.  This also gives the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1945
  implementation some opportunity for peep-hole optimization.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1946
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1947
  \end{description}
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  1948
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1949
  Association lists are adequate as simple and light-weight
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1950
  implementation of finite mappings in many practical situations.  A
40802
3cd23f676c5b updated generated files;
wenzelm
parents: 40508
diff changeset
  1951
  more heavy-duty table structure is defined in \verb|~~/src/Pure/General/table.ML|; that version scales easily to
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1952
  thousands or millions of elements.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1953
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1954
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1955
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1956
\isamarkupsubsection{Unsynchronized references%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1957
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1958
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1959
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1960
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1961
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1962
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1963
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1964
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1965
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1966
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1967
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1968
  \indexdef{}{ML type}{Unsynchronized.ref}\verb|type 'a Unsynchronized.ref| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1969
  \indexdef{}{ML}{Unsynchronized.ref}\verb|Unsynchronized.ref: 'a -> 'a Unsynchronized.ref| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1970
  \indexdef{}{ML}{!}\verb|! : 'a Unsynchronized.ref -> 'a| \\
46262
912b42e64fde tuned ML infixes;
wenzelm
parents: 42665
diff changeset
  1971
  \indexdef{}{ML infix}{:=}\verb|infix := : 'a Unsynchronized.ref * 'a -> unit| \\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1972
  \end{mldecls}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1973
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1974
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1975
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1976
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1977
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1978
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1979
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1980
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1981
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1982
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1983
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1984
Due to ubiquitous parallelism in Isabelle/ML (see also
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1985
  \secref{sec:multi-threading}), the mutable reference cells of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1986
  Standard ML are notorious for causing problems.  In a highly
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1987
  parallel system, both correctness \emph{and} performance are easily
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1988
  degraded when using mutable data.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1989
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1990
  The unwieldy name of \verb|Unsynchronized.ref| for the constructor
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1991
  for references in Isabelle/ML emphasizes the inconveniences caused by
46262
912b42e64fde tuned ML infixes;
wenzelm
parents: 42665
diff changeset
  1992
  mutability.  Existing operations \verb|!|  and \verb|:=| are
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1993
  unchanged, but should be used with special precautions, say in a
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  1994
  strictly local situation that is guaranteed to be restricted to
40508
76894f975440 never open Unsynchronized;
wenzelm
parents: 40406
diff changeset
  1995
  sequential evaluation --- now and in the future.
76894f975440 never open Unsynchronized;
wenzelm
parents: 40406
diff changeset
  1996
76894f975440 never open Unsynchronized;
wenzelm
parents: 40406
diff changeset
  1997
  \begin{warn}
76894f975440 never open Unsynchronized;
wenzelm
parents: 40406
diff changeset
  1998
  Never \verb|open Unsynchronized|, not even in a local scope!
76894f975440 never open Unsynchronized;
wenzelm
parents: 40406
diff changeset
  1999
  Pretending that mutable state is no problem is a very bad idea.
76894f975440 never open Unsynchronized;
wenzelm
parents: 40406
diff changeset
  2000
  \end{warn}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2001
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2002
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2003
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2004
\isamarkupsection{Thread-safe programming \label{sec:multi-threading}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2005
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2006
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2007
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2008
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2009
Multi-threaded execution has become an everyday reality in
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2010
  Isabelle since Poly/ML 5.2.1 and Isabelle2008.  Isabelle/ML provides
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2011
  implicit and explicit parallelism by default, and there is no way
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2012
  for user-space tools to ``opt out''.  ML programs that are purely
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2013
  functional, output messages only via the official channels
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2014
  (\secref{sec:message-channels}), and do not intercept interrupts
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2015
  (\secref{sec:exceptions}) can participate in the multi-threaded
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2016
  environment immediately without further ado.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2017
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2018
  More ambitious tools with more fine-grained interaction with the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2019
  environment need to observe the principles explained below.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2020
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2021
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2022
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2023
\isamarkupsubsection{Multi-threading with shared memory%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2024
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2025
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2026
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2027
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2028
Multiple threads help to organize advanced operations of the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2029
  system, such as real-time conditions on command transactions,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2030
  sub-components with explicit communication, general asynchronous
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2031
  interaction etc.  Moreover, parallel evaluation is a prerequisite to
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2032
  make adequate use of the CPU resources that are available on
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2033
  multi-core systems.\footnote{Multi-core computing does not mean that
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2034
  there are ``spare cycles'' to be wasted.  It means that the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2035
  continued exponential speedup of CPU performance due to ``Moore's
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2036
  Law'' follows different rules: clock frequency has reached its peak
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2037
  around 2005, and applications need to be parallelized in order to
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2038
  avoid a perceived loss of performance.  See also
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2039
  \cite{Sutter:2005}.}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2040
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2041
  Isabelle/Isar exploits the inherent structure of theories and proofs
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2042
  to support \emph{implicit parallelism} to a large extent.  LCF-style
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2043
  theorem provides almost ideal conditions for that, see also
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2044
  \cite{Wenzel:2009}.  This means, significant parts of theory and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2045
  proof checking is parallelized by default.  A maximum speedup-factor
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2046
  of 3.0 on 4 cores and 5.0 on 8 cores can be
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2047
  expected.\footnote{Further scalability is limited due to garbage
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2048
  collection, which is still sequential in Poly/ML 5.2/5.3/5.4.  It
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2049
  helps to provide initial heap space generously, using the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2050
  \texttt{-H} option.  Initial heap size needs to be scaled-up
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2051
  together with the number of CPU cores: approximately 1--2\,GB per
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2052
  core..}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2053
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2054
  \medskip ML threads lack the memory protection of separate
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2055
  processes, and operate concurrently on shared heap memory.  This has
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2056
  the advantage that results of independent computations are directly
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2057
  available to other threads: abstract values can be passed without
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2058
  copying or awkward serialization that is typically required for
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2059
  separate processes.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2060
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2061
  To make shared-memory multi-threading work robustly and efficiently,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2062
  some programming guidelines need to be observed.  While the ML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2063
  system is responsible to maintain basic integrity of the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2064
  representation of ML values in memory, the application programmer
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2065
  needs to ensure that multi-threaded execution does not break the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2066
  intended semantics.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2067
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2068
  \begin{warn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2069
  To participate in implicit parallelism, tools need to be
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2070
  thread-safe.  A single ill-behaved tool can affect the stability and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2071
  performance of the whole system.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2072
  \end{warn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2073
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2074
  Apart from observing the principles of thread-safeness passively,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2075
  advanced tools may also exploit parallelism actively, e.g.\ by using
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2076
  ``future values'' (\secref{sec:futures}) or the more basic library
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2077
  functions for parallel list operations (\secref{sec:parlist}).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2078
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2079
  \begin{warn}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2080
  Parallel computing resources are managed centrally by the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2081
  Isabelle/ML infrastructure.  User programs must not fork their own
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2082
  ML threads to perform computations.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2083
  \end{warn}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2084
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2085
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2086
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2087
\isamarkupsubsection{Critical shared resources%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2088
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2089
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2090
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2091
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2092
Thread-safeness is mainly concerned about concurrent
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2093
  read/write access to shared resources, which are outside the purely
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2094
  functional world of ML.  This covers the following in particular.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2095
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2096
  \begin{itemize}
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2097
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2098
  \item Global references (or arrays), i.e.\ mutable memory cells that
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2099
  persist over several invocations of associated
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2100
  operations.\footnote{This is independent of the visibility of such
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2101
  mutable values in the toplevel scope.}
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2102
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2103
  \item Global state of the running Isabelle/ML process, i.e.\ raw I/O
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2104
  channels, environment variables, current working directory.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2105
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2106
  \item Writable resources in the file-system that are shared among
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2107
  different threads or external processes.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2108
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2109
  \end{itemize}
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2110
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2111
  Isabelle/ML provides various mechanisms to avoid critical shared
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2112
  resources in most situations.  As last resort there are some
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2113
  mechanisms for explicit synchronization.  The following guidelines
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2114
  help to make Isabelle/ML programs work smoothly in a concurrent
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2115
  environment.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2116
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2117
  \begin{itemize}
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2118
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2119
  \item Avoid global references altogether.  Isabelle/Isar maintains a
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2120
  uniform context that incorporates arbitrary data declared by user
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2121
  programs (\secref{sec:context-data}).  This context is passed as
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2122
  plain value and user tools can get/map their own data in a purely
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2123
  functional manner.  Configuration options within the context
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2124
  (\secref{sec:config-options}) provide simple drop-in replacements
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2125
  for historic reference variables.
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2126
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2127
  \item Keep components with local state information re-entrant.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2128
  Instead of poking initial values into (private) global references, a
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2129
  new state record can be created on each invocation, and passed
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2130
  through any auxiliary functions of the component.  The state record
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2131
  may well contain mutable references, without requiring any special
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2132
  synchronizations, as long as each invocation gets its own copy.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2133
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2134
  \item Avoid raw output on \isa{stdout} or \isa{stderr}.  The
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2135
  Poly/ML library is thread-safe for each individual output operation,
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2136
  but the ordering of parallel invocations is arbitrary.  This means
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2137
  raw output will appear on some system console with unpredictable
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2138
  interleaving of atomic chunks.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2139
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2140
  Note that this does not affect regular message output channels
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2141
  (\secref{sec:message-channels}).  An official message is associated
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2142
  with the command transaction from where it originates, independently
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2143
  of other transactions.  This means each running Isar command has
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2144
  effectively its own set of message channels, and interleaving can
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2145
  only happen when commands use parallelism internally (and only at
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2146
  message boundaries).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2147
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2148
  \item Treat environment variables and the current working directory
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2149
  of the running process as strictly read-only.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2150
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2151
  \item Restrict writing to the file-system to unique temporary files.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2152
  Isabelle already provides a temporary directory that is unique for
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2153
  the running process, and there is a centralized source of unique
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2154
  serial numbers in Isabelle/ML.  Thus temporary files that are passed
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2155
  to to some external process will be always disjoint, and thus
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2156
  thread-safe.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2157
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2158
  \end{itemize}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2159
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2160
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2161
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2162
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2163
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2164
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2165
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2166
\isatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2167
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2168
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2169
\begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2170
  \indexdef{}{ML}{File.tmp\_path}\verb|File.tmp_path: Path.T -> Path.T| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2171
  \indexdef{}{ML}{serial\_string}\verb|serial_string: unit -> string| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2172
  \end{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2173
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2174
  \begin{description}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2175
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2176
  \item \verb|File.tmp_path|~\isa{path} relocates the base
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2177
  component of \isa{path} into the unique temporary directory of
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2178
  the running Isabelle/ML process.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2179
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2180
  \item \verb|serial_string|~\isa{{\isaliteral{28}{\isacharparenleft}}{\isaliteral{29}{\isacharparenright}}} creates a new serial number
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2181
  that is unique over the runtime of the Isabelle/ML process.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2182
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2183
  \end{description}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2184
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2185
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2186
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2187
\endisatagmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2188
{\isafoldmlref}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2189
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2190
\isadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2191
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2192
\endisadelimmlref
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2193
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2194
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2195
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2196
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2197
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2198
\isatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2199
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2200
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2201
The following example shows how to create unique
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2202
  temporary file names.%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2203
\end{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2204
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2205
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2206
\endisatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2207
{\isafoldmlex}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2208
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2209
\isadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2210
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2211
\endisadelimmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2212
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2213
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2214
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2215
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2216
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2217
\isatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2218
\isacommand{ML}\isamarkupfalse%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2219
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2220
\ \ val\ tmp{\isadigit{1}}\ {\isaliteral{3D}{\isacharequal}}\ File{\isaliteral{2E}{\isachardot}}tmp{\isaliteral{5F}{\isacharunderscore}}path\ {\isaliteral{28}{\isacharparenleft}}Path{\isaliteral{2E}{\isachardot}}basic\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{22}{\isachardoublequote}}foo{\isaliteral{22}{\isachardoublequote}}\ {\isaliteral{5E}{\isacharcircum}}\ serial{\isaliteral{5F}{\isacharunderscore}}string\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2221
\ \ val\ tmp{\isadigit{2}}\ {\isaliteral{3D}{\isacharequal}}\ File{\isaliteral{2E}{\isachardot}}tmp{\isaliteral{5F}{\isacharunderscore}}path\ {\isaliteral{28}{\isacharparenleft}}Path{\isaliteral{2E}{\isachardot}}basic\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{22}{\isachardoublequote}}foo{\isaliteral{22}{\isachardoublequote}}\ {\isaliteral{5E}{\isacharcircum}}\ serial{\isaliteral{5F}{\isacharunderscore}}string\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2222
\ \ %
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2223
\isaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2224
assert{}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2225
\endisaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2226
\ {\isaliteral{28}{\isacharparenleft}}tmp{\isadigit{1}}\ {\isaliteral{3C}{\isacharless}}{\isaliteral{3E}{\isachargreater}}\ tmp{\isadigit{2}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2227
{\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2228
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2229
{\isafoldML}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2230
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2231
\isadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2232
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2233
\endisadelimML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2234
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2235
\isamarkupsubsection{Explicit synchronization%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2236
}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2237
\isamarkuptrue%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2238
%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2239
\begin{isamarkuptext}%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2240
Isabelle/ML also provides some explicit synchronization
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2241
  mechanisms, for the rare situations where mutable shared resources
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2242
  are really required.  These are based on the synchronizations
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2243
  primitives of Poly/ML, which have been adapted to the specific
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2244
  assumptions of the concurrent Isabelle/ML environment.  User code
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2245
  must not use the Poly/ML primitives directly!
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2246
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2247
  \medskip The most basic synchronization concept is a single
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2248
  \emph{critical section} (also called ``monitor'' in the literature).
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2249
  A thread that enters the critical section prevents all other threads
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2250
  from doing the same.  A thread that is already within the critical
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2251
  section may re-enter it in an idempotent manner.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2252
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2253
  Such centralized locking is convenient, because it prevents
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2254
  deadlocks by construction.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2255
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2256
  \medskip More fine-grained locking works via \emph{synchronized
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2257
  variables}.  An explicit state component is associated with
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2258
  mechanisms for locking and signaling.  There are operations to
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2259
  await a condition, change the state, and signal the change to all
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2260
  other waiting threads.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2261
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2262
  Here the synchronized access to the state variable is \emph{not}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2263
  re-entrant: direct or indirect nesting within the same thread will
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2264
  cause a deadlock!%
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2265
\end{isamarkuptext}%
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2266
\isamarkuptrue%
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2267
%
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2268
\isadelimmlref
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2269
%
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2270
\endisadelimmlref
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2271
%
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2272
\isatagmlref
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2273
%
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2274
\begin{isamarkuptext}%
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2275
\begin{mldecls}
30121
5c7bcb296600 updated generated files;
wenzelm
parents: 29756
diff changeset
  2276
  \indexdef{}{ML}{NAMED\_CRITICAL}\verb|NAMED_CRITICAL: string -> (unit -> 'a) -> 'a| \\
5c7bcb296600 updated generated files;
wenzelm
parents: 29756
diff changeset
  2277
  \indexdef{}{ML}{CRITICAL}\verb|CRITICAL: (unit -> 'a) -> 'a| \\
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2278
  \end{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2279
  \begin{mldecls}
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2280
  \indexdef{}{ML type}{Synchronized.var}\verb|type 'a Synchronized.var| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2281
  \indexdef{}{ML}{Synchronized.var}\verb|Synchronized.var: string -> 'a -> 'a Synchronized.var| \\
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2282
  \indexdef{}{ML}{Synchronized.guarded\_access}\verb|Synchronized.guarded_access: 'a Synchronized.var ->|\isasep\isanewline%
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2283
\verb|  ('a -> ('b * 'a) option) -> 'b| \\
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2284
  \end{mldecls}
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2285
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2286
  \begin{description}
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2287
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2288
  \item \verb|NAMED_CRITICAL|~\isa{name\ e} evaluates \isa{e\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{29}{\isacharparenright}}}
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2289
  within the central critical section of Isabelle/ML.  No other thread
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2290
  may do so at the same time, but non-critical parallel execution will
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2291
  continue.  The \isa{name} argument is used for tracing and might
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2292
  help to spot sources of congestion.
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2293
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2294
  Entering the critical section without contention is very fast, and
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2295
  several basic system operations do so frequently.  Each thread
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2296
  should stay within the critical section quickly only very briefly,
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2297
  otherwise parallel performance may degrade.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2298
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2299
  \item \verb|CRITICAL| is the same as \verb|NAMED_CRITICAL| with empty
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2300
  name argument.
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2301
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2302
  \item Type \verb|'a Synchronized.var| represents synchronized
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2303
  variables with state of type \verb|'a|.
24089
070d539ba403 tuned section "Style";
wenzelm
parents: 23653
diff changeset
  2304
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2305
  \item \verb|Synchronized.var|~\isa{name\ x} creates a synchronized
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2306
  variable that is initialized with value \isa{x}.  The \isa{name} is used for tracing.
25151
9374a0df240c continued
haftmann
parents: 24110
diff changeset
  2307
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2308
  \item \verb|Synchronized.guarded_access|~\isa{var\ f} lets the
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2309
  function \isa{f} operate within a critical section on the state
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2310
  \isa{x} as follows: if \isa{f\ x} produces \verb|NONE|, it
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2311
  continues to wait on the internal condition variable, expecting that
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2312
  some other thread will eventually change the content in a suitable
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2313
  manner; if \isa{f\ x} produces \verb|SOME|~\isa{{\isaliteral{28}{\isacharparenleft}}y{\isaliteral{2C}{\isacharcomma}}\ x{\isaliteral{27}{\isacharprime}}{\isaliteral{29}{\isacharparenright}}} it is
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2314
  satisfied and assigns the new state value \isa{x{\isaliteral{27}{\isacharprime}}}, broadcasts a
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2315
  signal to all waiting threads on the associated condition variable,
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2316
  and returns the result \isa{y}.
26459
bb0e729be5a4 some styling
haftmann
parents: 26437
diff changeset
  2317
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2318
  \end{description}
26459
bb0e729be5a4 some styling
haftmann
parents: 26437
diff changeset
  2319
40802
3cd23f676c5b updated generated files;
wenzelm
parents: 40508
diff changeset
  2320
  There are some further variants of the \verb|Synchronized.guarded_access| combinator, see \verb|~~/src/Pure/Concurrent/synchronized.ML| for details.%
22293
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2321
\end{isamarkuptext}%
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2322
\isamarkuptrue%
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2323
%
22322
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2324
\endisatagmlref
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2325
{\isafoldmlref}%
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2326
%
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2327
\isadelimmlref
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2328
%
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2329
\endisadelimmlref
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2330
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2331
\isadelimmlex
22322
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2332
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2333
\endisadelimmlex
22322
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2334
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2335
\isatagmlex
22322
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2336
%
b9924abb8c66 continued
haftmann
parents: 22293
diff changeset
  2337
\begin{isamarkuptext}%
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2338
The following example implements a counter that produces
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2339
  positive integers that are unique over the runtime of the Isabelle
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2340
  process:%
22293
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2341
\end{isamarkuptext}%
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2342
\isamarkuptrue%
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2343
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2344
\endisatagmlex
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2345
{\isafoldmlex}%
22293
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2346
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2347
\isadelimmlex
22293
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2348
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2349
\endisadelimmlex
22293
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2350
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2351
\isadelimML
22293
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2352
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2353
\endisadelimML
22293
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2354
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2355
\isatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2356
\isacommand{ML}\isamarkupfalse%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2357
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2358
\ \ local\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2359
\ \ \ \ val\ counter\ {\isaliteral{3D}{\isacharequal}}\ Synchronized{\isaliteral{2E}{\isachardot}}var\ {\isaliteral{22}{\isachardoublequote}}counter{\isaliteral{22}{\isachardoublequote}}\ {\isadigit{0}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2360
\ \ in\isanewline
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2361
\ \ \ \ fun\ next\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{29}{\isacharparenright}}\ {\isaliteral{3D}{\isacharequal}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2362
\ \ \ \ \ \ Synchronized{\isaliteral{2E}{\isachardot}}guarded{\isaliteral{5F}{\isacharunderscore}}access\ counter\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2363
\ \ \ \ \ \ \ \ {\isaliteral{28}{\isacharparenleft}}fn\ i\ {\isaliteral{3D}{\isacharequal}}{\isaliteral{3E}{\isachargreater}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2364
\ \ \ \ \ \ \ \ \ \ let\ val\ j\ {\isaliteral{3D}{\isacharequal}}\ i\ {\isaliteral{2B}{\isacharplus}}\ {\isadigit{1}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2365
\ \ \ \ \ \ \ \ \ \ in\ SOME\ {\isaliteral{28}{\isacharparenleft}}j{\isaliteral{2C}{\isacharcomma}}\ j{\isaliteral{29}{\isacharparenright}}\ end{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2366
\ \ end{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2367
{\isaliteral{2A7D}{\isacharverbatimclose}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2368
\isanewline
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2369
\isacommand{ML}\isamarkupfalse%
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2370
\ {\isaliteral{7B2A}{\isacharverbatimopen}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2371
\ \ val\ a\ {\isaliteral{3D}{\isacharequal}}\ next\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2372
\ \ val\ b\ {\isaliteral{3D}{\isacharequal}}\ next\ {\isaliteral{28}{\isacharparenleft}}{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2373
\ \ %
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2374
\isaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2375
assert{}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2376
\endisaantiq
40406
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2377
\ {\isaliteral{28}{\isacharparenleft}}a\ {\isaliteral{3C}{\isacharless}}{\isaliteral{3E}{\isachargreater}}\ b{\isaliteral{29}{\isacharparenright}}{\isaliteral{3B}{\isacharsemicolon}}\isanewline
313a24b66a8d updated generated files;
wenzelm
parents: 40310
diff changeset
  2378
{\isaliteral{2A7D}{\isacharverbatimclose}}%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2379
\endisatagML
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2380
{\isafoldML}%
22293
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2381
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2382
\isadelimML
22293
3593a76c9ed3 added outline for Isabelle library description
haftmann
parents: 21501
diff changeset
  2383
%
39885
6a3f7941c3a0 cumulative update of generated files (since bf164c153d10);
wenzelm
parents: 36164
diff changeset
  2384
\endisadelimML
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2385
%
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2386
\begin{isamarkuptext}%
40802
3cd23f676c5b updated generated files;
wenzelm
parents: 40508
diff changeset
  2387
\medskip See \verb|~~/src/Pure/Concurrent/mailbox.ML| how
40126
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2388
  to implement a mailbox as synchronized variable over a purely
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2389
  functional queue.%
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2390
\end{isamarkuptext}%
916cb4a28ffd misc tuning;
wenzelm
parents: 40110
diff changeset
  2391
\isamarkuptrue%
18543
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
  2392
%
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
  2393
\isadelimtheory
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
  2394
%
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
  2395
\endisadelimtheory
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
  2396
%
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
  2397
\isatagtheory
e903a1d0bed5 updated;
wenzelm
parents: 18537
diff changeset
  2398
\isacommand{end}\isamarkupfalse%
18537
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2399
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2400
\endisatagtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2401
{\isafoldtheory}%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2402
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2403
\isadelimtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2404
%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2405
\endisadelimtheory
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2406
\end{isabellebody}%
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2407
%%% Local Variables:
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2408
%%% mode: latex
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2409
%%% TeX-master: "root"
2681f9e34390 "The Isabelle/Isar Implementation" manual;
wenzelm
parents:
diff changeset
  2410
%%% End: