# HG changeset patch # User wenzelm # Date 1165340009 -3600 # Node ID 219924615db649e2f10f5dc828cbb3d63aadd05d # Parent 3501b5a8a2c18a952ce4faca627540799c3f112b setup for polyml-5.0; diff -r 3501b5a8a2c1 -r 219924615db6 etc/settings --- a/etc/settings Tue Dec 05 18:32:54 2006 +0100 +++ b/etc/settings Tue Dec 05 18:33:29 2006 +0100 @@ -36,10 +36,10 @@ #ML_SYSTEM=polyml-4.2.0 #ML_OPTIONS="-H 80" -# Poly/ML 4.9.1 (experimental!) +# Poly/ML 5.0 #ML_PLATFORM=x86_64-linux #ML_HOME=/usr/local/polyml/x86_64-linux -#ML_SYSTEM=polyml-4.9.1 +#ML_SYSTEM=polyml-5.0 #ML_OPTIONS="-H 500" # Standard ML of New Jersey 110 or later diff -r 3501b5a8a2c1 -r 219924615db6 lib/scripts/run-polyml-5.0 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/lib/scripts/run-polyml-5.0 Tue Dec 05 18:33:29 2006 +0100 @@ -0,0 +1,90 @@ +#!/usr/bin/env bash +# +# $Id$ +# Author: Makarius +# +# Poly/ML startup script (for 5.0) + +export -n INFILE OUTFILE COPYDB COMPRESS MLTEXT TERMINATE NOWRITE + + +## diagnostics + +function fail_out() +{ + echo "Unable to create output heap file: \"$OUTFILE\"" >&2 + exit 2 +} + +function check_file() +{ + if [ ! -f "$1" ]; then + echo "Unable to locate $1" >&2 + echo "Please check your ML system settings!" >&2 + exit 2 + fi +} + + +## compiler executables and libraries + +POLY="$ML_HOME/poly" +check_file "$POLY" + +if [ "$(basename "$ML_HOME")" = bin ]; then + POLYLIB="$(cd "$ML_HOME"; cd "$(pwd -P)"; cd ../lib; pwd)" +else + POLYLIB="$ML_HOME" +fi + +export LD_LIBRARY_PATH="$POLYLIB:$LD_LIBRARY_PATH" +export DYLD_LIBRARY_PATH="$POLYLIB:$DYLD_LIBRARY_PATH" + + +## prepare databases + +if [ -z "$INFILE" ]; then + EXIT="fun exit 0 = (OS.Process.exit OS.Process.success): unit | exit _ = OS.Process.exit OS.Process.failure;" +else + check_file "$INFILE" + POLY="$INFILE" + EXIT="" +fi + +if [ -z "$OUTFILE" ]; then + COMMIT='fun commit () = (TextIO.output (TextIO.stdErr, "Error - Database is not opened for writing.\n"); false);' +else + if [ -z "$COMPRESS" ]; then + COMMIT="fun commit () = (TextIO.output (TextIO.stdOut, \"Exporting $OUTFILE\n\"); PolyML.export (\"$OUTFILE\", PolyML.rootFunction); true);" + else + COMMIT="fun commit () = (PolyML.shareCommonData PolyML.rootFunction; TextIO.output (TextIO.stdOut, \"Exporting $OUTFILE\n\"); PolyML.export (\"$OUTFILE\", PolyML.rootFunction); true);" + fi + [ -f "$OUTFILE" ] && { chmod +w "$OUTFILE" || fail_out; } + rm -f "${OUTFILE}.o" || fail_out +fi + + +## run it! + +MLTEXT="PolyML.Compiler.printInAlphabeticalOrder := false; $EXIT $COMMIT $MLTEXT" +MLEXIT="commit();" + +if [ -z "$TERMINATE" ]; then + FEEDER_OPTS="" +else + FEEDER_OPTS="-q" +fi + +"$ISABELLE_HOME/lib/scripts/feeder" -p -h "$MLTEXT" -t "$MLEXIT" $FEEDER_OPTS | \ + { read FPID; "$POLY" $ML_OPTIONS; RC="$?"; kill -HUP "$FPID"; exit "$RC"; } +RC="$?" + +if [ -n "$OUTFILE" ]; then + if [ -e "${OUTFILE}.o" ]; then + cc -o "$OUTFILE" "${OUTFILE}.o" -L"$POLYLIB" -lpolymain -lpolyml -lstdc++ || fail_out + rm -f "${OUTFILE}.o" + fi + [ -f "$OUTFILE" -a -n "$NOWRITE" ] && chmod -w "$OUTFILE" +fi + +exit "$RC" diff -r 3501b5a8a2c1 -r 219924615db6 src/Pure/ML-Systems/polyml-5.0.ML --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/Pure/ML-Systems/polyml-5.0.ML Tue Dec 05 18:33:29 2006 +0100 @@ -0,0 +1,10 @@ +(* Title: Pure/ML-Systems/polyml-5.0.ML + ID: $Id$ + +Compatibility wrapper for Poly/ML 5.0. +*) + +use "ML-Systems/polyml-4.1.4-patch.ML"; +use "ML-Systems/polyml.ML"; + +val pointer_eq = PolyML.pointerEq;