X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/3356a5d7d4ab2de2e1454a42718319754bb3c68f..2bcb5dd3317c733c31c288ae79e72fb28863d936:/src/smpi/smpicc.in diff --git a/src/smpi/smpicc.in b/src/smpi/smpicc.in index 38240c0f55..33b139112c 100755 --- a/src/smpi/smpicc.in +++ b/src/smpi/smpicc.in @@ -1,42 +1,74 @@ -#! /bin/bash +#! /bin/sh + +# Copyright (c) 2007-2015. 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@" CC=@CMAKE_C_COMPILER@ INCLUDEARGS="@includeflag@" CMAKE_LINKARGS="-L@libdir@" +@SMPITOOLS_SH@ + +list_set CFLAGS +list_set LINKARGS if [ "@WIN32@" != "1" ]; then - CFLAGS="-Dmain=smpi_simulated_main__" - LINKARGS="-lsimgrid -lsmpi" + list_add CFLAGS "-Dmain=smpi_simulated_main_" + list_add LINKARGS "-lsimgrid" else - CFLAGS="-include @includedir@/smpi/smpi_main.h" - LINKARGS="@libdir@\libsimgrid.dll @libdir@\libsmpi.dll" + list_add CFLAGS "-include" "@includedir@/smpi/smpi_main.h" + list_add LINKARGS "@libdir@\libsimgrid.dll" fi -CMDLINE="" -while [ -n "$1" ]; do - ARG="$1" - shift - case "${ARG}" in - -c) - CMAKE_LINKARGS="" - LINKARGS="" - CMDLINE="${CMDLINE} -c " - ;; - *.c) - SRCFILE="$(readlink -f ${ARG} 2>/dev/null)" - if [ -z $SRCFILE ] ; then - SRCFILE="$ARG" - fi - CMDLINE="${CMDLINE} ${SRCFILE} " - ;; - *) - CMDLINE="${CMDLINE} ${ARG} " - ;; - esac +list_set CMDARGS +while [ $# -gt 0 ]; do + ARG="$1" + shift + case "${ARG}" in + -c) + CMAKE_LINKARGS="" + LINKARGS="" + list_add CMDARGS "-c" + ;; + *.c) + SRCFILE="$(readlink -f ${ARG} 2>/dev/null)" + if [ -z "$SRCFILE" ] ; then + SRCFILE="$ARG" + fi + list_add CMDARGS "${SRCFILE}" + ;; + '-version' | '--version') + printf '%b\n' "$SIMGRID_VERSION" + exit 0 + ;; + "-git-version" | "--git-version") + printf '%b\n' "$SIMGRID_GITHASH" + exit 0 + ;; + '-trace-call-location') + list_add_not_empty CMDARGS "-DTRACE_CALL_LOCATION" + ;; + '-compiler-version' | '--compiler-version') + ${CC} --version + ;; + *) + list_add CMDARGS "${ARG}" + ;; + esac done -CMDLINE="${CC} ${CFLAGS} ${CMDLINE} ${INCLUDEARGS} ${CMAKE_LINKARGS} ${LINKARGS}" +list_set CMDLINE "${CC}" +list_add_not_empty CMDLINE "${CFLAGS}" +list_add_not_empty CMDLINE ${INCLUDEARGS} +list_add_not_empty CMDLINE ${CMAKE_LINKARGS} +list_add_not_empty CMDLINE "${CMDARGS}" +list_add_not_empty CMDLINE "${LINKARGS}" -#echo "${CMDLINE}" -${CMDLINE} +eval $(list_get CMDLINE) +"$@"