/[escript]/trunk/bin/run-escript
ViewVC logotype

Contents of /trunk/bin/run-escript

Parent Directory Parent Directory | Revision Log Revision Log


Revision 4993 - (show annotations)
Thu Jun 5 03:04:56 2014 UTC (5 years, 3 months ago) by sshaw
File size: 16994 byte(s)
fixing the launcher to run on all nodes for savanna
1 #!/usr/bin/env sh
2
3 # Escript/Finley wrapper for python
4 # Sets LD_LIBRARY_PATH and PYTHONPATH and then runs either python or the MPI launcher
5
6 #Extra paths can be configured about a page further down
7 #Search for EXTRA_PATH=""
8
9 #set to 1 if performing this is a standalone build and ../../pkg contains the relevant tools
10 STANDALONE=0
11
12 #set to 1 if this is part of a packaged build (.deb) and files will be installed in standard locations
13 #rather than everything in a single directory
14 #Do not use this together with $STANDALONE
15 STDLOCATION=0
16
17 #Now we find the location of this script
18 #Note that this location should be absolute but does not need to be unique
19 scriptdir=""
20 CURDIR=$(pwd)
21
22 #Environment vars which control operations:
23 # ESCRIPT_NUM_NODES, ESCRIPT_NUM_PROCS, ESCRIPT_NUM_THREADS, ESCRIPT_HOSTFILE, ESCRIPT_CREATESTDFILES
24
25 HOSTFILE=/tmp/escript.$USER.$$
26 HOSTFILE2=/tmp/escript2.$USER.$$
27
28 #Begin finding ESCRIPT_ROOT
29 if [ $STDLOCATION -ne 0 ]
30 then
31 ESCRIPT_ROOT=/usr/lib/python-escript
32 else
33 # We don't know the escript root so we need to work it out from the invocation
34 # Need to match if the name contains /
35 if $(echo $0|grep -q /)
36 then
37 # We are not using the PATH to find the script
38 cd "$(dirname $0)"
39 scriptdir=$(pwd)
40 cd "$CURDIR"
41 else
42 # name does not contain / therefore we are using
43 tscriptdir=$(which $0)
44 if [ $? -ne 0 ]
45 then
46 echo "Error! Unable to determine script directory. Exiting."
47 exit 1
48 fi
49 scriptdir=$(dirname $tscriptdir)
50 fi
51
52 cd "$scriptdir/.."
53 ESCRIPT_ROOT=$(pwd)
54 cd ..
55 ESCRIPT_PARENT=$(pwd)
56 cd "$CURDIR"
57
58 fi
59 ##### End finding ESCRIPT_ROOT ########
60
61 PYTHON_MPI_NULL="$ESCRIPT_ROOT/lib/pythonMPI"
62 PYTHON_MPI_REDIRECT="$ESCRIPT_ROOT/lib/pythonMPIredirect"
63 PYTHON_CMD=python
64
65 # if possible please express paths relative to $ESCRIPT_ROOT unless
66 # they are in an unrelated location
67
68 EXTRA_DYLD_LIBRARY_PATH=""
69 EXTRA_PATH=$ESCRIPT_ROOT/bin
70 EXTRA_PYTHONPATH=$ESCRIPT_ROOT
71
72 if [ $STDLOCATION -eq 1 ]
73 then
74 EXTRA_LD_LIBRARY_PATH=/usr/lib/python-escript
75 else
76 EXTRA_LD_LIBRARY_PATH=$ESCRIPT_ROOT/lib
77 fi
78
79
80 if [ $STANDALONE -eq 1 ]
81 then
82 EXTRA_PATH=$ESCRIPT_PARENT/pkg/python/bin:$ESCRIPT_PARENT/pkg/scons/bin:$EXTRA_PATH
83 EXTRA_LD_LIBRARY_PATH=$ESCRIPT_PARENT/pkg/boost/lib:$ESCRIPT_PARENT/pkg/netcdf/lib/:$EXTRA_LD_LIBRARY_PATH
84 EXTRA_LD_LIBRARY_PATH=$EXTRA_LD_LIBRARY_PATH
85 EXTRA_LD_LIBRARY_PATH=$ESCRIPT_PARENT/pkg/python/lib:$EXTRA_LD_LIBRARY_PATH
86 EXTRA_PYTHONPATH=$ESCRIPT_PARENT/pkg/numpy/lib/python2.6/site-packages:$ESCRIPT_PARENT/pkg/matplotlib/lib/python2.6/site-packages:$EXTRA_PYTHONPATH
87 fi
88
89
90 BUILDINFO_FILE="$ESCRIPT_ROOT/lib/buildvars"
91 if [ "$STDLOCATION" = "1" ]
92 then
93 BUILDINFO_FILE=/usr/lib/python-escript/buildvars
94 fi
95 if [ ! -r "$BUILDINFO_FILE" ]; then
96 if [ "$1" = "-e" ]; then
97 echo "export LD_LIBRARY_PATH=$EXTRA_LD_LIBRARY_PATH:\$LD_LIBRARY_PATH"
98 echo "export PYTHONPATH=$EXTRA_PYTHONPATH:\$PYTHONPATH"
99 echo "export PATH=$EXTRA_PATH:\$PATH"
100 if [ "$(uname)" = "Darwin" ]
101 then
102 echo "export DYLD_LIBRARY_PATH=$EXTRA_DYLD_LIBRARY_PATH:$EXTRA_LD_LIBRARY_PATH:\$DYLD_LIBRARY_PATH"
103 fi
104 exit 0
105 fi
106 echo "Error! Unable to read escript build information. Exiting."
107 exit 1
108 fi
109
110 get_buildvar () {
111 echo $(grep "^$1=" "$BUILDINFO_FILE" |cut -d= -f2)
112 }
113
114 #
115 # Add VisIt paths if required
116 #
117 WITH_VISIT=$(get_buildvar visit)
118 if [ "$WITH_VISIT" = "1" ]; then
119 VISIT_BIN=$(which visit 2>/dev/null)
120 if [ $? -eq 0 ]; then
121 VISIT_PY_PATH=$($VISIT_BIN -env | grep LIBPATH | cut -d= -f2)
122 EXTRA_PYTHONPATH=$EXTRA_PYTHONPATH:$VISIT_PY_PATH
123 EXTRA_LD_LIBRARY_PATH=$EXTRA_LD_LIBRARY_PATH:$VISIT_PY_PATH
124 elif [ ! -z $ESCRIPT_VERBOSE ]; then
125 echo "VisIt module enabled but VisIt not in path!"
126 fi
127 fi
128
129 HELP_TEXT="
130 Usage: run-escript [options] script.py [arguments...]
131 -n nn number of nodes to use
132 -p np number of MPI processes to spawn per node
133 -t nt number of OpenMP threads to use
134 -f file name of MPI hostfile
135 -c print compile information for escript and exit
136 -V print escript version and exit
137 -i interactive mode
138 -b do not invoke python (run non-python programs)
139 -e print export statements for environment and exit
140 -o redirect output from MPI to files
141 -v print diagnostics
142 -x run in new xterm instance
143 -m tool run with valgrind {tool=m[emcheck]/c[allgrind]}
144 script.py Your python script
145 arguments... The optional command-line arguments to your script
146 "
147
148 if [ "$1" = "--help" ]; then
149 echo "$HELP_TEXT"
150 exit 0
151 fi
152 #==============================================================================
153
154 # Parse the command-line options
155 while getopts 'bn:p:t:f:echim:oVvx' option
156 do
157 case "$option" in
158 "b") DO_BINARY=y
159 ;;
160 "m") DO_VALGRIND=$OPTARG
161 ;;
162 "n") ESCRIPT_NUM_NODES=$OPTARG
163 ;;
164 "p") ESCRIPT_NUM_PROCS=$OPTARG
165 ;;
166 "t") ESCRIPT_NUM_THREADS=$OPTARG
167 ;;
168 "f") ESCRIPT_HOSTFILE=$OPTARG
169 ;;
170 "c") cat "$BUILDINFO_FILE"
171 exit 0
172 ;;
173 "V") echo "escript-development(build "$(get_buildvar svn_revision)")"
174 exit 0
175 ;;
176 "h") echo "$HELP_TEXT"
177 exit 0
178 ;;
179 "i") DO_INTERACTIVE=y
180 ;;
181 "e") echo "export LD_LIBRARY_PATH=$EXTRA_LD_LIBRARY_PATH:\$LD_LIBRARY_PATH"
182 echo "export PYTHONPATH=$EXTRA_PYTHONPATH:\$PYTHONPATH"
183 echo "export PATH=$EXTRA_PATH:\$PATH"
184 if [ "$(uname)" = "Darwin" ]
185 then
186 echo "export DYLD_LIBRARY_PATH=$EXTRA_DYLD_LIBRARY_PATH:$EXTRA_LD_LIBRARY_PATH:\$DYLD_LIBRARY_PATH"
187 fi
188 exit 0
189 ;;
190 "o") ESCRIPT_CREATESTDFILES=y
191 ;;
192 "v") ESCRIPT_VERBOSE=y
193 ;;
194 "x") DO_XTERM=y
195 ;;
196 ?) echo "$HELP_TEXT"
197 exit 1
198 ;;
199 esac
200 done
201 shift $(($OPTIND - 1))
202 #==============================================
203 #
204 # Read MPI_FLAVOUR and WITH_OPENMP from the buildvars
205 #
206 MPI_FLAVOUR=$(get_buildvar mpi)
207 WITH_OPENMP=$(get_buildvar openmp)
208
209 if [ ! -z $ESCRIPT_VERBOSE ]; then
210 echo "MPI flavour is $MPI_FLAVOUR."
211 if [ "$WITH_OPENMP" = "1" ]; then echo "OpenMP enabled."; fi
212 fi
213
214 #
215 # extend path variables
216 #
217 export PATH=$EXTRA_PATH:$PATH
218 export LD_LIBRARY_PATH=$EXTRA_LD_LIBRARY_PATH:$LD_LIBRARY_PATH
219 export PYTHONPATH=$EXTRA_PYTHONPATH:$PYTHONPATH
220 EXPORT_ENV="PATH,LD_LIBRARY_PATH,PYTHONPATH"
221 if [ "$(uname)" = "Darwin" ]
222 then
223 export DYLD_LIBRARY_PATH=$EXTRA_DYLD_LIBRARY_PATH:$EXTRA_LD_LIBRARY_PATH:$DYLD_LIBRARY_PATH
224 EXPORT_ENV="$EXPORT_ENV,DYLD_LIBRARY_PATH"
225 fi
226 if [ ! -z $ESCRIPT_VERBOSE ]
227 then
228 echo "PATH = $PATH "
229 echo "LD_LIBRARY_PATH = $LD_LIBRARY_PATH "
230 echo "PYTHONPATH = $PYTHONPATH "
231 if [ ! -z $DYLD_LIBRARY_PATH ]; then echo "DYLD_LIBRARY_PATH = $DYLD_LIBRARY_PATH "; fi
232 fi
233 #==============================================
234 #
235 # Ensure the variables have sensible values
236 #
237 if [ "$MPI_FLAVOUR" = "none" ]
238 then
239 if [ ! -z "$ESCRIPT_NUM_NODES" ]; then
240 if [ $ESCRIPT_NUM_NODES -gt 1 ]; then
241 echo "Warning: MPI disabled but number of nodes set. Option ignored."
242 fi
243 fi
244 if [ ! -z "$ESCRIPT_NUM_PROCS" ]; then
245 if [ $ESCRIPT_NUM_PROCS -gt 1 ]; then
246 echo "Warning: MPI disabled but number of processors per node set. Option ignored."
247 fi
248 fi
249 if [ ! -z "$ESCRIPT_HOSTFILE" ]
250 then
251 echo "Warning: MPI disabled but host file is given. Option ignored."
252 fi
253 ESCRIPT_NUM_NODES=1
254 ESCRIPT_NUM_PROCS=1
255 else
256 # use the PBS_NODEFILE if not otherwise specified
257 if [ ! -z "$PBS_NODEFILE" ] && [ -z "$ESCRIPT_HOSTFILE" ]
258 then
259 ESCRIPT_HOSTFILE=$PBS_NODEFILE
260 fi
261
262 if [ ! -z "$ESCRIPT_HOSTFILE" ]
263 then
264 if [ -f "$ESCRIPT_HOSTFILE" ]
265 then
266 cat "$ESCRIPT_HOSTFILE" | sort -u > $HOSTFILE
267 NUM_HOSTS=$(cat "$HOSTFILE" | wc -l)
268 if [ ! -z $ESCRIPT_NUM_NODES ]
269 then
270 if [ $NUM_HOSTS -ne $ESCRIPT_NUM_NODES ]
271 then
272 echo "number of hosts selected in the host file $ESCRIPT_HOSTFILE needs to match the requested number of nodes $ESCRIPT_NUM_NODES."
273 exit 1
274 fi
275 else
276 ESCRIPT_NUM_NODES=$NUM_HOSTS
277 fi
278 else
279 echo "cannot find hostfile $ESCRIPT_HOSTFILE."
280 exit 1
281 fi
282 else
283 HOSTFILE=''
284 fi
285
286 if [ -z $ESCRIPT_NUM_NODES ]
287 then
288 ESCRIPT_NUM_NODES=1
289 fi
290
291 if [ -z $ESCRIPT_NUM_PROCS ]
292 then
293 ESCRIPT_NUM_PROCS=1
294 fi
295
296 if [ ! -z $ESCRIPT_VERBOSE ]
297 then
298 echo "ESCRIPT_NUM_NODES = $ESCRIPT_NUM_NODES "
299 echo "ESCRIPT_NUM_PROCS = $ESCRIPT_NUM_PROCS "
300 fi
301 fi
302
303 if [ "$WITH_OPENMP" = "1" ]
304 then
305 if [ -z $ESCRIPT_NUM_THREADS ]
306 then
307 ESCRIPT_NUM_THREADS=$OMP_NUM_THREADS
308 if [ -z $ESCRIPT_NUM_THREADS ]
309 then
310 ESCRIPT_NUM_THREADS=1
311 fi
312 fi
313 if [ ! -z $ESCRIPT_VERBOSE ]
314 then
315 echo "ESCRIPT_NUM_THREADS is $ESCRIPT_NUM_THREADS."
316 fi
317 else
318 if [ ! -z $ESCRIPT_NUM_THREADS ] && [ $ESCRIPT_NUM_THREADS != 1 ]
319 then
320 echo "Warning: OpenMP is disabled but number of threads requested is $ESCRIPT_NUM_THREADS!=1. Running without threads."
321 fi
322 ESCRIPT_NUM_THREADS=1
323 fi
324 #
325 # Now we compute total number of Processes
326 #
327 TOTPROC=$((ESCRIPT_NUM_NODES * ESCRIPT_NUM_PROCS))
328 if [ $? -ne 0 ] #Some compute error
329 then #This could happen if the args were not a number
330 echo "expression of total number of processors = $ESCRIPT_NUM_NODES * $ESCRIPT_NUM_PROCS is not numerical."
331 exit 1
332 fi
333
334 #
335 # Test to ensure people aren't trying to combine interactive and multi-process
336 #
337 if ([ ! -z $DO_INTERACTIVE ] || [ $# -eq 0 ]) && ([ $TOTPROC -gt 1 ])
338 then
339 echo "Interactive mode cannot be used with more than one process"
340 exit 1
341 fi
342
343 if [ $TOTPROC -gt 1 ]
344 then
345 if [ "$ESCRIPT_CREATESTDFILES" = "y" ]
346 then
347 PYTHON_MPI=$PYTHON_MPI_REDIRECT
348 else
349 PYTHON_MPI=$PYTHON_MPI_NULL
350 fi
351 else
352 PYTHON_MPI=$PYTHON_MPI_NULL
353 fi
354 #==============================================================================
355 # Must have at least one command-line arg: the python script
356 if [ $# -eq 0 ]
357 then
358 if [ ! -z $DO_BINARY ]
359 then
360 echo "No program to run was specified. Exiting."
361 exit 1
362 else
363 DO_INTERACTIVE=y
364 fi
365 fi
366
367 #==============================================================================
368
369 if [ ! -z $DO_XTERM ]
370 then
371 EXEC_CMD="xterm -e"
372 else
373 EXEC_CMD=""
374 fi
375
376 if [ ! -z "$DO_VALGRIND" ]
377 then
378 VALGRIND_BIN=$(which valgrind 2>/dev/null)
379 if [ $? -eq 0 ]; then
380 LOGDIR=$ESCRIPT_ROOT/valgrind_logs
381 [ -d $LOGDIR ] || mkdir $LOGDIR
382 VG_TOOL=$(echo $DO_VALGRIND | awk '{ s=substr($0,1,1);print s;}')
383 if [ $VG_TOOL = "c" ];
384 then
385 # run callgrind
386 LOGFILE=${LOGDIR}/callgrind.%p.xml
387 VALGRIND="valgrind --tool=callgrind --callgrind-out-file=$LOGFILE"
388 EXEC_CMD="$EXEC_CMD $VALGRIND"
389 else
390 # run memcheck by default
391 LAST_N=$(ls -1 $LOGDIR|grep "^memcheck"|tail -1|cut -d. -f2)
392 NEW_N=$(printf "%04d" $((LAST_N + 1)))
393 LOGFILE=${LOGDIR}/memcheck.${NEW_N}.xml
394 VALGRIND="valgrind --tool=memcheck --xml=yes --show-reachable=yes --error-limit=no --gen-suppressions=all --suppressions=$ESCRIPT_ROOT/scripts/escript.supp --leak-check=full --xml-file=$LOGFILE"
395 EXEC_CMD="$EXEC_CMD $VALGRIND"
396 fi
397 else
398 echo "Execution with valgrind requested but valgrind not in path!"
399 exit 1
400 fi
401 fi
402
403 if [ ! -z $DO_BINARY ]
404 then
405 EXEC_CMD="$EXEC_CMD $@"
406 else
407 # Check to see if the python version we were compiled with matches the
408 # one of PYTHON_CMD.
409 compfull=$(get_buildvar python_version)
410 compversion=$(echo $compfull | cut -d. -f1,2)
411 compmajor=$(echo $compfull | cut -d. -f1)
412 if [ "$PYTHON_CMD" = "python" ] # if people have customised the command they
413 then # might not want us changing it
414 if [ "$compmajor" = "3" ]
415 then
416 PYTHON_CMD=python3
417 fi
418 fi
419 intversion=$($PYTHON_CMD -c 'from __future__ import print_function;import sys;print("%d.%d"%(sys.version_info[0], sys.version_info[1]))')
420 if [ "$compversion" != "$intversion" ]
421 then
422 echo "Python versions do not match. Escript was compiled for "$compversion"."
423 echo "Current version of Python appears to be "$intversion"."
424 exit 1
425 fi
426 if [ "$MPI_FLAVOUR" = "none" ]
427 then
428 if [ ! -z $DO_INTERACTIVE ]
429 then
430 EXEC_CMD="$EXEC_CMD $PYTHON_CMD -i $@"
431 else
432 EXEC_CMD="$EXEC_CMD $PYTHON_CMD $@"
433 fi
434 else
435 if [ ! -z $DO_INTERACTIVE ]
436 then
437 EXEC_CMD="$EXEC_CMD $PYTHON_MPI -i $@"
438 else
439 EXEC_CMD="$EXEC_CMD $PYTHON_MPI $@"
440 fi
441 fi
442 fi
443 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "Command to be executed is \"$EXEC_CMD\"."; fi
444 #==============================================================================
445 #
446 # now we start to spawn things:
447 #
448 if [ "$WITH_OPENMP" = "1" ]
449 then
450 export OMP_NUM_THREADS=$ESCRIPT_NUM_THREADS
451 EXPORT_ENV="$EXPORT_ENV,OMP_NUM_THREADS"
452 fi
453 EXIT_CODE=1
454 #=============== no MPI ===================================
455 if [ "$MPI_FLAVOUR" = "none" ]
456 then
457 $EXEC_CMD
458 EXIT_CODE=$?
459 #=============== OpenMPI ===================================
460 elif [ "$MPI_FLAVOUR" = "OPENMPI" ]
461 then
462 EXPORT_ENV=$(echo $EXPORT_ENV|sed -e 's/,/ -x /g')
463 if [ ! -z "$HOSTFILE" ]
464 then
465 HOST_LIST=$(sort -u "$HOSTFILE" | awk 'BEGIN{S=""}{if (S == "") { S = $0 } else {S = S "," $0}}END{print S}')
466 CMD="mpirun --gmca mpi_warn_on_fork 0 -x ${EXPORT_ENV} --bynode --bind-to-none --host $HOST_LIST -np $TOTPROC $EXEC_CMD"
467 else
468 CMD="mpirun --gmca mpi_warn_on_fork 0 -x ${EXPORT_ENV} --cpus-per-rank $ESCRIPT_NUM_THREADS -np $TOTPROC $EXEC_CMD"
469 fi
470 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "MPI command is \"$CMD\"."; fi
471 $CMD
472 EXIT_CODE=$?
473
474 #=============== Intel MPI ===================================
475 elif [ "$MPI_FLAVOUR" = "INTELMPI" ]
476 then
477
478 if [ "$WITH_OPENMP" = "1" ]
479 then
480 export I_MPI_PIN_DOMAIN=omp
481 EXPORT_ENV="$EXPORT_ENV,I_MPI_PIN_DOMAIN"
482 fi
483
484 if [ ! -z "$HOSTFILE" ]
485 then
486 CMD="mpirun -hostfile $HOSTFILE -n $TOTPROC -ppn $ESCRIPT_NUM_PROCS $EXEC_CMD"
487 else
488 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "Empty hostfile, running on single node"; fi
489 CMD="mpirun -n 1 -ppn $ESCRIPT_NUM_PROCS $EXEC_CMD"
490 fi
491 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "MPI command is \"$CMD\"."; fi
492 $CMD
493 EXIT_CODE=$?
494 #=============== SGI's MPIMPT ===================================
495 elif [ "$MPI_FLAVOUR" = "MPT" ]
496 then
497 export MPI_NUM_MEMORY_REGIONS=0
498 EXPORT_ENV="$EXPORT_ENV,MPI_NUM_MEMORY_REGIONS"
499 if [ ! -z "$HOSTFILE" ]
500 then
501 HOST_LIST=$(awk 'BEGIN{S=""}{if (S == "") { S = $0 } else {S = S "," $0}}END{print S}' "$HOSTFILE")
502 CMD="mpirun $HOST_LIST -np $ESCRIPT_NUM_PROCS $EXEC_CMD"
503 else
504 CMD="mpirun -np $TOTPROC $EXEC_CMD"
505 fi
506 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "MPI command is \"$CMD\"."; fi
507 $CMD
508 EXIT_CODE=$?
509 #=============== MPICH ===================================
510 elif [ "$MPI_FLAVOUR" = "MPICH" ]
511 then
512 if [ ! -z "$HOSTFILE" ]
513 then
514 touch "$HOSTFILE2"
515 for i in $(seq $ESCRIPT_NUM_PROCS); do cat "$HOSTFILE" >> "$HOSTFILE2"; done
516 CMD="mpirun -machinefile \"$HOSTFILE2\" -np $TOTPROC $EXEC_CMD"
517 else
518 CMD="mpirun -np $TOTPROC $EXEC_CMD"
519 fi
520 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "MPI command is \"$CMD\"."; fi
521 $CMD
522 EXIT_CODE=$?
523 #=============== MPICH2 ===================================
524 elif [ "$MPI_FLAVOUR" = "MPICH2" ]
525 then
526 if [ ! -z "$HOSTFILE" ]
527 then
528 mpdboot -n $ESCRIPT_NUM_NODES -r ssh -f "$HOSTFILE"
529 if [ $? -ne 0 ]
530 then
531 echo "mpdboot with host file $ESCRIPT_HOSTFILE for $ESCRIPT_NUM_NODES nodes failed."
532 exit 1
533 else
534 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "mpdboot was started with host file $HOSTFILE for $ESCRIPT_NUM_NODES nodes."; fi
535 fi
536 else
537 mpdboot -n 1 -r ssh
538 if [ $? -ne 0 ]
539 then
540 echo "mpdboot failed."
541 exit 1
542 else
543 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "mpdboot was started."; fi
544 fi
545 fi
546 CMD="mpiexec -genvlist $EXPORT_ENV -np $TOTPROC $EXEC_CMD"
547 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "MPI command is \"$CMD\"."; fi
548 $CMD
549 EXIT_CODE=$?
550 mpdallexit
551 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "mpdallexit executed."; fi
552 else
553 echo "unknown MPI flavour '$MPI_FLAVOUR'."
554 fi
555
556 if [ ! -z "$DO_VALGRIND" ]; then
557 echo "Valgrind log file written to ${LOGFILE}"
558 fi
559
560 exit $EXIT_CODE
561

Properties

Name Value
svn:executable *
svn:mergeinfo /branches/3.4/bin/run-escript:4453-4490 /branches/lapack2681/bin/escript:2682-2741 /branches/pasowrap/bin/run-escript:3661-3674 /branches/py3_attempt2/bin/run-escript:3871-3891 /branches/release3.4/bin/run-escript:4452 /branches/restext/bin/escript:2610-2624 /branches/ripleygmg_from_3668/bin/run-escript:3669-3791 /branches/stage3.0/bin/escript:2569-2590 /branches/symbolic_from_3470/bin/run-escript:3471-3974 /branches/symbolic_from_3470/ripley/test/python/bin/run-escript:3517-3974 /release/3.0/bin/escript:2591-2601 /trunk/ripley/test/python/bin/run-escript:3480-3515

  ViewVC Help
Powered by ViewVC 1.1.26