Blame debug/xtrace.sh

Packit Service 82fcde
#! @BASH@
Packit Service 82fcde
# Copyright (C) 1999-2018 Free Software Foundation, Inc.
Packit Service 82fcde
# This file is part of the GNU C Library.
Packit Service 82fcde
# Contributed by Ulrich Drepper <drepper@gnu.org>, 1999.
Packit Service 82fcde
Packit Service 82fcde
# The GNU C Library is free software; you can redistribute it and/or
Packit Service 82fcde
# modify it under the terms of the GNU Lesser General Public
Packit Service 82fcde
# License as published by the Free Software Foundation; either
Packit Service 82fcde
# version 2.1 of the License, or (at your option) any later version.
Packit Service 82fcde
Packit Service 82fcde
# The GNU C Library is distributed in the hope that it will be useful,
Packit Service 82fcde
# but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 82fcde
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 82fcde
# Lesser General Public License for more details.
Packit Service 82fcde
Packit Service 82fcde
# You should have received a copy of the GNU Lesser General Public
Packit Service 82fcde
# License along with the GNU C Library; if not, see
Packit Service 82fcde
# <http://www.gnu.org/licenses/>.
Packit Service 82fcde
Packit Service 82fcde
pcprofileso='@SLIBDIR@/libpcprofile.so'
Packit Service 82fcde
pcprofiledump='@BINDIR@/pcprofiledump'
Packit Service 82fcde
TEXTDOMAIN=libc
Packit Service 82fcde
Packit Service 82fcde
# Print usage message.
Packit Service 82fcde
do_usage() {
Packit Service 82fcde
  printf $"Usage: xtrace [OPTION]... PROGRAM [PROGRAMOPTION]...\n"
Packit Service 82fcde
  exit 0
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
# Refer to --help option.
Packit Service 82fcde
help_info() {
Packit Service 82fcde
  printf >&2 $"Try \`%s --help' or \`%s --usage' for more information.\n" xtrace xtrace
Packit Service 82fcde
  exit 1
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
# Message for missing argument.
Packit Service 82fcde
do_missing_arg() {
Packit Service 82fcde
  printf >&2 $"%s: option '%s' requires an argument.\n" xtrace "$1"
Packit Service 82fcde
  help_info
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
# Print help message
Packit Service 82fcde
do_help() {
Packit Service 82fcde
  printf $"Usage: xtrace [OPTION]... PROGRAM [PROGRAMOPTION]...\n"
Packit Service 82fcde
  printf $"Trace execution of program by printing currently executed function.
Packit Service 82fcde
Packit Service 82fcde
     --data=FILE          Don't run the program, just print the data from FILE.
Packit Service 82fcde
Packit Service 82fcde
   -?,--help              Print this help and exit
Packit Service 82fcde
      --usage             Give a short usage message
Packit Service 82fcde
   -V,--version           Print version information and exit
Packit Service 82fcde
Packit Service 82fcde
Mandatory arguments to long options are also mandatory for any corresponding
Packit Service 82fcde
short options.
Packit Service 82fcde
Packit Service 82fcde
"
Packit Service 82fcde
  printf $"For bug reporting instructions, please see:\\n%s.\\n" \
Packit Service 82fcde
    "@REPORT_BUGS_TO@"
Packit Service 82fcde
  exit 0
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
do_version() {
Packit Service 82fcde
  echo 'xtrace @PKGVERSION@@VERSION@'
Packit Service 82fcde
  printf $"Copyright (C) %s Free Software Foundation, Inc.
Packit Service 82fcde
This is free software; see the source for copying conditions.  There is NO
Packit Service 82fcde
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
Packit Service 82fcde
" "2018"
Packit Service 82fcde
  printf $"Written by %s.
Packit Service 82fcde
" "Ulrich Drepper"
Packit Service 82fcde
  exit 0
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
# Print out function name, file, and line number in a nicely formatted way.
Packit Service 82fcde
format_line() {
Packit Service 82fcde
  fct=$1
Packit Service 82fcde
  file=${2%%:*}
Packit Service 82fcde
  line=${2##*:}
Packit Service 82fcde
  width=$(expr $COLUMNS - 30)
Packit Service 82fcde
  filelen=$(expr length $file)
Packit Service 82fcde
  if test "$filelen" -gt "$width"; then
Packit Service 82fcde
    rwidth=$(expr $width - 3)
Packit Service 82fcde
    file="...$(expr substr $file $(expr 1 + $filelen - $rwidth) $rwidth)"
Packit Service 82fcde
  fi
Packit Service 82fcde
  printf '%-20s  %-*s  %6s\n' $fct $width $file $line
Packit Service 82fcde
}
Packit Service 82fcde
Packit Service 82fcde
Packit Service 82fcde
# If the variable COLUMNS is not set do this now.
Packit Service 82fcde
COLUMNS=${COLUMNS:-80}
Packit Service 82fcde
Packit Service 82fcde
# If `TERMINAL_PROG' is not set, set it to `xterm'.
Packit Service 82fcde
TERMINAL_PROG=${TERMINAL_PROG:-xterm}
Packit Service 82fcde
Packit Service 82fcde
# The data file to process, if any.
Packit Service 82fcde
data=
Packit Service 82fcde
Packit Service 82fcde
# Process arguments.  But stop as soon as the program name is found.
Packit Service 82fcde
while test $# -gt 0; do
Packit Service 82fcde
  case "$1" in
Packit Service 82fcde
  --d | --da | --dat | --data)
Packit Service 82fcde
    if test $# -eq 1; then
Packit Service 82fcde
      do_missing_arg $1
Packit Service 82fcde
    fi
Packit Service 82fcde
    shift
Packit Service 82fcde
    data="$1"
Packit Service 82fcde
    ;;
Packit Service 82fcde
  --d=* | --da=* | --dat=* | --data=*)
Packit Service 82fcde
    data=${1##*=}
Packit Service 82fcde
    ;;
Packit Service 82fcde
  -\? | --h | --he | --hel | --help)
Packit Service 82fcde
    do_help
Packit Service 82fcde
    ;;
Packit Service 82fcde
  -V | --v | --ve | --ver | --vers | --versi | --versio | --version)
Packit Service 82fcde
    do_version
Packit Service 82fcde
    ;;
Packit Service 82fcde
  --u | --us | --usa | --usag | --usage)
Packit Service 82fcde
    do_usage
Packit Service 82fcde
    ;;
Packit Service 82fcde
  --)
Packit Service 82fcde
    # Stop processing arguments.
Packit Service 82fcde
    shift
Packit Service 82fcde
    break
Packit Service 82fcde
    ;;
Packit Service 82fcde
  --*)
Packit Service 82fcde
    printf >&2 $"xtrace: unrecognized option \`$1'\n"
Packit Service 82fcde
    help_info
Packit Service 82fcde
    ;;
Packit Service 82fcde
  *)
Packit Service 82fcde
    # Unknown option.  This means the rest is the program name and parameters.
Packit Service 82fcde
    break
Packit Service 82fcde
    ;;
Packit Service 82fcde
  esac
Packit Service 82fcde
  shift
Packit Service 82fcde
done
Packit Service 82fcde
Packit Service 82fcde
# See whether any arguments are left.
Packit Service 82fcde
if test $# -eq 0; then
Packit Service 82fcde
  printf >&2 $"No program name given\n"
Packit Service 82fcde
  help_info
Packit Service 82fcde
fi
Packit Service 82fcde
Packit Service 82fcde
# Determine the program name and check whether it exists.
Packit Service 82fcde
program=$1
Packit Service 82fcde
shift
Packit Service 82fcde
if test ! -f "$program"; then
Packit Service 82fcde
  printf >&2 $"executable \`$program' not found\n"
Packit Service 82fcde
  help_info
Packit Service 82fcde
fi
Packit Service 82fcde
if test ! -x "$program"; then
Packit Service 82fcde
  printf >&2 $"\`$program' is no executable\n"
Packit Service 82fcde
  help_info
Packit Service 82fcde
fi
Packit Service 82fcde
Packit Service 82fcde
# We have two modes.  If a data file is given simply print the included data.
Packit Service 82fcde
printf "%-20s  %-*s  %6s\n" Function $(expr $COLUMNS - 30) File Line
Packit Service 82fcde
for i in $(seq 1 $COLUMNS); do printf -; done; printf '\n'
Packit Service 82fcde
if test -n "$data"; then
Packit Service 82fcde
  $pcprofiledump "$data" |
Packit Service 82fcde
  sed 's/this = \([^,]*\).*/\1/' |
Packit Service 82fcde
  addr2line -fC -e "$program" |
Packit Service 82fcde
  while read fct; do
Packit Service 82fcde
    read file
Packit Service 82fcde
    if test "$fct" != '??' -a "$file" != '??:0'; then
Packit Service 82fcde
      format_line "$fct" "$file"
Packit Service 82fcde
    fi
Packit Service 82fcde
  done
Packit Service 82fcde
else
Packit Service 82fcde
  fifo=$(mktemp -ut xtrace.XXXXXX) || exit
Packit Service 82fcde
  trap 'rm -f "$fifo"; exit 1' HUP INT QUIT TERM PIPE
Packit Service 82fcde
  mkfifo -m 0600 $fifo || exit 1
Packit Service 82fcde
Packit Service 82fcde
  # Now start the program and let it write to the FIFO.
Packit Service 82fcde
  $TERMINAL_PROG -T "xtrace - $program $*" -e /bin/sh -c "LD_PRELOAD=$pcprofileso PCPROFILE_OUTPUT=$fifo $program $*; read < $fifo" &
Packit Service 82fcde
  termpid=$!
Packit Service 82fcde
  $pcprofiledump -u "$fifo" |
Packit Service 82fcde
  while read line; do
Packit Service 82fcde
     echo "$line" |
Packit Service 82fcde
     sed 's/this = \([^,]*\).*/\1/' |
Packit Service 82fcde
     addr2line -fC -e "$program"
Packit Service 82fcde
  done |
Packit Service 82fcde
  while read fct; do
Packit Service 82fcde
    read file
Packit Service 82fcde
    if test "$fct" != '??' -a "$file" != '??:0'; then
Packit Service 82fcde
      format_line "$fct" "$file"
Packit Service 82fcde
    fi
Packit Service 82fcde
  done
Packit Service 82fcde
  read -p "Press return here to close $TERMINAL_PROG($program)."
Packit Service 82fcde
  echo > "$fifo"
Packit Service 82fcde
  rm "$fifo"
Packit Service 82fcde
fi
Packit Service 82fcde
Packit Service 82fcde
exit 0
Packit Service 82fcde
# Local Variables:
Packit Service 82fcde
#  mode:ksh
Packit Service 82fcde
# End: