#!/bin/bash
@@{PARTITION}
@@{CONSTRAINTS}
#SBATCH --nodes=@@{NNODES}-@@{NNODES}
#SBATCH --ntasks-per-node=@@{PPN}
#SBATCH --time=@@{WALLTIME}
#SBATCH -J JOB_@@{JOBID}_@@{INSTANCEID}
#SBATCH -o slurm_@@{RUNNAME}_@@{INSTANCEID}_@@{CLUSTERID}.stdout
#SBATCH -e slurm_@@{RUNNAME}_@@{INSTANCEID}_@@{CLUSTERID}.stderr
@@{REMOTEBATCHACCOUNT}
@@{SUBMISSIONSCRIPTCOMMANDS}

@@{ENVIRONMENT}

# ExecuteSLURM:makeSerialTemplate
# SubmissionScripts/Distributor/Batch/SLURM/pegasusserial

trap cleanup HUP INT QUIT ABRT TERM

cleanup()
{
   echo "Abnormal termination by signal"
   if [ ! -s @@{TS_FINISH} ] ; then
      date +"%s" > @@{TS_FINISH}
   fi
   exit 1
}

export PATH=${SLURM_SUBMIT_DIR}:${PATH}
# Change to directory where job was submitted.
cd ${SLURM_SUBMIT_DIR}

date +"%s" > @@{TS_START}

@@{PREMANAGERCOMMANDS}
TIMEPATH=
if [ -n "@@{TIMEPATHS}" ] ; then
   for timePath in @@{TIMEPATHS} ; do
      if [ -x ${timePath} ] ; then
         TIMEPATH=${timePath}
         break
      fi
   done
fi

if [ -n "${TIMEPATH}" ] ; then
   ${TIMEPATH} --format "Command exited with status %x\nreal %e\nuser %U\nsys %S" -o @@{TIME_RESULTS} \
      @@{EXECUTABLE} @@{ARGUMENTS}  < @@{STDIN} \
                                    > @@{STDOUT} \
                                   2> @@{STDERR}
else
   { time -p @@{EXECUTABLE} @@{ARGUMENTS}  < @@{STDIN} \
                                           > @@{STDOUT} \
                                          2> @@{STDERR} ; } \
                 > @@{TIME_RESULTS} 2>&1
   echo "Command exited with status $?" >> @@{TIME_RESULTS}
fi
@@{POSTMANAGERCOMMANDS}

date +"%s" > @@{TS_FINISH}
