]> git.sur5r.net Git - bacula/bacula/blobdiff - bacula/scripts/btraceback.in
Fix bug #1206 -- Error: sql_update.c:194, which was probably
[bacula/bacula] / bacula / scripts / btraceback.in
index 79df59979d183bc2fa3ab48889e30558f0f2d63c..d4271c34cef29dde8255fece4cd2b54536ff160b 100755 (executable)
@@ -8,31 +8,16 @@
 #  $1 = path to executable
 #  $2 = main pid of running program to be traced back.
 #
-gdb -quiet -batch -x @sbindir@/btraceback.gdb $1 $2 2>&1 \
- | @sbindir@/bsmtp -h @smtp_host@ -s "Bacula traceback" @dump_email@
-
-# Below is some old code that did the traceback from a core
-#  dump. However, for some odd reason, core dumps are not
-#  always produced.
-#i=0
-#core=
-#echo "In modified btraceback"
-#echo "$1 $2"
-#pwd
-#while [ "$i" -lt 60 ] ; do
-#  if [ -f core ] ; then
-#     break;
-#  fi
-#  if [ -f core.$2 ] ; then
-#     core=core.$2
-#     break 
-#  fi 
-#  sleep 1
-#  i=`expr $i + 1`
-#done
-
-#if test x$core != x; then
-#   gdb -quiet -batch -x @sbindir@/btraceback.gdb $1 $core 2>&1 | mail -s "Bacula traceback" @dump_email@
-#else
-#   gdb -quiet -batch -x @sbindir@/btraceback.gdb $1 $2 2>&1 | mail -s "Bacula traceback" @dump_email@
-#fi
+PNAME=`basename $1`
+PNAME="${PNAME} on `hostname`"
+WD="@working_dir@"
+if test `uname -s` = SunOS ; then
+  gcore -o ${WD}/${PNAME} $2
+  dbx $1 $2 <@scriptdir@/btraceback.dbx >${WD}/bacula.$$.traceback 2>&1
+  cat ${WD}/bacula.$$.traceback \
+   | @sbindir@/bsmtp -h @smtp_host@ -f @dump_email@ -s "Bacula DBX traceback of ${PNAME}" @dump_email@
+else
+  gdb -quiet -batch -x @scriptdir@/btraceback.gdb $1 $2 >${WD}/bacula.$$.traceback 2>&1
+  cat ${WD}/bacula.$$.traceback \
+   | @sbindir@/bsmtp -h @smtp_host@ -f @dump_email@ -s "Bacula GDB traceback of ${PNAME}" @dump_email@
+fi