-#! /bin/sh
+#!/usr/bin/env sh
-prefix="@exec_prefix@"
-smpicc="$prefix/bin/smpicc"
-smpif2c="$prefix/bin/smpif2c"
+# Copyright (c) 2012-2019. The SimGrid Team. All rights reserved.
+
+# This program is free software; you can redistribute it and/or modify it
+# under the terms of the license (GNU LGPL) which comes with this package.
+
+SIMGRID_VERSION="@SIMGRID_VERSION_STRING@"
+SIMGRID_GITHASH="@SIMGRID_GITHASH@"
+
+REAL_FORTRAN_COMPILER=@SMPI_Fortran_COMPILER@
+
+INCLUDEARGS="@includeflag@"
+CMAKE_LINKARGS="-L@libdir@"
@SMPITOOLS_SH@
-list_set ARGS "-DMAIN__=user_main" "-Diargc_=smpi_process_argc" "-Dgetarg_=smpi_process_getarg"
-list_set LINKARGS "-L@F2C_LIBRARY_PATH@" "-lf2c" "-lm"
-list_set SRCFILES
+list_set FFLAGS @SMPI_Fortran_FLAGS@
+list_set LINKARGS "-lsimgrid" @SMPI_Fortran_LIBS@ "-lm"
+if [ "x${SMPI_PRETEND_CC}" = "x" ]; then
+ list_add LINKARGS "-shared"
+else
+ echo "Warning: smpiff pretends to be a regular compiler (SMPI_PRETEND_CC is set). Produced binaries will not be usable in SimGrid."
+fi
+list_set TMPFILES
+main_name=main
+
+cleanup () {
+ eval $(list_get TMPFILES)
+ rm -f "$@"
+}
+trap 'cleanup' EXIT
+filter_and_compile_f77() {
+ list_add TMPFILES "${TMPFILE}"
+ #replace "program main_name by subroutine user_main (and the end clause as well)"
+ if [ $TRACE_CALL_LOCATION -gt 0 ]; then
+ echo "#include \"@includedir@/smpi/smpi_extended_traces_fortran.h\"" > ${TMPFILE}
+ echo "#line 1 \"${ARG}\"" >> ${TMPFILE}
+ fi
+ sed 's/^[[:space:]]\{6\}[[:space:]]*\([eE][nN][dD] \)\{0,1\}[pP][rR][oO][gG][rR][aA][mM][^a-zA-Z0-9]*\([a-zA-Z0-9_]*\)/ \1subroutine user_main /g' "${ARG}" >> "${TMPFILE}"
+ SRCFILE="${TMPFILE}"
+ list_add CMDLINE "${SRCFILE}"
+}
+filter_and_compile_f90() {
+ list_add TMPFILES "${TMPFILE}"
+ #replace "program main_name by subroutine user_main (and the end clause as well)"
+ if [ $TRACE_CALL_LOCATION -gt 0 ]; then
+ echo "#include \"@includedir@/smpi/smpi_extended_traces_fortran.h\"" > ${TMPFILE}
+ echo "#line 1 \"${ARG}\"" >> ${TMPFILE}
+ fi
+ sed 's/^\([[:space:]]*\)\([eE][nN][dD] \)\{0,1\}[pP][rR][oO][gG][rR][aA][mM][^a-zA-Z0-9]*\([a-zA-Z0-9_]*\)/\1\2subroutine user_main /g' "${ARG}" >> "${TMPFILE}"
+ SRCFILE="${TMPFILE}"
+ list_add CMDLINE "${SRCFILE}"
+}
+TRACE_CALL_LOCATION=0
+NEEDS_OUTPUT=1
+
+# By default, we execute the commands instead of only showing them to cmake
+Show=
+
+list_set CMDLINE "${REAL_FORTRAN_COMPILER}"
+list_add_not_empty CMDLINE "${FFLAGS}"
while [ $# -gt 0 ]; do
ARG="$1"
shift
case "${ARG}" in
+ -c)
+ CMAKE_LINKARGS=""
+ LINKARGS=""
+ list_add CMDLINE "-c"
+ ;;
*.f)
- SRCFILE="$(readlink -f ${ARG} 2>/dev/null)"
- if [ -z "$SRCFILE" ] ; then
- SRCFILE="$ARG"
- fi
- list_add SRCFILES "${SRCFILE}"
+ FILENAME=`basename ${ARG}`
+ TMPFILE=$(mymktemp "${ARG}" ".f")
+ ORIGFILE="${FILENAME%.f}"
+ filter_and_compile_f77
;;
+ *.F)$
+ FILENAME=`basename ${ARG}`
+ TMPFILE=$(mymktemp "${ARG}" ".F")
+ ORIGFILE="${FILENAME%.F}"
+ filter_and_compile_f77
+ ;;
+ *.f90)
+ FILENAME=`basename ${ARG}`
+ TMPFILE=$(mymktemp "${ARG}" ".f90")
+ ORIGFILE="${FILENAME%.f90}"
+ filter_and_compile_f90
+ ;;
+ *.F90)$
+ FILENAME=`basename ${ARG}`
+ TMPFILE=$(mymktemp "${ARG}" ".F90")
+ ORIGFILE="${FILENAME%.F90}"
+ filter_and_compile_f90
+ ;;
+ '-version' | '--version')
+ printf '%b\n' "$SIMGRID_VERSION"
+ exit 0
+ ;;
+ "-git-version" | "--git-version")
+ printf '%b\n' "$SIMGRID_GITHASH"
+ exit 0
+ ;;
+ '-compiler-version' | '--compiler-version')
+ ${REAL_FORTRAN_COMPILER} --version
+ ;;
+ '-trace-call-location')
+ TRACE_CALL_LOCATION=1
+ # This should be list_add FFLAGS but it's not possible
+ # anymore: FFLAGS was already moved into CMDLINE above.
+ list_add_not_empty CMDLINE "-ffixed-line-length-none" "-cpp"
+ ;;
+ -o)
+ list_add CMDLINE "-o$1"
+ NEEDS_OUTPUT=0
+ shift
+ ;;
+ '-show'|'-compile-info'|'-link-info')
+ # Dry run displaying commands instead of executing them. Useful to cmake
+ Show=echo
+ ;;
*)
- if [ "${ARG}" = "-c" ]; then
- LINKARGS=""
- fi
- list_add ARGS "${ARG}"
+ list_add CMDLINE "${ARG}"
;;
esac
done
-list_add_not_empty ARGS "${LINKARGS}"
-build () {
- local SRCFILE
- SRCFILE="$1"
- TMPFILE=$(mymktemp "${SRCFILE}" ".f")
- CFILE="${TMPFILE%.f}.c"
-
- eval $(list_get ARGS)
+if [ $NEEDS_OUTPUT -ne 0 ]; then
+ list_add CMDLINE "-o${ORIGFILE}.o"
+fi
- cp "${SRCFILE}" "${TMPFILE}" \
- && "$smpif2c" "${TMPFILE}" \
- && "$smpicc" "$@" "${CFILE}" \
- && rm -f "${CFILE}" \
- && rm -f "${TMPFILE}" \
- || exit $?
+list_add_not_empty CMDLINE ${INCLUDEARGS}
+list_add_not_empty CMDLINE ${CMAKE_LINKARGS}
+list_add_not_empty CMDLINE "${LINKARGS}"
- # When the file is compiled with "-c" and no output file is specified with
- # "-o", rename the output. FIXME: do it properly.
- if [ -f "${CFILE%.c}.o" ]; then
- mv "${CFILE%.c}.o" "${SRCFILE%.f}.o"
- fi
-}
-
-if [ -n "${SRCFILES}" ]; then
- eval $(list_get SRCFILES)
- for SRCFILE in "$@"; do
- build "$SRCFILE"
- done
-else
- eval $(list_get ARGS)
- "$smpicc" "$@"
-fi
+eval $(list_get CMDLINE)
+$Show "$@"