src/HOL/Mirabelle/lib/Tools/mirabelle
author wenzelm
Sat, 05 Apr 2014 19:16:44 +0200
changeset 56426 ad83657a3f93
parent 48703 d408ff0abf23
child 66156 f54c32c413a9
permissions -rwxr-xr-x
tuned -- just one qualification of sections ("!");
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
     1
#!/usr/bin/env bash
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
     2
#
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
     3
# Author: Sascha Boehme
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
     4
#
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
     5
# DESCRIPTION: testing tool for automated proof tools
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
     6
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
     7
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
     8
PRG="$(basename "$0")"
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
     9
47848
030d3c89eacf more robust wrt. spaces in directory names;
wenzelm
parents: 47846
diff changeset
    10
function print_action_names()
030d3c89eacf more robust wrt. spaces in directory names;
wenzelm
parents: 47846
diff changeset
    11
{
030d3c89eacf more robust wrt. spaces in directory names;
wenzelm
parents: 47846
diff changeset
    12
  for TOOL in "$MIRABELLE_HOME/Tools"/mirabelle_*.ML
32397
1899b8c47961 more quoting for shell variables, canonical isabelle process
boehmes
parents: 32385
diff changeset
    13
  do
47848
030d3c89eacf more robust wrt. spaces in directory names;
wenzelm
parents: 47846
diff changeset
    14
    echo "$TOOL" | perl -w -p -e 's/.*mirabelle_(.*)\.ML/    $1/'
32397
1899b8c47961 more quoting for shell variables, canonical isabelle process
boehmes
parents: 32385
diff changeset
    15
  done
32385
594890623c46 split actions from Mirabelle core (Mirabelle may thus be applied to basic theories in HOL)
boehmes
parents: 32383
diff changeset
    16
}
594890623c46 split actions from Mirabelle core (Mirabelle may thus be applied to basic theories in HOL)
boehmes
parents: 32383
diff changeset
    17
47480
24d8c9e9dae4 Mirabelle's 'usage' description relating to Sledgehammer now synchs with the ML code of the Mirabelle-Sledgehammer action
sultana
parents: 47479
diff changeset
    18
function print_sledgehammer_options() {
47848
030d3c89eacf more robust wrt. spaces in directory names;
wenzelm
parents: 47846
diff changeset
    19
  grep -e "^val .*K =" "$MIRABELLE_HOME/Tools/mirabelle_sledgehammer.ML" | \
030d3c89eacf more robust wrt. spaces in directory names;
wenzelm
parents: 47846
diff changeset
    20
  perl -w -p -e 's/val .*K *= *"(.*)" *\(\*(.*)\*\)/    $1$2/'
47480
24d8c9e9dae4 Mirabelle's 'usage' description relating to Sledgehammer now synchs with the ML code of the Mirabelle-Sledgehammer action
sultana
parents: 47479
diff changeset
    21
}
24d8c9e9dae4 Mirabelle's 'usage' description relating to Sledgehammer now synchs with the ML code of the Mirabelle-Sledgehammer action
sultana
parents: 47479
diff changeset
    22
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    23
function usage() {
42069
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
    24
  [ -n "$MIRABELLE_OUTPUT_PATH" ] && out="$MIRABELLE_OUTPUT_PATH" || out="None"
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    25
  timeout="$MIRABELLE_TIMEOUT"
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    26
  echo
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    27
  echo "Usage: isabelle $PRG [OPTIONS] ACTIONS FILES"
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    28
  echo
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    29
  echo "  Options are:"
40976
8df0a190df1e correcting usage documentation in mirabelle tool
bulwahn
parents: 34035
diff changeset
    30
  echo "    -L LOGIC     parent logic to use (default $MIRABELLE_LOGIC)"
32385
594890623c46 split actions from Mirabelle core (Mirabelle may thus be applied to basic theories in HOL)
boehmes
parents: 32383
diff changeset
    31
  echo "    -T THEORY    parent theory to use (default $MIRABELLE_THEORY)"
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    32
  echo "    -O DIR       output directory for test data (default $out)"
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    33
  echo "    -t TIMEOUT   timeout for each action in seconds (default $timeout)"
46824
1257c80988cd added Mirabelle action info in its log file; tuned;
sultana
parents: 42069
diff changeset
    34
  echo "    -q           be quiet (suppress output of Isabelle process)"
48703
d408ff0abf23 extended Mirabelle to support user-provided setup files which contain the configuration for a Mirabelle run (avoids some layers of scripts and reduces the complexity of the overall Mirabelle setup)
boehmes
parents: 47848
diff changeset
    35
  echo "    -S FILE      user-provided setup file (no actions required)"
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    36
  echo
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    37
  echo "  Apply the given actions (i.e., automated proof tools)"
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    38
  echo "  at all proof steps in the given theory files."
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    39
  echo
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    40
  echo "  ACTIONS is a colon-separated list of actions, where each action is"
32522
1b70db55c811 Mirabelle: command-line action options may either be key=value or just key
boehmes
parents: 32521
diff changeset
    41
  echo "  either NAME or NAME[OPTION,...,OPTION]. Available actions are:"
32397
1899b8c47961 more quoting for shell variables, canonical isabelle process
boehmes
parents: 32385
diff changeset
    42
  print_action_names
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    43
  echo
33248
95478a5b4c05 included description for sledgehammer options in Mirabelle script
boehmes
parents: 32522
diff changeset
    44
  echo "  Available OPTIONs for the ACTION sledgehammer:"
47480
24d8c9e9dae4 Mirabelle's 'usage' description relating to Sledgehammer now synchs with the ML code of the Mirabelle-Sledgehammer action
sultana
parents: 47479
diff changeset
    45
  print_sledgehammer_options
32522
1b70db55c811 Mirabelle: command-line action options may either be key=value or just key
boehmes
parents: 32521
diff changeset
    46
  echo
32397
1899b8c47961 more quoting for shell variables, canonical isabelle process
boehmes
parents: 32385
diff changeset
    47
  echo "  FILES is a list of theory files, where each file is either NAME.thy"
1899b8c47961 more quoting for shell variables, canonical isabelle process
boehmes
parents: 32385
diff changeset
    48
  echo "  or NAME.thy[START:END] and START and END are numbers indicating the"
1899b8c47961 more quoting for shell variables, canonical isabelle process
boehmes
parents: 32385
diff changeset
    49
  echo "  range the given actions are to be applied."
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    50
  echo
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    51
  exit 1
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
    52
}
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
    53
42034
a77df5241959 propagate mirabelle failures properly;
krauss
parents: 40976
diff changeset
    54
function fail()
a77df5241959 propagate mirabelle failures properly;
krauss
parents: 40976
diff changeset
    55
{
a77df5241959 propagate mirabelle failures properly;
krauss
parents: 40976
diff changeset
    56
  echo "$1" >&2
a77df5241959 propagate mirabelle failures properly;
krauss
parents: 40976
diff changeset
    57
  exit 2
a77df5241959 propagate mirabelle failures properly;
krauss
parents: 40976
diff changeset
    58
}
a77df5241959 propagate mirabelle failures properly;
krauss
parents: 40976
diff changeset
    59
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
    60
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    61
## process command line
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
    62
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    63
# options
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
    64
47479
e6add51fd7ba Mirabelle now gives usage info when no arguments given
sultana
parents: 47478
diff changeset
    65
[ $# -eq 0 ] && usage
e6add51fd7ba Mirabelle now gives usage info when no arguments given
sultana
parents: 47478
diff changeset
    66
48703
d408ff0abf23 extended Mirabelle to support user-provided setup files which contain the configuration for a Mirabelle run (avoids some layers of scripts and reduces the complexity of the overall Mirabelle setup)
boehmes
parents: 47848
diff changeset
    67
MIRABELLE_SETUP_FILE=
d408ff0abf23 extended Mirabelle to support user-provided setup files which contain the configuration for a Mirabelle run (avoids some layers of scripts and reduces the complexity of the overall Mirabelle setup)
boehmes
parents: 47848
diff changeset
    68
d408ff0abf23 extended Mirabelle to support user-provided setup files which contain the configuration for a Mirabelle run (avoids some layers of scripts and reduces the complexity of the overall Mirabelle setup)
boehmes
parents: 47848
diff changeset
    69
while getopts "L:T:O:t:S:q?" OPT
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    70
do
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    71
  case "$OPT" in
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    72
    L)
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    73
      MIRABELLE_LOGIC="$OPTARG"
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    74
      ;;
32385
594890623c46 split actions from Mirabelle core (Mirabelle may thus be applied to basic theories in HOL)
boehmes
parents: 32383
diff changeset
    75
    T)
594890623c46 split actions from Mirabelle core (Mirabelle may thus be applied to basic theories in HOL)
boehmes
parents: 32383
diff changeset
    76
      MIRABELLE_THEORY="$OPTARG"
594890623c46 split actions from Mirabelle core (Mirabelle may thus be applied to basic theories in HOL)
boehmes
parents: 32383
diff changeset
    77
      ;;
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    78
    O)
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    79
      MIRABELLE_OUTPUT_PATH="$OPTARG"
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    80
      ;;
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    81
    t)
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    82
      MIRABELLE_TIMEOUT="$OPTARG"
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    83
      ;;
48703
d408ff0abf23 extended Mirabelle to support user-provided setup files which contain the configuration for a Mirabelle run (avoids some layers of scripts and reduces the complexity of the overall Mirabelle setup)
boehmes
parents: 47848
diff changeset
    84
    S)
d408ff0abf23 extended Mirabelle to support user-provided setup files which contain the configuration for a Mirabelle run (avoids some layers of scripts and reduces the complexity of the overall Mirabelle setup)
boehmes
parents: 47848
diff changeset
    85
      MIRABELLE_SETUP_FILE="$OPTARG"
d408ff0abf23 extended Mirabelle to support user-provided setup files which contain the configuration for a Mirabelle run (avoids some layers of scripts and reduces the complexity of the overall Mirabelle setup)
boehmes
parents: 47848
diff changeset
    86
      ;;
32521
f20cc66b2c74 added initialization and cleanup of actions,
boehmes
parents: 32496
diff changeset
    87
    q)
f20cc66b2c74 added initialization and cleanup of actions,
boehmes
parents: 32496
diff changeset
    88
      MIRABELLE_QUIET="true"
f20cc66b2c74 added initialization and cleanup of actions,
boehmes
parents: 32496
diff changeset
    89
      ;;
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    90
    \?)
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    91
      usage
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    92
      ;;
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    93
  esac
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    94
done
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
    95
48703
d408ff0abf23 extended Mirabelle to support user-provided setup files which contain the configuration for a Mirabelle run (avoids some layers of scripts and reduces the complexity of the overall Mirabelle setup)
boehmes
parents: 47848
diff changeset
    96
export MIRABELLE_SETUP_FILE
32521
f20cc66b2c74 added initialization and cleanup of actions,
boehmes
parents: 32496
diff changeset
    97
export MIRABELLE_QUIET
f20cc66b2c74 added initialization and cleanup of actions,
boehmes
parents: 32496
diff changeset
    98
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
    99
shift $(($OPTIND - 1))
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
   100
32521
f20cc66b2c74 added initialization and cleanup of actions,
boehmes
parents: 32496
diff changeset
   101
export MIRABELLE_ACTIONS="$1"
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
   102
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
   103
shift
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
   104
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
   105
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
   106
# setup
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
   107
42069
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   108
if [ -z "$MIRABELLE_OUTPUT_PATH" ]; then
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   109
  MIRABELLE_OUTPUT_PATH="${ISABELLE_TMP_PREFIX}-mirabelle$$"
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   110
  PURGE_OUTPUT="true"
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   111
fi
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   112
32397
1899b8c47961 more quoting for shell variables, canonical isabelle process
boehmes
parents: 32385
diff changeset
   113
mkdir -p "$MIRABELLE_OUTPUT_PATH"
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
   114
42069
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   115
export MIRABELLE_OUTPUT_PATH
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
   116
47848
030d3c89eacf more robust wrt. spaces in directory names;
wenzelm
parents: 47846
diff changeset
   117
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
   118
## main
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
   119
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
   120
for FILE in "$@"
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
   121
do
42034
a77df5241959 propagate mirabelle failures properly;
krauss
parents: 40976
diff changeset
   122
  perl -w "$MIRABELLE_HOME/lib/scripts/mirabelle.pl" "$FILE" || fail "Mirabelle failed."
32382
98674ac811c4 Mirabelle tool script conforming to standard Isabelle tool interface,
boehmes
parents: 32381
diff changeset
   123
done
32381
11542bebe4d4 made Mirabelle a component
boehmes
parents:
diff changeset
   124
42069
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   125
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   126
## cleanup
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   127
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   128
if [ -n "$PURGE_OUTPUT" ]; then
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   129
  rm -rf "$MIRABELLE_OUTPUT_PATH"
6a147393c62a replace hardwired MIRABELLE_OUTPUT_PATH by temporary directory derived from ISABELLE_TMP_PREFIX and $$ -- old behaviour can be achieved by manually setting MIRABELLE_OUTPUT_PATH
krauss
parents: 42034
diff changeset
   130
fi