doc-src/System/Thy/Basics.thy
author blanchet
Wed, 21 Dec 2011 15:04:28 +0100
changeset 45945 aa8100cc02dc
parent 45028 d608dd8cd409
child 47661 012a887997f3
permissions -rw-r--r--
no need for type arguments for monomorphic constructors of polymorphic datatypes (e.g. "Nil")
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
     1
theory Basics
43564
9864182c6bad document antiquotations are managed as theory data, with proper name space and entity markup;
wenzelm
parents: 41955
diff changeset
     2
imports Base
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
     3
begin
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
     4
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
     5
chapter {* The Isabelle system environment *}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
     6
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
     7
text {*
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
     8
  This manual describes Isabelle together with related tools and user
28916
0a802cdda340 removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents: 28914
diff changeset
     9
  interfaces as seen from a system oriented view.  See also the
0a802cdda340 removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents: 28914
diff changeset
    10
  \emph{Isabelle/Isar Reference Manual}~\cite{isabelle-isar-ref} for
0a802cdda340 removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents: 28914
diff changeset
    11
  the actual Isabelle input language and related concepts.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    12
28916
0a802cdda340 removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents: 28914
diff changeset
    13
  \medskip The Isabelle system environment provides the following
0a802cdda340 removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents: 28914
diff changeset
    14
  basic infrastructure to integrate tools smoothly.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    15
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    16
  \begin{enumerate}
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    17
28916
0a802cdda340 removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents: 28914
diff changeset
    18
  \item The \emph{Isabelle settings} mechanism provides process
0a802cdda340 removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents: 28914
diff changeset
    19
  environment variables to all Isabelle executables (including tools
0a802cdda340 removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents: 28914
diff changeset
    20
  and user interfaces).
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    21
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
    22
  \item The \emph{raw Isabelle process} (@{executable_ref
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
    23
  "isabelle-process"}) runs logic sessions either interactively or in
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
    24
  batch mode.  In particular, this view abstracts over the invocation
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
    25
  of the actual ML system to be used.  Regular users rarely need to
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
    26
  care about the low-level process.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    27
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
    28
  \item The \emph{Isabelle tools wrapper} (@{executable_ref isabelle})
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    29
  provides a generic startup environment Isabelle related utilities,
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    30
  user interfaces etc.  Such tools automatically benefit from the
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    31
  settings mechanism.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    32
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    33
  \end{enumerate}
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    34
*}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    35
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    36
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    37
section {* Isabelle settings \label{sec:settings} *}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    38
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    39
text {*
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    40
  The Isabelle system heavily depends on the \emph{settings
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    41
  mechanism}\indexbold{settings}.  Essentially, this is a statically
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    42
  scoped collection of environment variables, such as @{setting
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    43
  ISABELLE_HOME}, @{setting ML_SYSTEM}, @{setting ML_HOME}.  These
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    44
  variables are \emph{not} intended to be set directly from the shell,
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    45
  though.  Isabelle employs a somewhat more sophisticated scheme of
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    46
  \emph{settings files} --- one for site-wide defaults, another for
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    47
  additional user-specific modifications.  With all configuration
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    48
  variables in at most two places, this scheme is more maintainable
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    49
  and user-friendly than global shell environment variables.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    50
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    51
  In particular, we avoid the typical situation where prospective
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    52
  users of a software package are told to put several things into
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    53
  their shell startup scripts, before being able to actually run the
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    54
  program. Isabelle requires none such administrative chores of its
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    55
  end-users --- the executables can be invoked straight away.
40800
330eb65c9469 Parse.liberal_name for document antiquotations and attributes;
wenzelm
parents: 40569
diff changeset
    56
  Occasionally, users would still want to put the @{file
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    57
  "$ISABELLE_HOME/bin"} directory into their shell's search path, but
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    58
  this is not required.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    59
*}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    60
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    61
32323
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
    62
subsection {* Bootstrapping the environment \label{sec:boot} *}
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    63
32323
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
    64
text {* Isabelle executables need to be run within a proper settings
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
    65
  environment.  This is bootstrapped as described below, on the first
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
    66
  invocation of one of the outer wrapper scripts (such as
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
    67
  @{executable_ref isabelle}).  This happens only once for each
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
    68
  process tree, i.e.\ the environment is passed to subprocesses
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
    69
  according to regular Unix conventions.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    70
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    71
  \begin{enumerate}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    72
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    73
  \item The special variable @{setting_def ISABELLE_HOME} is
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    74
  determined automatically from the location of the binary that has
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    75
  been run.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    76
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    77
  You should not try to set @{setting ISABELLE_HOME} manually. Also
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    78
  note that the Isabelle executables either have to be run from their
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    79
  original location in the distribution directory, or via the
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    80
  executable objects created by the @{tool install} utility.  Symbolic
40800
330eb65c9469 Parse.liberal_name for document antiquotations and attributes;
wenzelm
parents: 40569
diff changeset
    81
  links are admissible, but a plain copy of the @{file
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    82
  "$ISABELLE_HOME/bin"} files will not work!
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    83
40800
330eb65c9469 Parse.liberal_name for document antiquotations and attributes;
wenzelm
parents: 40569
diff changeset
    84
  \item The file @{file "$ISABELLE_HOME/etc/settings"} is run as a
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    85
  @{executable_ref bash} shell script with the auto-export option for
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
    86
  variables enabled.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    87
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    88
  This file holds a rather long list of shell variable assigments,
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    89
  thus providing the site-wide default settings.  The Isabelle
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    90
  distribution already contains a global settings file with sensible
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    91
  defaults for most variables.  When installing the system, only a few
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    92
  of these may have to be adapted (probably @{setting ML_SYSTEM}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    93
  etc.).
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    94
  
28285
91cd65eabd7f unchecked $ISABELLE_HOME_USER/etc/settings;
wenzelm
parents: 28250
diff changeset
    95
  \item The file @{verbatim "$ISABELLE_HOME_USER/etc/settings"} (if it
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    96
  exists) is run in the same way as the site default settings. Note
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
    97
  that the variable @{setting ISABELLE_HOME_USER} has already been set
40387
e4c9e0dad473 moved ISABELLE_IDENTIFIER from ISABELLE_OUTPUT further up to ISABELLE_HOME_USER;
wenzelm
parents: 38253
diff changeset
    98
  before --- usually to something like @{verbatim
e4c9e0dad473 moved ISABELLE_IDENTIFIER from ISABELLE_OUTPUT further up to ISABELLE_HOME_USER;
wenzelm
parents: 38253
diff changeset
    99
  "$HOME/.isabelle/IsabelleXXXX"}.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   100
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   101
  Thus individual users may override the site-wide defaults.  See also
40800
330eb65c9469 Parse.liberal_name for document antiquotations and attributes;
wenzelm
parents: 40569
diff changeset
   102
  file @{file "$ISABELLE_HOME/etc/user-settings.sample"} in the
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   103
  distribution.  Typically, a user settings file would contain only a
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   104
  few lines, just the assigments that are really changed.  One should
40800
330eb65c9469 Parse.liberal_name for document antiquotations and attributes;
wenzelm
parents: 40569
diff changeset
   105
  definitely \emph{not} start with a full copy the basic @{file
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   106
  "$ISABELLE_HOME/etc/settings"}. This could cause very annoying
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   107
  maintainance problems later, when the Isabelle installation is
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   108
  updated or changed otherwise.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   109
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   110
  \end{enumerate}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   111
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   112
  Since settings files are regular GNU @{executable_def bash} scripts,
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   113
  one may use complex shell commands, such as @{verbatim "if"} or
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   114
  @{verbatim "case"} statements to set variables depending on the
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   115
  system architecture or other environment variables.  Such advanced
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   116
  features should be added only with great care, though. In
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   117
  particular, external environment references should be kept at a
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   118
  minimum.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   119
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   120
  \medskip A few variables are somewhat special:
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   121
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   122
  \begin{itemize}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   123
28502
6b0e3e4e1891 replaced ISABELLE by ISABELLE_PROCESS;
wenzelm
parents: 28500
diff changeset
   124
  \item @{setting_def ISABELLE_PROCESS} and @{setting_def ISABELLE_TOOL} are set
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   125
  automatically to the absolute path names of the @{executable
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   126
  "isabelle-process"} and @{executable isabelle} executables,
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   127
  respectively.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   128
  
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   129
  \item @{setting_ref ISABELLE_OUTPUT} will have the identifiers of
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   130
  the Isabelle distribution (cf.\ @{setting ISABELLE_IDENTIFIER}) and
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   131
  the ML system (cf.\ @{setting ML_IDENTIFIER}) appended automatically
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   132
  to its value.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   133
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   134
  \end{itemize}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   135
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   136
  \medskip Note that the settings environment may be inspected with
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   137
  the Isabelle tool @{tool getenv}.  This might help to figure out the
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   138
  effect of complex settings scripts.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   139
*}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   140
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   141
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   142
subsection{* Common variables *}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   143
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   144
text {*
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   145
  This is a reference of common Isabelle settings variables. Note that
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   146
  the list is somewhat open-ended. Third-party utilities or interfaces
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   147
  may add their own selection. Variables that are special in some
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   148
  sense are marked with @{text "\<^sup>*"}.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   149
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   150
  \begin{description}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   151
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   152
  \item[@{setting_def ISABELLE_HOME}@{text "\<^sup>*"}] is the
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   153
  location of the top-level Isabelle distribution directory. This is
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   154
  automatically determined from the Isabelle executable that has been
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   155
  invoked.  Do not attempt to set @{setting ISABELLE_HOME} yourself
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   156
  from the shell!
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   157
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   158
  \item[@{setting_def ISABELLE_HOME_USER}] is the user-specific
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   159
  counterpart of @{setting ISABELLE_HOME}. The default value is
40387
e4c9e0dad473 moved ISABELLE_IDENTIFIER from ISABELLE_OUTPUT further up to ISABELLE_HOME_USER;
wenzelm
parents: 38253
diff changeset
   160
  relative to @{verbatim "$HOME/.isabelle"}, under rare circumstances
e4c9e0dad473 moved ISABELLE_IDENTIFIER from ISABELLE_OUTPUT further up to ISABELLE_HOME_USER;
wenzelm
parents: 38253
diff changeset
   161
  this may be changed in the global setting file.  Typically, the
e4c9e0dad473 moved ISABELLE_IDENTIFIER from ISABELLE_OUTPUT further up to ISABELLE_HOME_USER;
wenzelm
parents: 38253
diff changeset
   162
  @{setting ISABELLE_HOME_USER} directory mimics @{setting
e4c9e0dad473 moved ISABELLE_IDENTIFIER from ISABELLE_OUTPUT further up to ISABELLE_HOME_USER;
wenzelm
parents: 38253
diff changeset
   163
  ISABELLE_HOME} to some extend. In particular, site-wide defaults may
e4c9e0dad473 moved ISABELLE_IDENTIFIER from ISABELLE_OUTPUT further up to ISABELLE_HOME_USER;
wenzelm
parents: 38253
diff changeset
   164
  be overridden by a private @{verbatim
e4c9e0dad473 moved ISABELLE_IDENTIFIER from ISABELLE_OUTPUT further up to ISABELLE_HOME_USER;
wenzelm
parents: 38253
diff changeset
   165
  "$ISABELLE_HOME_USER/etc/settings"}.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   166
  
36196
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   167
  \item[@{setting_def ISABELLE_PLATFORM}@{text "\<^sup>*"}] is automatically
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   168
  set to a symbolic identifier for the underlying hardware and
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   169
  operating system.  The Isabelle platform identification always
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   170
  refers to the 32 bit variant, even this is a 64 bit machine.  Note
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   171
  that the ML or Java runtime may have a different idea, depending on
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   172
  which binaries are actually run.
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   173
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   174
  \item[@{setting_def ISABELLE_PLATFORM64}@{text "\<^sup>*"}] is similar to
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   175
  @{setting ISABELLE_PLATFORM} but refers to the proper 64 bit variant
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   176
  on a platform that supports this; the value is empty for 32 bit.
cbb9ee265cdd added ISABELLE_PLATFORM and ISABELLE_PLATFORM64 -- NB: ML and JVM may have a different idea;
wenzelm
parents: 33952
diff changeset
   177
28502
6b0e3e4e1891 replaced ISABELLE by ISABELLE_PROCESS;
wenzelm
parents: 28500
diff changeset
   178
  \item[@{setting_def ISABELLE_PROCESS}@{text "\<^sup>*"}, @{setting
28500
4b79e5d3d0aa replaced ISATOOL by ISABELLE_TOOL;
wenzelm
parents: 28285
diff changeset
   179
  ISABELLE_TOOL}@{text "\<^sup>*"}] are automatically set to the full path
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   180
  names of the @{executable "isabelle-process"} and @{executable
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   181
  isabelle} executables, respectively.  Thus other tools and scripts
40800
330eb65c9469 Parse.liberal_name for document antiquotations and attributes;
wenzelm
parents: 40569
diff changeset
   182
  need not assume that the @{file "$ISABELLE_HOME/bin"} directory is
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   183
  on the current search path of the shell.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   184
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   185
  \item[@{setting_def ISABELLE_IDENTIFIER}@{text "\<^sup>*"}] refers
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   186
  to the name of this Isabelle distribution, e.g.\ ``@{verbatim
41512
8445396e1e39 updated to Isabelle2011;
wenzelm
parents: 40800
diff changeset
   187
  Isabelle2011}''.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   188
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   189
  \item[@{setting_def ML_SYSTEM}, @{setting_def ML_HOME},
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   190
  @{setting_def ML_OPTIONS}, @{setting_def ML_PLATFORM}, @{setting_def
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   191
  ML_IDENTIFIER}@{text "\<^sup>*"}] specify the underlying ML system
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   192
  to be used for Isabelle.  There is only a fixed set of admissable
40800
330eb65c9469 Parse.liberal_name for document antiquotations and attributes;
wenzelm
parents: 40569
diff changeset
   193
  @{setting ML_SYSTEM} names (see the @{file
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   194
  "$ISABELLE_HOME/etc/settings"} file of the distribution).
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   195
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   196
  The actual compiler binary will be run from the directory @{setting
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   197
  ML_HOME}, with @{setting ML_OPTIONS} as first arguments on the
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   198
  command line.  The optional @{setting ML_PLATFORM} may specify the
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   199
  binary format of ML heap images, which is useful for cross-platform
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   200
  installations.  The value of @{setting ML_IDENTIFIER} is
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   201
  automatically obtained by composing the values of @{setting
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   202
  ML_SYSTEM}, @{setting ML_PLATFORM} and the Isabelle version values.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   203
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   204
  \item[@{setting_def ISABELLE_PATH}] is a list of directories
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   205
  (separated by colons) where Isabelle logic images may reside.  When
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   206
  looking up heaps files, the value of @{setting ML_IDENTIFIER} is
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   207
  appended to each component internally.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   208
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   209
  \item[@{setting_def ISABELLE_OUTPUT}@{text "\<^sup>*"}] is a
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   210
  directory where output heap files should be stored by default. The
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   211
  ML system and Isabelle version identifier is appended here, too.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   212
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   213
  \item[@{setting_def ISABELLE_BROWSER_INFO}] is the directory where
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   214
  theory browser information (HTML text, graph data, and printable
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   215
  documents) is stored (see also \secref{sec:info}).  The default
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   216
  value is @{verbatim "$ISABELLE_HOME_USER/browser_info"}.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   217
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   218
  \item[@{setting_def ISABELLE_LOGIC}] specifies the default logic to
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   219
  load if none is given explicitely by the user.  The default value is
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   220
  @{verbatim HOL}.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   221
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   222
  \item[@{setting_def ISABELLE_LINE_EDITOR}] specifies the default
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   223
  line editor for the @{tool_ref tty} interface.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   224
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   225
  \item[@{setting_def ISABELLE_USEDIR_OPTIONS}] is implicitly prefixed
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   226
  to the command line of any @{tool_ref usedir} invocation. This
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   227
  typically contains compilation options for object-logics --- @{tool
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   228
  usedir} is the basic utility for managing logic sessions (cf.\ the
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   229
  @{verbatim IsaMakefile}s in the distribution).
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   230
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   231
  \item[@{setting_def ISABELLE_LATEX}, @{setting_def
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   232
  ISABELLE_PDFLATEX}, @{setting_def ISABELLE_BIBTEX}, @{setting_def
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   233
  ISABELLE_DVIPS}] refer to {\LaTeX} related tools for Isabelle
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   234
  document preparation (see also \secref{sec:tool-latex}).
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   235
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   236
  \item[@{setting_def ISABELLE_TOOLS}] is a colon separated list of
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   237
  directories that are scanned by @{executable isabelle} for external
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   238
  utility programs (see also \secref{sec:isabelle-tool}).
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   239
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   240
  \item[@{setting_def ISABELLE_DOCS}] is a colon separated list of
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   241
  directories with documentation files.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   242
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   243
  \item[@{setting_def ISABELLE_DOC_FORMAT}] specifies the preferred
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   244
  document format, typically @{verbatim dvi} or @{verbatim pdf}.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   245
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   246
  \item[@{setting_def DVI_VIEWER}] specifies the command to be used
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   247
  for displaying @{verbatim dvi} files.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   248
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   249
  \item[@{setting_def PDF_VIEWER}] specifies the command to be used
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   250
  for displaying @{verbatim pdf} files.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   251
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   252
  \item[@{setting_def PRINT_COMMAND}] specifies the standard printer
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   253
  spool command, which is expected to accept @{verbatim ps} files.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   254
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   255
  \item[@{setting_def ISABELLE_TMP_PREFIX}@{text "\<^sup>*"}] is the
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   256
  prefix from which any running @{executable "isabelle-process"}
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   257
  derives an individual directory for temporary files.  The default is
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   258
  somewhere in @{verbatim "/tmp"}.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   259
  
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   260
  \end{description}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   261
*}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   262
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   263
32323
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   264
subsection {* Additional components \label{sec:components} *}
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   265
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   266
text {* Any directory may be registered as an explicit \emph{Isabelle
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   267
  component}.  The general layout conventions are that of the main
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   268
  Isabelle distribution itself, and the following two files (both
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   269
  optional) have a special meaning:
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   270
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   271
  \begin{itemize}
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   272
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   273
  \item @{verbatim "etc/settings"} holds additional settings that are
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   274
  initialized when bootstrapping the overall Isabelle environment,
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   275
  cf.\ \secref{sec:boot}.  As usual, the content is interpreted as a
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   276
  @{verbatim bash} script.  It may refer to the component's enclosing
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   277
  directory via the @{verbatim "COMPONENT"} shell variable.
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   278
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   279
  For example, the following setting allows to refer to files within
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   280
  the component later on, without having to hardwire absolute paths:
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   281
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   282
  \begin{ttbox}
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   283
  MY_COMPONENT_HOME="$COMPONENT"
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   284
  \end{ttbox}
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   285
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   286
  Components can also add to existing Isabelle settings such as
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   287
  @{setting_def ISABELLE_TOOLS}, in order to provide
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   288
  component-specific tools that can be invoked by end-users.  For
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   289
  example:
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   290
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   291
  \begin{ttbox}
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   292
  ISABELLE_TOOLS="$ISABELLE_TOOLS:$COMPONENT/lib/Tools"
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   293
  \end{ttbox}
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   294
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   295
  \item @{verbatim "etc/components"} holds a list of further
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   296
  sub-components of the same structure.  The directory specifications
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   297
  given here can be either absolute (with leading @{verbatim "/"}) or
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   298
  relative to the component's main directory.
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   299
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   300
  \end{itemize}
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   301
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   302
  The root of component initialization is @{setting ISABELLE_HOME}
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   303
  itself.  After initializing all of its sub-components recursively,
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   304
  @{setting ISABELLE_HOME_USER} is included in the same manner (if
40569
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   305
  that directory exists).  This allows to install private components
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   306
  via @{verbatim "$ISABELLE_HOME_USER/etc/components"}, although it is
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   307
  often more convenient to do that programmatically via the
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   308
  \verb,init_component, shell function in the \verb,etc/settings,
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   309
  script of \verb,$ISABELLE_HOME_USER, (or any other component
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   310
  directory).  For example:
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   311
  \begin{verbatim}
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   312
  if [ -d "$HOME/screwdriver-2.0" ]
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   313
  then
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   314
    init_component "$HOME/screwdriver-2.0"
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   315
  else
ffcff7509a49 more explicit explanation of init_component shell function;
wenzelm
parents: 40387
diff changeset
   316
  \end{verbatim}
32323
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   317
*}
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   318
8185d3bfcbf1 tuned "Bootstrapping the environment";
wenzelm
parents: 32088
diff changeset
   319
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   320
section {* The raw Isabelle process *}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   321
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   322
text {*
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   323
  The @{executable_def "isabelle-process"} executable runs bare-bones
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   324
  Isabelle logic sessions --- either interactively or in batch mode.
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   325
  It provides an abstraction over the underlying ML system, and over
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   326
  the actual heap file locations.  Its usage is:
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   327
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   328
\begin{ttbox}
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   329
Usage: isabelle-process [OPTIONS] [INPUT] [OUTPUT]
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   330
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   331
  Options are:
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   332
    -I           startup Isar interaction mode
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   333
    -P           startup Proof General interaction mode
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   334
    -S           secure mode -- disallow critical operations
45028
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 43564
diff changeset
   335
    -T ADDR      startup process wrapper, with socket address
38253
3d4e521014f7 Isabelle_Process: separate input fifo for commands (still using the old tty protocol);
wenzelm
parents: 36196
diff changeset
   336
    -W IN:OUT    startup process wrapper, with input/output fifos
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   337
    -X           startup PGIP interaction mode
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   338
    -e MLTEXT    pass MLTEXT to the ML session
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   339
    -f           pass 'Session.finish();' to the ML session
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   340
    -m MODE      add print mode for output
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   341
    -q           non-interactive session
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   342
    -r           open heap file read-only
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   343
    -u           pass 'use"ROOT.ML";' to the ML session
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   344
    -w           reset write permissions on OUTPUT
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   345
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   346
  INPUT (default "\$ISABELLE_LOGIC") and OUTPUT specify in/out heaps.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   347
  These are either names to be searched in the Isabelle path, or
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   348
  actual file names (containing at least one /).
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   349
  If INPUT is "RAW_ML_SYSTEM", just start the bare bones ML system.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   350
\end{ttbox}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   351
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   352
  Input files without path specifications are looked up in the
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   353
  @{setting ISABELLE_PATH} setting, which may consist of multiple
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   354
  components separated by colons --- these are tried in the given
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   355
  order with the value of @{setting ML_IDENTIFIER} appended
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   356
  internally.  In a similar way, base names are relative to the
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   357
  directory specified by @{setting ISABELLE_OUTPUT}.  In any case,
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   358
  actual file locations may also be given by including at least one
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   359
  slash (@{verbatim "/"}) in the name (hint: use @{verbatim "./"} to
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   360
  refer to the current directory).
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   361
*}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   362
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   363
28223
wenzelm
parents: 28215
diff changeset
   364
subsubsection {* Options *}
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   365
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   366
text {*
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   367
  If the input heap file does not have write permission bits set, or
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   368
  the @{verbatim "-r"} option is given explicitely, then the session
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   369
  started will be read-only.  That is, the ML world cannot be
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   370
  committed back into the image file.  Otherwise, a writable session
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   371
  enables commits into either the input file, or into another output
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   372
  heap file (if that is given as the second argument on the command
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   373
  line).
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   374
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   375
  The read-write state of sessions is determined at startup only, it
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   376
  cannot be changed intermediately. Also note that heap images may
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   377
  require considerable amounts of disk space (approximately
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   378
  50--200~MB). Users are responsible for themselves to dispose their
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   379
  heap files when they are no longer needed.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   380
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   381
  \medskip The @{verbatim "-w"} option makes the output heap file
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   382
  read-only after terminating.  Thus subsequent invocations cause the
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   383
  logic image to be read-only automatically.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   384
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   385
  \medskip Using the @{verbatim "-e"} option, arbitrary ML code may be
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   386
  passed to the Isabelle session from the command line. Multiple
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   387
  @{verbatim "-e"}'s are evaluated in the given order. Strange things
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   388
  may happen when errorneous ML code is provided. Also make sure that
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   389
  the ML commands are terminated properly by semicolon.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   390
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   391
  \medskip The @{verbatim "-u"} option is a shortcut for @{verbatim
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   392
  "-e"} passing ``@{verbatim "use \"ROOT.ML\";"}'' to the ML session.
28223
wenzelm
parents: 28215
diff changeset
   393
  The @{verbatim "-f"} option passes ``@{verbatim
wenzelm
parents: 28215
diff changeset
   394
  "Session.finish();"}'', which is intended mainly for administrative
wenzelm
parents: 28215
diff changeset
   395
  purposes.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   396
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   397
  \medskip The @{verbatim "-m"} option adds identifiers of print modes
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   398
  to be made active for this session. Typically, this is used by some
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   399
  user interface, e.g.\ to enable output of proper mathematical
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   400
  symbols.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   401
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   402
  \medskip Isabelle normally enters an interactive top-level loop
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   403
  (after processing the @{verbatim "-e"} texts). The @{verbatim "-q"}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   404
  option inhibits interaction, thus providing a pure batch mode
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   405
  facility.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   406
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   407
  \medskip The @{verbatim "-I"} option makes Isabelle enter Isar
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   408
  interaction mode on startup, instead of the primitive ML top-level.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   409
  The @{verbatim "-P"} option configures the top-level loop for
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   410
  interaction with the Proof General user interface, and the
38253
3d4e521014f7 Isabelle_Process: separate input fifo for commands (still using the old tty protocol);
wenzelm
parents: 36196
diff changeset
   411
  @{verbatim "-X"} option enables XML-based PGIP communication.
3d4e521014f7 Isabelle_Process: separate input fifo for commands (still using the old tty protocol);
wenzelm
parents: 36196
diff changeset
   412
45028
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 43564
diff changeset
   413
  \medskip The @{verbatim "-T"} or @{verbatim "-W"} option makes
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 43564
diff changeset
   414
  Isabelle enter a special process wrapper for interaction via the
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 43564
diff changeset
   415
  Isabelle/Scala layer, see also @{file
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 43564
diff changeset
   416
  "~~/src/Pure/System/isabelle_process.scala"}.  The protocol between
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 43564
diff changeset
   417
  the ML and JVM process is private to the implementation.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   418
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   419
  \medskip The @{verbatim "-S"} option makes the Isabelle process more
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   420
  secure by disabling some critical operations, notably runtime
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   421
  compilation and evaluation of ML source code.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   422
*}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   423
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   424
28223
wenzelm
parents: 28215
diff changeset
   425
subsubsection {* Examples *}
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   426
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   427
text {*
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   428
  Run an interactive session of the default object-logic (as specified
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   429
  by the @{setting ISABELLE_LOGIC} setting) like this:
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   430
\begin{ttbox}
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   431
isabelle-process
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   432
\end{ttbox}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   433
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   434
  Usually @{setting ISABELLE_LOGIC} refers to one of the standard
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   435
  logic images, which are read-only by default.  A writable session
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   436
  --- based on @{verbatim FOL}, but output to @{verbatim Foo} (in the
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   437
  directory specified by the @{setting ISABELLE_OUTPUT} setting) ---
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   438
  may be invoked as follows:
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   439
\begin{ttbox}
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   440
isabelle-process FOL Foo
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   441
\end{ttbox}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   442
  Ending this session normally (e.g.\ by typing control-D) dumps the
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   443
  whole ML system state into @{verbatim Foo}. Be prepared for several
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   444
  tens of megabytes.
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   445
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   446
  The @{verbatim Foo} session may be continued later (still in
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   447
  writable state) by:
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   448
\begin{ttbox}
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   449
isabelle-process Foo
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   450
\end{ttbox}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   451
  A read-only @{verbatim Foo} session may be started by:
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   452
\begin{ttbox}
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   453
isabelle-process -r Foo
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   454
\end{ttbox}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   455
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   456
  \medskip Note that manual session management like this does
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   457
  \emph{not} provide proper setup for theory presentation.  This would
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   458
  require the @{tool usedir} utility.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   459
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   460
  \bigskip The next example demonstrates batch execution of Isabelle.
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   461
  We retrieve the @{verbatim FOL} theory value from the theory loader
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   462
  within ML:
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   463
\begin{ttbox}
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   464
isabelle-process -e 'theory "FOL";' -q -r FOL
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   465
\end{ttbox}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   466
  Note that the output text will be interspersed with additional junk
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   467
  messages by the ML runtime environment.  The @{verbatim "-W"} option
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   468
  allows to communicate with the Isabelle process via an external
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   469
  program in a more robust fashion.
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   470
*}
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   471
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   472
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   473
section {* The Isabelle tools wrapper \label{sec:isabelle-tool} *}
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   474
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   475
text {*
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   476
  All Isabelle related tools and interfaces are called via a common
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   477
  wrapper --- @{executable isabelle}:
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   478
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   479
\begin{ttbox}
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   480
Usage: isabelle TOOL [ARGS ...]
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   481
28506
3ab515ee4e6f tuned isabelle usage;
wenzelm
parents: 28504
diff changeset
   482
  Start Isabelle tool NAME with ARGS; pass "-?" for tool specific help.
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   483
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   484
  Available tools are:
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   485
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   486
    browser - Isabelle graph browser
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   487
    \dots
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   488
\end{ttbox}
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   489
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   490
  In principle, Isabelle tools are ordinary executable scripts that
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   491
  are run within the Isabelle settings environment, see
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   492
  \secref{sec:settings}.  The set of available tools is collected by
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   493
  @{executable isabelle} from the directories listed in the @{setting
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   494
  ISABELLE_TOOLS} setting.  Do not try to call the scripts directly
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   495
  from the shell.  Neither should you add the tool directories to your
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   496
  shell's search path!
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   497
*}
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   498
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   499
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   500
subsubsection {* Examples *}
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   501
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   502
text {*
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   503
  Show the list of available documentation of the current Isabelle
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   504
  installation like this:
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   505
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   506
\begin{ttbox}
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   507
  isabelle doc
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   508
\end{ttbox}
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   509
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   510
  View a certain document as follows:
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   511
\begin{ttbox}
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   512
  isabelle doc isar-ref
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   513
\end{ttbox}
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   514
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   515
  Create an Isabelle session derived from HOL (see also
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   516
  \secref{sec:tool-mkdir} and \secref{sec:tool-make}):
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   517
\begin{ttbox}
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   518
  isabelle mkdir HOL Test && isabelle make
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   519
\end{ttbox}
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   520
  Note that @{verbatim "isabelle mkdir"} is usually only invoked once;
28238
398bf960d3d4 misc tuning and modernization;
wenzelm
parents: 28223
diff changeset
   521
  existing sessions (including document output etc.) are then updated
28504
7ad7d7d6df47 simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents: 28502
diff changeset
   522
  by @{verbatim "isabelle make"} alone.
28215
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   523
*}
a1cfc43ac47d converted basics.tex to theory file;
wenzelm
parents:
diff changeset
   524
28223
wenzelm
parents: 28215
diff changeset
   525
end