aoqi@0: #!/bin/bash aoqi@0: # aoqi@0: # Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. aoqi@0: # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. aoqi@0: # aoqi@0: # This code is free software; you can redistribute it and/or modify it aoqi@0: # under the terms of the GNU General Public License version 2 only, as aoqi@0: # published by the Free Software Foundation. aoqi@0: # aoqi@0: # This code is distributed in the hope that it will be useful, but WITHOUT aoqi@0: # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or aoqi@0: # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License aoqi@0: # version 2 for more details (a copy is included in the LICENSE file that aoqi@0: # accompanied this code). aoqi@0: # aoqi@0: # You should have received a copy of the GNU General Public License version aoqi@0: # 2 along with this work; if not, write to the Free Software Foundation, aoqi@0: # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. aoqi@0: # aoqi@0: # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA aoqi@0: # or visit www.oracle.com if you need additional information or have any aoqi@0: # questions. aoqi@0: # aoqi@0: aoqi@0: # Usage: sh shell-tracer.sh aoqi@0: # aoqi@0: # This shell script is supposed to be set as a replacement for SHELL in make, aoqi@0: # causing it to be called whenever make wants to execute shell commands. aoqi@0: # The is suitable for passing on to the old shell, aoqi@0: # typically beginning with -c. aoqi@0: # aoqi@0: # This script will make sure the shell command line is executed with aoqi@0: # OLD_SHELL -x, and it will also store a simple log of the the time it takes to aoqi@0: # execute the command in the OUTPUT_FILE, using the "time" utility as pointed aoqi@0: # to by TIME_CMD. If TIME_CMD is "-", no timestamp will be stored. aoqi@0: aoqi@0: TIME_CMD="$1" aoqi@0: OUTPUT_FILE="$2" aoqi@0: OLD_SHELL="$3" aoqi@0: shift aoqi@0: shift aoqi@0: shift aoqi@0: if [ "$TIME_CMD" != "-" ]; then aoqi@0: "$TIME_CMD" -f "[TIME:%E] $*" -a -o "$OUTPUT_FILE" "$OLD_SHELL" -x "$@" aoqi@0: else aoqi@0: "$OLD_SHELL" -x "$@" aoqi@0: fi