# HG changeset patch # User wenzelm # Date 1411977454 -7200 # Node ID 890d8286fd4e02b157b59a28384532bd6b99e597 # Parent 66ddc5ad4f6335665e9c7f6252f94dd5b358ccd2 pro-forma support for polyml-5.5.3 (presently SVN 1960); diff -r 66ddc5ad4f63 -r 890d8286fd4e lib/scripts/run-polyml-5.5.3 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/lib/scripts/run-polyml-5.5.3 Mon Sep 29 09:57:34 2014 +0200 @@ -0,0 +1,90 @@ +#!/usr/bin/env bash +# :mode=shellscript: +# +# Author: Makarius +# +# Startup script for Poly/ML 5.5.3. + +export -n INFILE OUTFILE MLTEXT TERMINATE NOWRITE + + +## diagnostics + +function fail() +{ + echo "$1" >&2 + exit 2 +} + +function fail_out() +{ + fail "Unable to create output heap file: \"$OUTFILE\"" +} + +function check_file() +{ + [ ! -f "$1" ] && fail "Unable to locate \"$1\"" +} + + +## compiler executables and libraries + +[ -z "$ML_HOME" ] && fail "Missing ML installation (ML_HOME)" + +POLY="$ML_HOME/poly" +check_file "$POLY" + +librarypath "$ML_HOME" + + + +## prepare databases + +if [ -z "$INFILE" ]; then + INIT="" + EXIT="fun exit rc = Posix.Process.exit (Word8.fromInt rc);" +else + check_file "$INFILE" + INIT="(Signal.signal (2, Signal.SIG_HANDLE (fn _ => Process.interruptConsoleProcesses ())); PolyML.SaveState.loadState \"$INFILE\" handle exn => (TextIO.output (TextIO.stdErr, General.exnMessage exn ^ \": $INFILE\\n\"); Posix.Process.exit 0w1));" + EXIT="" +fi + +if [ -z "$OUTFILE" ]; then + COMMIT='fun commit () = false;' + MLEXIT="" +else + if [ -z "$INFILE" ]; then + COMMIT="fun commit () = (PolyML.shareCommonData PolyML.rootFunction; TextIO.output (TextIO.stdOut, \"Exporting $OUTFILE\n\"); PolyML.SaveState.saveState \"$OUTFILE\"; true) handle exn => (TextIO.output (TextIO.stdErr, General.exnMessage exn ^ \": $OUTFILE\\n\"); Posix.Process.exit 0w1);" + else + COMMIT="fun commit () = (ML_System.share_common_data (); ML_System.save_state \"$OUTFILE\");" + fi + [ -f "$OUTFILE" ] && { chmod +w "$OUTFILE" || fail_out; } + MLEXIT="commit();" +fi + + +## run it! + +MLTEXT="$INIT $EXIT $COMMIT $MLTEXT" + +if [ -n "$TERMINATE" -a -z "$MLEXIT" ]; then + "$POLY" -q -i $ML_OPTIONS --eval "$(perl "$ISABELLE_HOME/lib/scripts/recode.pl" "$MLTEXT")" \ + --error-exit n + | NONE => Thread.numProcessors ()); + end; +end; + +use "ML-Systems/polyml.ML"; + diff -r 66ddc5ad4f63 -r 890d8286fd4e src/Pure/ROOT --- a/src/Pure/ROOT Mon Sep 29 08:13:23 2014 +0200 +++ b/src/Pure/ROOT Mon Sep 29 09:57:34 2014 +0200 @@ -14,6 +14,7 @@ "ML-Systems/overloading_smlnj.ML" "ML-Systems/polyml.ML" "ML-Systems/polyml-5.5.2.ML" + "ML-Systems/polyml-5.5.3.ML" "ML-Systems/pp_dummy.ML" "ML-Systems/proper_int.ML" "ML-Systems/single_assignment.ML" @@ -39,6 +40,7 @@ "ML-Systems/overloading_smlnj.ML" "ML-Systems/polyml.ML" "ML-Systems/polyml-5.5.2.ML" + "ML-Systems/polyml-5.5.3.ML" "ML-Systems/pp_dummy.ML" "ML-Systems/proper_int.ML" "ML-Systems/single_assignment.ML" diff -r 66ddc5ad4f63 -r 890d8286fd4e src/Pure/ROOT.ML --- a/src/Pure/ROOT.ML Mon Sep 29 08:13:23 2014 +0200 +++ b/src/Pure/ROOT.ML Mon Sep 29 09:57:34 2014 +0200 @@ -96,12 +96,14 @@ if ML_System.name = "polyml-5.5.1" orelse ML_System.name = "polyml-5.5.2" + orelse ML_System.name = "polyml-5.5.3" then use "ML/exn_trace_polyml-5.5.1.ML" else (); if ML_System.name = "polyml-5.5.0" orelse ML_System.name = "polyml-5.5.1" orelse ML_System.name = "polyml-5.5.2" + orelse ML_System.name = "polyml-5.5.3" then use "ML/ml_statistics_polyml-5.5.0.ML" else use "ML/ml_statistics_dummy.ML";