mirror of
https://github.com/HDFGroup/hdf5.git
synced 2024-11-21 01:04:10 +08:00
89fbe00dec
* commit '54957d37f5aa73912763dbb6e308555e863c43f4': Commit copyright header change for src/H5PLpkg.c which was added after running script to make changes. Add new files in release_docs to MANIFEST. Cimmit changes to Makefile.in(s) and H5PL.c that resulted from running autogen.sh. Merge pull request #407 in HDFFV/hdf5 from ~LRKNOX/hdf5_lrk:hdf5_1_10_1 to hdf5_1_10_1 Change copyright headers to replace url referring to file to be removed and replace it with new url for COPYING file.
130 lines
3.7 KiB
Bash
Executable File
130 lines
3.7 KiB
Bash
Executable File
#!/bin/sh
|
|
##
|
|
# Copyright by The HDF Group.
|
|
# Copyright by the Board of Trustees of the University of Illinois.
|
|
# All rights reserved.
|
|
#
|
|
# This file is part of HDF5. The full HDF5 copyright notice, including
|
|
# terms governing use, modification, and redistribution, is contained in
|
|
# the COPYING file, which can be found at the root of the source code
|
|
# distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases.
|
|
# If you do not have access to either file, you may request a copy from
|
|
# help@hdfgroup.org.
|
|
##
|
|
# As a time keeper of the remote daily test process launched by runtest.
|
|
# It sleeps for a certain time and then wakes up to hangup those processes
|
|
# that are still around, assuming they have run too long.
|
|
#
|
|
# Programmer: Albert Cheng
|
|
# Created Date: 2004/12/23
|
|
|
|
# variable initialization
|
|
waitminutes=300 # default to 5 hours == 300 minutes
|
|
debugtimelimit=
|
|
debugflag= # no debug
|
|
|
|
# Function definitions
|
|
#
|
|
# PRINTMSG
|
|
# Print a one line message left justified in a field of 70 characters
|
|
# without newline. More output for this line later.
|
|
#
|
|
PRINTMSG() {
|
|
SPACES=" "
|
|
echo "$* $SPACES" | cut -c1-70 | tr -d '\012'
|
|
}
|
|
|
|
|
|
USAGE()
|
|
{
|
|
echo "Usage: %0 [-h] [-debug] [<time-limit>]"
|
|
echo " Run timekeeper with <time-limit> minutes, default is $waitminutes."
|
|
echo " If <time-limit> is in the form of HH:MM, it means wait till then."
|
|
echo " -h print this help page"
|
|
echo " -debug run debug mode"
|
|
}
|
|
|
|
|
|
ParseOption()
|
|
{
|
|
if [ $# -gt 0 -a "$1" = -h ]; then
|
|
shift
|
|
USAGE
|
|
exit 0
|
|
fi
|
|
if [ $# -gt 0 -a "$1" = -debug ]; then
|
|
shift
|
|
debugflag=yes
|
|
waitminutes=1 # use shorter time for debug
|
|
fi
|
|
if [ $# -gt 0 ]; then
|
|
targettime=$1
|
|
shift
|
|
|
|
# find out it is minutes to wait or HH:MM to wake up
|
|
case $targettime in
|
|
*:*) # HH:MM
|
|
currenttime=`date +%H:%M`
|
|
currenthour=`echo $currenttime | cut -f1 -d:`
|
|
currentminute=`echo $currenttime | cut -f2 -d:`
|
|
targethour=`echo $targettime | cut -f1 -d:`
|
|
targetminute=`echo $targettime | cut -f2 -d:`
|
|
waitminutes=`expr \( $targethour - $currenthour \) \* 60 + $targetminute - $currentminute`
|
|
if test $waitminutes -le 0; then
|
|
# target time is in tomorrow, add 1 day of minutes
|
|
waitminutes=`expr 24 \* 60 + $waitminutes`
|
|
fi
|
|
;;
|
|
*)
|
|
waitminutes=$targettime
|
|
;;
|
|
esac
|
|
fi
|
|
}
|
|
|
|
|
|
# Main body
|
|
echo "Timekeeper started at `date`"
|
|
ParseOption $*
|
|
waitperiod=`expr $waitminutes \* 60` # convert to seconds
|
|
|
|
if [ -z "$debugflag" ]; then
|
|
# normal time keeping mode
|
|
# sleep first
|
|
echo Timekeeper sleeping for $waitperiod seconds
|
|
sleep $waitperiod
|
|
# Look for any processes still around
|
|
echo "Timekeeper woke up at `date`, looking for processes to terminate..."
|
|
for x in PID.* ; do
|
|
if [ -f $x ]; then
|
|
pid=`cat $x`
|
|
# check if process is still around
|
|
if test X$pid \!= X && ps -p $pid > /dev/null; then
|
|
echo "terminating process $x ($pid)"
|
|
kill -HUP $pid
|
|
echo "Remote shell command ended. But some processes might still be"
|
|
echo "running in the remote machine. Login there to verify."
|
|
fi
|
|
fi
|
|
done
|
|
else
|
|
# Debug mode. Launch two rsh process, one ends before, the other after
|
|
# waitperiod. Must launch timekeeper from a subshell, else the debug
|
|
# will wait for it too.
|
|
myhostname=`hostname`
|
|
( $0 $waitminutes &)
|
|
debugtimelimit=`expr $waitperiod - 10`
|
|
echo rsh $myhostname sleep $debugtimelimit
|
|
rsh $myhostname sleep $debugtimelimit &
|
|
echo $! > PID.before
|
|
debugtimelimit=`expr $waitperiod + 10`
|
|
echo rsh $myhostname sleep $debugtimelimit
|
|
rsh $myhostname sleep $debugtimelimit &
|
|
echo $! > PID.after
|
|
|
|
wait
|
|
rm PID.before PID.after
|
|
fi
|
|
|
|
echo "Timekeeper ended at `date`"
|