4 SCRIPTNAME="$(basename "${0}")"
6 # -------------------------------------------------
12 # -------------------------------------------------
14 DEFAULTRELEASESUFFIX="NONE"
15 DEFAULTNUMBEROFJOBS="10"
17 # -------------------------------------------------
19 echo "${SCRIPTNAME} mac/main.mac njobs releasesuffix paramtogate"
20 echo "default njobs = ${DEFAULTNUMBEROFJOBS}"
21 echo "default releasesuffix = ${DEFAULTRELEASESUFFIX} (NONE means use Gate in PATH)"
22 echo "default paramtogate = \"\" (use \"\" around params and \\ in front of commas)"
24 # -------------------------------------------------
26 test $# -eq 0 && usage && exit 0
28 RELEASESUFFIX=${3:-"${DEFAULTRELEASESUFFIX}"}
29 RELEASEDIR="${HOME}/releases/grid_release${RELEASESUFFIX}"
30 if test "$(dnsdomainname)" = "in2p3.fr"
32 JOBFILE="$(dirname $0)/gate_job_ccin2p3.job"
34 JOBFILE="$(dirname $0)/gate_job_cluster.job"
38 test -f ${JOBFILE} || error "can't find job file ${JOBFILE}"
39 if test "${RELEASESUFFIX}" = "${DEFAULTRELEASESUFFIX}"
42 which Gate 2>&1 >/dev/null || error "there is no Gate in the PATH"
44 test -d ${RELEASEDIR} || error "invalid release dir ${RELEASEDIR}"
47 test -d ${MACRODIR}/mac && test -d ${MACRODIR}/data || error "invalid path"
48 MACROFILE=${1:?"provide relative macro path"}
49 test -f ${MACRODIR}/${MACROFILE} || error "invalid macro"
50 if test "$(dnsdomainname)" = "in2p3.fr"
52 OUTPUTDIR=$(mktemp -d -p "${MACRODIR}" run.XXXX || error "can't create temp dir")
53 ssh -i ${HOME}/.ssh/ccin2p3 linux1.dg.creatis.insa-lyon.fr mkdir -p "cc/$(basename ${OUTPUTDIR})"
56 if [[ "$unamestr" == 'Darwin' ]]; then
57 ## On OSX (Darwin), mktemp version is different from Linux version . We
58 ## need the absolute folder here
59 OUTPUTDIR=$(mktemp -d run.XXXX || error "can't create temp dir")
60 OUTPUTDIR=${MACRODIR}/${OUTPUTDIR}
62 OUTPUTDIR=$(mktemp --tmpdir=${MACRODIR} -d run.XXXX || error "can't create temp dir")
66 test -d ${OUTPUTDIR} || error "can't locate output dir"
67 RUNID=${OUTPUTDIR##*.}
68 NJOBS=${2:-"${DEFAULTNUMBEROFJOBS}"}
73 echo "runid is ${RUNID}"
75 QSUB=$(which qsub 2> /dev/null)
76 # echo "qsub is $(which qsub)"
77 test -z "${QSUB}" && QSUB="noqsub"
78 if test "${QSUB}" = "noqsub"
80 echo "qsub is not found. Simply run Gate on multiple cores."
83 test -z "${PARAM}" && echo "no param" || echo "param is ${PARAM}"
84 if test "$RELEASESUFFIX" = "$DEFAULTRELEASESUFFIX"
86 echo "Gate is $(which Gate)"
88 echo "Gate release is $(basename ${RELEASEDIR})"
90 echo "submitting ${NJOBS} jobs"
92 PARAMFILE="${OUTPUTDIR}/params.txt"
93 echo "njobs = ${NJOBS}" >> "${PARAMFILE}"
94 echo "macro = ${MACROFILE}" >> "${PARAMFILE}"
95 test -z "${PARAM}" || echo "param = ${PARAM}" >> "${PARAMFILE}"
97 # Copy macros files (for log)
98 mkdir ${OUTPUTDIR}/mac
99 cp ${MACROFILE} ${OUTPUTDIR}/mac
100 files=`grep "control/execute" ${MACROFILE} | cut -d " " -f 2`
103 cp $i ${OUTPUTDIR}/mac
106 while test $NJOBS -gt 0; do
108 if test "${QSUB}" = "noqsub"
110 echo "Launching Gate log in ${OUTPUTDIR}/gate_${NJOBS}.log"
111 PARAM=\"${PARAM}\" INDEX=${NJOBS} INDEXMAX=${NJOBSMAX} OUTPUTDIR=${OUTPUTDIR} RELEASEDIR=${RELEASEDIR} MACROFILE=${MACROFILE} MACRODIR=${MACRODIR} PBS_JOBID="local_${NJOBS}" bash "${JOBFILE}" > ${OUTPUTDIR}/gate_${NJOBS}.log &
112 elif test "$(dnsdomainname)" = "in2p3.fr"
115 qsub -o "${OUTPUTDIR}" \
119 -v "PARAM=\"${PARAM}\",INDEX=${NJOBS},INDEXMAX=${NJOBSMAX},OUTPUTDIR=${OUTPUTDIR},RELEASEDIR=${RELEASEDIR},MACROFILE=${MACROFILE},MACRODIR=${MACRODIR}" \
120 "${JOBFILE}" || error "submission error"
122 qsub -N "gatejob.${RUNID}" -o "${OUTPUTDIR}" \
123 -v "PARAM=${PARAM},INDEX=${NJOBS},INDEXMAX=${NJOBSMAX},OUTPUTDIR=${OUTPUTDIR},RELEASEDIR=${RELEASEDIR},MACROFILE=${MACROFILE},MACRODIR=${MACRODIR}" \
124 "${JOBFILE}" || error "submission error"
130 echo "runid is ${RUNID}"