lib/Tools/usedir
author wenzelm
Wed, 18 Aug 1999 17:31:53 +0200
changeset 7259 e75aa311788c
parent 7226 1a4ed2eb48f3
child 7275 3a001f2148f7
permissions -rwxr-xr-x
tuned messages;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3007
e5efa177ee0c removed -norc;
wenzelm
parents: 2917
diff changeset
     1
#!/bin/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$
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
     4
#
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
     5
# DESCRIPTION: build object-logic or run examples
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
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
     8
## diagnostics
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
PRG=$(basename $0)
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    11
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    12
function usage()
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
  echo
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    15
  echo "Usage: $PRG LOGIC NAME"
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    16
  echo
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    17
  echo "  Options are:"
6940
ee6640456cbb -B option;
wenzelm
parents: 6652
diff changeset
    18
  echo "    -B           build mode with THIS_IS_ISABELLE_BUILD indication"
ee6640456cbb -B option;
wenzelm
parents: 6652
diff changeset
    19
  echo "    -P PATH      set path for remote theory browsing information"
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
    20
  echo "    -b           build mode (output heap image, using current dir)"
3747
cd9b6c86926c There is now one single option -i for generating theory browsing
berghofe
parents: 3636
diff changeset
    21
  echo "    -i BOOL      generate theory browsing information,"
cd9b6c86926c There is now one single option -i for generating theory browsing
berghofe
parents: 3636
diff changeset
    22
  echo "                 i.e. HTML / graph data (default false)"
7226
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
    23
  echo "    -m BOOL      multi line output (default false)"
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
    24
  echo "    -r           reset session path"
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    25
  echo "    -s NAME      override session NAME"
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    26
  echo
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    27
  echo "  Build object-logic or run examples. Also creates browsing"
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    28
  echo "  information (HTML etc.) according to settings."
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    29
  echo
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    30
  exit 1
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    31
}
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    32
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    33
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    34
## process command line
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    35
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    36
# options
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    37
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    38
BUILD=""
3747
cd9b6c86926c There is now one single option -i for generating theory browsing
berghofe
parents: 3636
diff changeset
    39
INFO=false
7226
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
    40
MULTI=false
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
    41
RESET=false
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    42
SESSION=""
6652
401f14f25648 usedir now recognizes additional option -P which is used to
berghofe
parents: 6249
diff changeset
    43
RPATH=""
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    44
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    45
function getoptions()
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    46
{
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    47
  OPTIND=1
7226
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
    48
  while getopts "BP:bi:m:rs:" OPT
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    49
  do
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    50
    case "$OPT" in
6940
ee6640456cbb -B option;
wenzelm
parents: 6652
diff changeset
    51
      B)
ee6640456cbb -B option;
wenzelm
parents: 6652
diff changeset
    52
        BUILD=true
ee6640456cbb -B option;
wenzelm
parents: 6652
diff changeset
    53
        export THIS_IS_ISABELLE_BUILD=true
ee6640456cbb -B option;
wenzelm
parents: 6652
diff changeset
    54
        ;;
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    55
      b)
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    56
        BUILD=true
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    57
        ;;
3747
cd9b6c86926c There is now one single option -i for generating theory browsing
berghofe
parents: 3636
diff changeset
    58
      i)
cd9b6c86926c There is now one single option -i for generating theory browsing
berghofe
parents: 3636
diff changeset
    59
        INFO="$OPTARG"
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    60
        ;;
7226
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
    61
      m)
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
    62
        MULTI="$OPTARG"
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
    63
        ;;
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
    64
      r)
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
    65
        RESET=true
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
    66
        ;;
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    67
      s)
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    68
        SESSION="$OPTARG"
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    69
        ;;
6652
401f14f25648 usedir now recognizes additional option -P which is used to
berghofe
parents: 6249
diff changeset
    70
      P)
401f14f25648 usedir now recognizes additional option -P which is used to
berghofe
parents: 6249
diff changeset
    71
        RPATH="$OPTARG"
401f14f25648 usedir now recognizes additional option -P which is used to
berghofe
parents: 6249
diff changeset
    72
        ;;
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    73
      \?)
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    74
        usage
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    75
        ;;
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    76
    esac
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    77
  done
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    78
}
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    79
2917
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    80
getoptions $ISABELLE_USEDIR_OPTIONS
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    81
c7411fce37e4 added -g, -h options;
wenzelm
parents: 2849
diff changeset
    82
getoptions "$@"
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    83
shift $(($OPTIND - 1))
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    84
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    85
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    86
# args
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    87
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    88
[ $# -ne 2 ] && usage
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    89
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    90
LOGIC="$1"; shift
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    91
NAME="$1"; shift
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    92
4419
wenzelm
parents: 4075
diff changeset
    93
[ -z "$SESSION" ] && SESSION=$(basename $NAME)
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
    94
4419
wenzelm
parents: 4075
diff changeset
    95
wenzelm
parents: 4075
diff changeset
    96
wenzelm
parents: 4075
diff changeset
    97
## main
3636
3f2e55e5bacc Added some code for generating theory browsing data.
berghofe
parents: 3504
diff changeset
    98
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
    99
# prepare browser info dir
4419
wenzelm
parents: 4075
diff changeset
   100
4586
wenzelm
parents: 4492
diff changeset
   101
if [ "$INFO" = "true" -a ! -f $ISABELLE_BROWSER_INFO/index.html ]; then
4419
wenzelm
parents: 4075
diff changeset
   102
3747
cd9b6c86926c There is now one single option -i for generating theory browsing
berghofe
parents: 3636
diff changeset
   103
  mkdir -p $ISABELLE_BROWSER_INFO/gif
3848
97bb3ff3c771 non-transparent logo;
wenzelm
parents: 3844
diff changeset
   104
  cp $ISABELLE_HOME/lib/logo/isabelle.gif $ISABELLE_BROWSER_INFO/gif/isabelle.gif
3747
cd9b6c86926c There is now one single option -i for generating theory browsing
berghofe
parents: 3636
diff changeset
   105
  cp $ISABELLE_HOME/lib/html/index1.html $ISABELLE_BROWSER_INFO/index.html
4419
wenzelm
parents: 4075
diff changeset
   106
3636
3f2e55e5bacc Added some code for generating theory browsing data.
berghofe
parents: 3504
diff changeset
   107
  mkdir -p $ISABELLE_BROWSER_INFO/graph
3f2e55e5bacc Added some code for generating theory browsing data.
berghofe
parents: 3504
diff changeset
   108
  cp $ISABELLE_HOME/lib/html/index2.html $ISABELLE_BROWSER_INFO/graph/index.html
3f2e55e5bacc Added some code for generating theory browsing data.
berghofe
parents: 3504
diff changeset
   109
  mkdir $ISABELLE_BROWSER_INFO/graph/GraphBrowser
3f2e55e5bacc Added some code for generating theory browsing data.
berghofe
parents: 3504
diff changeset
   110
  mkdir $ISABELLE_BROWSER_INFO/graph/awtUtilities
4419
wenzelm
parents: 4075
diff changeset
   111
  cp $ISABELLE_HOME/lib/browser/GraphBrowser/*.class $ISABELLE_BROWSER_INFO/graph/GraphBrowser
wenzelm
parents: 4075
diff changeset
   112
  cp $ISABELLE_HOME/lib/browser/awtUtilities/*.class $ISABELLE_BROWSER_INFO/graph/awtUtilities
wenzelm
parents: 4075
diff changeset
   113
3636
3f2e55e5bacc Added some code for generating theory browsing data.
berghofe
parents: 3504
diff changeset
   114
fi
3f2e55e5bacc Added some code for generating theory browsing data.
berghofe
parents: 3504
diff changeset
   115
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   116
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   117
# prepare log dir
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   118
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   119
LOGDIR="$ISABELLE_OUTPUT/log"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   120
mkdir -p "$LOGDIR"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   121
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   122
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   123
# run isabelle
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   124
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   125
SECONDS=0
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   126
6249
8bb90076cc7c Session.use_dir: check parent;
wenzelm
parents: 6212
diff changeset
   127
PARENT=$(basename "$LOGIC")
8bb90076cc7c Session.use_dir: check parent;
wenzelm
parents: 6212
diff changeset
   128
7226
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
   129
ECHO_LINE="echo -n"
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
   130
[ "$MULTI" = "true" ] && ECHO_LINE="echo"
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
   131
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   132
if [ -n "$BUILD" ]; then
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   133
  ITEM="$SESSION"
7226
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
   134
  $ECHO_LINE "Building $ITEM ..."
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   135
  LOG="$LOGDIR/$ITEM"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   136
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   137
  $ISABELLE \
6652
401f14f25648 usedir now recognizes additional option -P which is used to
berghofe
parents: 6249
diff changeset
   138
    -e "Session.use_dir $RESET $INFO \"$PARENT\" \"$SESSION\" \"$RPATH\";" \
4492
ab441d89a2cb stderr to $LOG;
wenzelm
parents: 4451
diff changeset
   139
    -q -w $LOGIC $NAME > $LOG 2>&1
6249
8bb90076cc7c Session.use_dir: check parent;
wenzelm
parents: 6212
diff changeset
   140
  RC=$?
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   141
else
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   142
  ITEM=$(basename $LOGIC)-"$SESSION"
7226
1a4ed2eb48f3 -m option;
wenzelm
parents: 6940
diff changeset
   143
  $ECHO_LINE "Running $ITEM ..."
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   144
  LOG="$LOGDIR/$ITEM"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   145
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
   146
  cd "$NAME"
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   147
  $ISABELLE \
6652
401f14f25648 usedir now recognizes additional option -P which is used to
berghofe
parents: 6249
diff changeset
   148
    -e "Session.use_dir $RESET $INFO \"$PARENT\" \"$SESSION\" \"$RPATH\"; quit();" \
4492
ab441d89a2cb stderr to $LOG;
wenzelm
parents: 4451
diff changeset
   149
    -r -q $LOGIC > $LOG 2>&1
6249
8bb90076cc7c Session.use_dir: check parent;
wenzelm
parents: 6212
diff changeset
   150
  RC=$?
6212
974310f9ca7d Session.init;
wenzelm
parents: 5034
diff changeset
   151
  cd ..
2808
e8a224e41b9f usedir -- build object-logic or run examples;
wenzelm
parents:
diff changeset
   152
fi
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   153
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   154
ELAPSED=$($ISABELLE_HOME/lib/scripts/showtime $SECONDS)
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   155
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   156
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   157
# exit status
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   158
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   159
if [ $RC -eq 0 ]; then
7259
e75aa311788c tuned messages;
wenzelm
parents: 7226
diff changeset
   160
  if [ "$MULTI" = "true" ]; then
e75aa311788c tuned messages;
wenzelm
parents: 7226
diff changeset
   161
    echo "Finished $ITEM  ($ELAPSED elapsed time)"
e75aa311788c tuned messages;
wenzelm
parents: 7226
diff changeset
   162
  else
e75aa311788c tuned messages;
wenzelm
parents: 7226
diff changeset
   163
    echo " OK  ($ELAPSED elapsed time)"
e75aa311788c tuned messages;
wenzelm
parents: 7226
diff changeset
   164
  fi
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   165
  gzip --force "$LOG"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   166
else
7259
e75aa311788c tuned messages;
wenzelm
parents: 7226
diff changeset
   167
  [ "$MULTI" = "true" ] || echo
e75aa311788c tuned messages;
wenzelm
parents: 7226
diff changeset
   168
  echo "$ITEM FAILED"
4451
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   169
  echo "(see also $LOG)"
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   170
  echo; tail $LOG; echo
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   171
fi
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   172
f9e3e9f1af61 log file;
wenzelm
parents: 4419
diff changeset
   173
exit $RC