+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"
+ ;;
+ *.f90)
+ FILENAME=`basename ${ARG}`
+ TMPFILE=$(mymktemp "${ARG}" ".f90")
+ ORIGFILE="${FILENAME%.f90}"
+ filter_and_compile
+ ;;
+ *.F90)
+ FILENAME=`basename ${ARG}`
+ TMPFILE=$(mymktemp "${ARG}" ".F90")
+ ORIGFILE="${FILENAME%.F90}"
+ filter_and_compile
+ ;;
+ '-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
+ ;;
+ -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
+ ;;
+ *)
+ list_add CMDLINE "${ARG}"
+ ;;
+ esac
+done
+
+if [ $NEEDS_OUTPUT -ne 0 ]; then
+ list_add CMDLINE "-o${ORIGFILE}.o"