lib/Tools/usedir
author nipkow
Sat, 17 Apr 2004 14:51:00 +0200
changeset 14614 196ff8d245bf
parent 12912 0e144958cf27
child 14981 e73f8140af78
permissions -rwxr-xr-x
2003 -> 2004
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10555
2323ec838401 /usr/bin/env bash;
wenzelm
parents: 10511
diff changeset
     1
#!/usr/bin/env bash
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
     2
#
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
     3
# $Id$
9788
wenzelm
parents: 9237
diff changeset
     4
# Author: Markus Wenzel, TU Muenchen
wenzelm
parents: 9237
diff changeset
     5
# License: GPL (GNU GENERAL PUBLIC LICENSE)
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
     6
#
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
     7
# DESCRIPTION: build object-logic or run examples
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
     8
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
     9
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    10
## diagnostics
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    11
10511
wenzelm
parents: 9788
diff changeset
    12
PRG="$(basename "$0")"
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    13
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    14
function usage()
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    15
{
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    16
  echo
9237
161fb7f00414 fixed usage;
wenzelm
parents: 9047
diff changeset
    17
  echo "Usage: $PRG [OPTIONS] LOGIC NAME"
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    18
  echo
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    19
  echo "  Options are:"
8197
baab8e487fad -D PATH: dump generated document sources into PATH;
wenzelm
parents: 7888
diff changeset
    20
  echo "    -D PATH      dump generated document sources into PATH"
6940
ee6640456cbb -B option;
wenzelm
parents: 6652
diff changeset
    21
  echo "    -P PATH      set path for remote theory browsing information"
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
    22
  echo "    -b           build mode (output heap image, using current dir)"
8359
124ad46105dd option -c: tell ML system to compress output image;
wenzelm
parents: 8241
diff changeset
    23
  echo "    -c BOOL      tell ML system to compress output image (default true)"
7737
acaf55bee03e document preparation options: -c -d;
wenzelm
parents: 7461
diff changeset
    24
  echo "    -d FORMAT    build document as FORMAT (default false)"
11847
82df5977101b option -g for document graph;
wenzelm
parents: 11577
diff changeset
    25
  echo "    -g BOOL      generate session graph image for document (default false)"
82df5977101b option -g for document graph;
wenzelm
parents: 11577
diff changeset
    26
  echo "    -i BOOL      generate HTML and graph browser information (default false)"
10562
fcd29e58c40c option -m;
wenzelm
parents: 10555
diff changeset
    27
  echo "    -m MODE      add print mode for output"
11535
7f4c5cdea239 Added new option for setting level of detail for proof objects.
berghofe
parents: 10585
diff changeset
    28
  echo "    -p LEVEL     set level of detail for proof objects"
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
    29
  echo "    -r           reset session path"
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    30
  echo "    -s NAME      override session NAME"
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    31
  echo "    -v BOOL      be verbose (default false)"
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    32
  echo
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    33
  echo "  Build object-logic or run examples. Also creates browsing"
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    34
  echo "  information (HTML etc.) according to settings."
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    35
  echo
7461
94ae093f6706 usage: tell ISABELLE_USEDIR_OPTIONS;
wenzelm
parents: 7276
diff changeset
    36
  echo "  ISABELLE_USEDIR_OPTIONS=$ISABELLE_USEDIR_OPTIONS"
94ae093f6706 usage: tell ISABELLE_USEDIR_OPTIONS;
wenzelm
parents: 7276
diff changeset
    37
  echo
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    38
  exit 1
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    39
}
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    40
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    41
function fail()
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    42
{
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    43
  echo "$1" >&2
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    44
  exit 2
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    45
}
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    46
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    47
function check_bool()
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    48
{
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    49
  [ "$1" = true -o "$1" = false ] || fail "Bad boolean: \"$1\""
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    50
}
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    51
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    52
function check_number()
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    53
{
12912
0e144958cf27 tr: quote argument;
wenzelm
parents: 11949
diff changeset
    54
  [ -n "$1" -a -z "$(echo "$1" | tr -d '[0-9]')" ] || fail "Bad number: \"$1\""
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    55
}
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    56
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    57
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    58
## process command line
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    59
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    60
# options
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    61
8197
baab8e487fad -D PATH: dump generated document sources into PATH;
wenzelm
parents: 7888
diff changeset
    62
DUMP=""
baab8e487fad -D PATH: dump generated document sources into PATH;
wenzelm
parents: 7888
diff changeset
    63
RPATH=""
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    64
BUILD=""
8747
22580c8bc62f fixed -c default value;
wenzelm
parents: 8568
diff changeset
    65
COMPRESS=true
7737
acaf55bee03e document preparation options: -c -d;
wenzelm
parents: 7461
diff changeset
    66
DOCUMENT=false
11847
82df5977101b option -g for document graph;
wenzelm
parents: 11577
diff changeset
    67
DOCUMENT_GRAPH=false
3747
cd9b6c86926c There is now one single option -i for generating theory browsing
berghofe
parents: 3636
diff changeset
    68
INFO=false
10562
fcd29e58c40c option -m;
wenzelm
parents: 10555
diff changeset
    69
MODES=""
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
    70
RESET=false
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    71
SESSION=""
11543
d61b913431c5 renamed `keep_derivs' to `proofs', and made an integer;
wenzelm
parents: 11535
diff changeset
    72
PROOFS=0
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    73
VERBOSE=false
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    74
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    75
function getoptions()
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    76
{
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    77
  OPTIND=1
11847
82df5977101b option -g for document graph;
wenzelm
parents: 11577
diff changeset
    78
  while getopts "D:P:bc:d:g:i:m:p:rs:v:" OPT
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    79
  do
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    80
    case "$OPT" in
8197
baab8e487fad -D PATH: dump generated document sources into PATH;
wenzelm
parents: 7888
diff changeset
    81
      D)
baab8e487fad -D PATH: dump generated document sources into PATH;
wenzelm
parents: 7888
diff changeset
    82
        DUMP="$OPTARG"
baab8e487fad -D PATH: dump generated document sources into PATH;
wenzelm
parents: 7888
diff changeset
    83
        ;;
baab8e487fad -D PATH: dump generated document sources into PATH;
wenzelm
parents: 7888
diff changeset
    84
      P)
baab8e487fad -D PATH: dump generated document sources into PATH;
wenzelm
parents: 7888
diff changeset
    85
        RPATH="$OPTARG"
baab8e487fad -D PATH: dump generated document sources into PATH;
wenzelm
parents: 7888
diff changeset
    86
        ;;
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    87
      b)
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    88
        BUILD=true
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    89
        ;;
8359
124ad46105dd option -c: tell ML system to compress output image;
wenzelm
parents: 8241
diff changeset
    90
      c)
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
    91
        check_bool "$OPTARG"
8359
124ad46105dd option -c: tell ML system to compress output image;
wenzelm
parents: 8241
diff changeset
    92
        COMPRESS="$OPTARG"
124ad46105dd option -c: tell ML system to compress output image;
wenzelm
parents: 8241
diff changeset
    93
        ;;
7737
acaf55bee03e document preparation options: -c -d;
wenzelm
parents: 7461
diff changeset
    94
      d)
acaf55bee03e document preparation options: -c -d;
wenzelm
parents: 7461
diff changeset
    95
        DOCUMENT="$OPTARG"
acaf55bee03e document preparation options: -c -d;
wenzelm
parents: 7461
diff changeset
    96
        ;;
11847
82df5977101b option -g for document graph;
wenzelm
parents: 11577
diff changeset
    97
      g)
82df5977101b option -g for document graph;
wenzelm
parents: 11577
diff changeset
    98
        check_bool "$OPTARG"
82df5977101b option -g for document graph;
wenzelm
parents: 11577
diff changeset
    99
        DOCUMENT_GRAPH="$OPTARG"
82df5977101b option -g for document graph;
wenzelm
parents: 11577
diff changeset
   100
        ;;
3747
cd9b6c86926c There is now one single option -i for generating theory browsing
berghofe
parents: 3636
diff changeset
   101
      i)
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   102
        check_bool "$OPTARG"
3747
cd9b6c86926c There is now one single option -i for generating theory browsing
berghofe
parents: 3636
diff changeset
   103
        INFO="$OPTARG"
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   104
        ;;
10562
fcd29e58c40c option -m;
wenzelm
parents: 10555
diff changeset
   105
      m)
fcd29e58c40c option -m;
wenzelm
parents: 10555
diff changeset
   106
        if [ -z "$MODES" ]; then
fcd29e58c40c option -m;
wenzelm
parents: 10555
diff changeset
   107
          MODES="\"$OPTARG\""
fcd29e58c40c option -m;
wenzelm
parents: 10555
diff changeset
   108
        else
10585
58a1ed1edb65 proper order of modes;
wenzelm
parents: 10562
diff changeset
   109
          MODES="\"$OPTARG\", $MODES"
10562
fcd29e58c40c option -m;
wenzelm
parents: 10555
diff changeset
   110
        fi
fcd29e58c40c option -m;
wenzelm
parents: 10555
diff changeset
   111
        ;;
11535
7f4c5cdea239 Added new option for setting level of detail for proof objects.
berghofe
parents: 10585
diff changeset
   112
      p)
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   113
        check_number "$OPTARG"
11543
d61b913431c5 renamed `keep_derivs' to `proofs', and made an integer;
wenzelm
parents: 11535
diff changeset
   114
        PROOFS="$OPTARG"
11535
7f4c5cdea239 Added new option for setting level of detail for proof objects.
berghofe
parents: 10585
diff changeset
   115
        ;;
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
   116
      r)
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
   117
        RESET=true
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
   118
        ;;
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   119
      s)
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   120
        SESSION="$OPTARG"
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   121
        ;;
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   122
      v)
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   123
        check_bool "$OPTARG"
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   124
        VERBOSE="$OPTARG"
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   125
        ;;
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   126
      \?)
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   127
        usage
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   128
        ;;
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   129
    esac
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   130
  done
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   131
}
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   132
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   133
getoptions $ISABELLE_USEDIR_OPTIONS
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   134
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
   135
getoptions "$@"
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   136
shift $(($OPTIND - 1))
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   137
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   138
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   139
# args
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   140
9788
wenzelm
parents: 9237
diff changeset
   141
[ "$#" -ne 2 ] && usage
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   142
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   143
LOGIC="$1"; shift
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   144
NAME="$1"; shift
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   145
9788
wenzelm
parents: 9237
diff changeset
   146
[ -z "$SESSION" ] && SESSION=$(basename "$NAME")
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   147
4419
wenzelm
parents: 4075
diff changeset
   148
wenzelm
parents: 4075
diff changeset
   149
wenzelm
parents: 4075
diff changeset
   150
## main
3636
3f2e55e5bacc Added some code for generating theory browsing data.
berghofe
parents: 3504
diff changeset
   151
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   152
# prepare browser info dir
4419
wenzelm
parents: 4075
diff changeset
   153
9788
wenzelm
parents: 9237
diff changeset
   154
if [ "$INFO" = "true" -a ! -f "$ISABELLE_BROWSER_INFO/index.html" ]; then
wenzelm
parents: 9237
diff changeset
   155
  mkdir -p "$ISABELLE_BROWSER_INFO"
wenzelm
parents: 9237
diff changeset
   156
  cp "$ISABELLE_HOME/lib/logo/isabelle.gif" "$ISABELLE_BROWSER_INFO/isabelle.gif"
wenzelm
parents: 9237
diff changeset
   157
  cp "$ISABELLE_HOME/lib/html/index.html" "$ISABELLE_BROWSER_INFO/index.html"
3636
3f2e55e5bacc Added some code for generating theory browsing data.
berghofe
parents: 3504
diff changeset
   158
fi
3f2e55e5bacc Added some code for generating theory browsing data.
berghofe
parents: 3504
diff changeset
   159
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   160
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   161
# prepare log dir
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   162
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   163
LOGDIR="$ISABELLE_OUTPUT/log"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   164
mkdir -p "$LOGDIR"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   165
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   166
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   167
# run isabelle
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   168
7737
acaf55bee03e document preparation options: -c -d;
wenzelm
parents: 7461
diff changeset
   169
PARENT=$(basename "$LOGIC")
acaf55bee03e document preparation options: -c -d;
wenzelm
parents: 7461
diff changeset
   170
11949
wenzelm
parents: 11907
diff changeset
   171
if [ -z "$BUILD" ]; then
wenzelm
parents: 11907
diff changeset
   172
  cd "$NAME" || fail "Bad session directory '$NAME'"
wenzelm
parents: 11907
diff changeset
   173
fi
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   174
11847
82df5977101b option -g for document graph;
wenzelm
parents: 11577
diff changeset
   175
if [ "$DOCUMENT" != false ]; then
8568
wenzelm
parents: 8565
diff changeset
   176
  DOC="$DOCUMENT"
wenzelm
parents: 8565
diff changeset
   177
else
wenzelm
parents: 8565
diff changeset
   178
  DOC=""
wenzelm
parents: 8565
diff changeset
   179
fi
7737
acaf55bee03e document preparation options: -c -d;
wenzelm
parents: 7461
diff changeset
   180
acaf55bee03e document preparation options: -c -d;
wenzelm
parents: 7461
diff changeset
   181
acaf55bee03e document preparation options: -c -d;
wenzelm
parents: 7461
diff changeset
   182
SECONDS=0
6249
8bb90076cc7c Session.use_dir: check parent;
wenzelm
parents: 6212
diff changeset
   183
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   184
if [ -n "$BUILD" ]; then
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   185
  ITEM="$SESSION"
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   186
  echo "Building $ITEM ..." >&2
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   187
  LOG="$LOGDIR/$ITEM"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   188
8359
124ad46105dd option -c: tell ML system to compress output image;
wenzelm
parents: 8241
diff changeset
   189
  OPT_C=""
124ad46105dd option -c: tell ML system to compress output image;
wenzelm
parents: 8241
diff changeset
   190
  [ "$COMPRESS" = true ] && OPT_C="-c"
124ad46105dd option -c: tell ML system to compress output image;
wenzelm
parents: 8241
diff changeset
   191
9788
wenzelm
parents: 9237
diff changeset
   192
  "$ISABELLE" \
11907
f2a5481c7998 pass build mode to process;
wenzelm
parents: 11847
diff changeset
   193
    -e "Session.use_dir true [$MODES] $RESET $INFO \"$DOC\" $DOCUMENT_GRAPH \"$PARENT\" \"$SESSION\" \"$DUMP\" \"$RPATH\" $PROOFS $VERBOSE;" \
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   194
    $OPT_C -q -w $LOGIC $NAME > "$LOG"
9788
wenzelm
parents: 9237
diff changeset
   195
  RC="$?"
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   196
else
9788
wenzelm
parents: 9237
diff changeset
   197
  ITEM=$(basename "$LOGIC")-"$SESSION"
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   198
  echo "Running $ITEM ..." >&2
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   199
  LOG="$LOGDIR/$ITEM"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   200
9788
wenzelm
parents: 9237
diff changeset
   201
  "$ISABELLE" \
11907
f2a5481c7998 pass build mode to process;
wenzelm
parents: 11847
diff changeset
   202
    -e "Session.use_dir false [$MODES] $RESET $INFO \"$DOC\" $DOCUMENT_GRAPH \"$PARENT\" \"$SESSION\" \"$DUMP\" \"$RPATH\" $PROOFS $VERBOSE; quit();" \
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   203
    -r -q "$LOGIC" > "$LOG"
9788
wenzelm
parents: 9237
diff changeset
   204
  RC="$?"
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
   205
  cd ..
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   206
fi
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   207
9788
wenzelm
parents: 9237
diff changeset
   208
ELAPSED=$("$ISABELLE_HOME/lib/scripts/showtime" "$SECONDS")
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   209
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   210
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   211
# exit status
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   212
9788
wenzelm
parents: 9237
diff changeset
   213
if [ "$RC" -eq 0 ]; then
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   214
  echo "Finished $ITEM ($ELAPSED elapsed time)" >&2
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   215
  gzip --force "$LOG"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   216
else
11577
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   217
  { echo "$ITEM FAILED";
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   218
    echo "(see also $LOG)";
68323aa9575d option -v;
wenzelm
parents: 11543
diff changeset
   219
    echo; tail "$LOG"; echo; } >&2
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   220
fi
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   221
9788
wenzelm
parents: 9237
diff changeset
   222
exit "$RC"