view more/timeout.sh @ 1187:878dbfe76341

Move $BUILD/logs creation from record-commands.sh to include.sh so it gets reliably recreated when a user blanks the logs and re-runs.
author Rob Landley <rob@landley.net>
date Sun, 01 Aug 2010 15:19:00 -0500
parents 300e6d919d86
children 2868f2d87624
line wrap: on
line source

#!/bin/bash

# Run a command line with a hang timeout, which kills the child process if it
# doesn't produce a new line of output for $1 seconds.

# This script has to be a separate process (rather than just a shell function)
# so killing it doesn't kill the parent process.

source sources/functions.sh

if [ $# -lt 1 ]
then
  echo "Usage: timeout.sh SECONDS COMMANDS..." >&2
  exit 1
fi

trap "killtree $$" EXIT
TIMEOUT="$1"
shift
( eval "$@" ) | tee >(while read -t "$TIMEOUT" -n 32 i; do true; done; sleep 1; kill -TERM $$ 2>/dev/null )