mirror of
https://github.com/darlinghq/darling-gdb.git
synced 2025-01-10 06:00:59 +00:00
7fc7e0c328
* observer.sh: Conditionally declare `args', thus cleaning up unused instances of this variable.
200 lines
4.4 KiB
Bash
Executable File
200 lines
4.4 KiB
Bash
Executable File
#!/bin/sh -e
|
|
|
|
# Make certain that the script is not running in an internationalized
|
|
# environment.
|
|
LANG=C ; export LANG
|
|
LC_ALL=C ; export LC_ALL
|
|
|
|
if test $# -ne 3
|
|
then
|
|
echo "Usage: $0 <h|inc> <observer.texi> <observer.out>" 1>&2
|
|
exit 0
|
|
fi
|
|
|
|
lang=$1 ; shift
|
|
texi=$1 ; shift
|
|
o=$1
|
|
case $lang in
|
|
h) tmp=htmp ;;
|
|
inc) tmp=itmp ;;
|
|
esac
|
|
otmp="`echo $1 | sed -e 's,\.[^.]*$,,'`.$tmp"; shift
|
|
echo "Creating ${otmp}" 1>&2
|
|
rm -f ${otmp}
|
|
|
|
# Can use any of the following: cat cmp cp diff echo egrep expr false
|
|
# grep install-info ln ls mkdir mv pwd rm rmdir sed sleep sort tar
|
|
# test touch true
|
|
|
|
cat <<EOF >>${otmp}
|
|
/* GDB Notifications to Observers.
|
|
|
|
Copyright (C) 2004-2005, 2007-2012 Free Software Foundation, Inc.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
--
|
|
|
|
This file was generated using observer.sh and observer.texi. */
|
|
|
|
EOF
|
|
|
|
|
|
case $lang in
|
|
h) cat <<EOF >>${otmp}
|
|
#ifndef OBSERVER_H
|
|
#define OBSERVER_H
|
|
|
|
struct observer;
|
|
struct bpstats;
|
|
struct so_list;
|
|
struct objfile;
|
|
struct thread_info;
|
|
struct inferior;
|
|
EOF
|
|
;;
|
|
esac
|
|
|
|
# We are about to set IFS=:, so DOS-style file names with a drive
|
|
# letter and a colon will be in trouble.
|
|
|
|
if test -n "$DJGPP"
|
|
then
|
|
texi=`echo $texi | sed -e 's,^\([a-zA-Z]\):/,/dev/\1/,'`
|
|
fi
|
|
|
|
# generate a list of events that can be observed
|
|
|
|
IFS=:
|
|
sed -n '
|
|
/@deftypefun void/{
|
|
# Save original line for later processing into the actual parameter
|
|
h
|
|
# Convert from: @deftypefun void EVENT (TYPE @var{PARAM},...)
|
|
# to event and formals: EVENT:TYPE PARAM, ...:
|
|
s/^.* void \([a-z_][a-z_]*\) (\(.*\))$/\1:\2/
|
|
s/@var{//g
|
|
s/}//g
|
|
# Switch to held
|
|
x
|
|
# Convert from: @deftypefun void FUNC (TYPE @var{PARAM},...)
|
|
# to actuals: PARAM, ...
|
|
s/^[^{]*[{]*//
|
|
s/[}]*[^}]*$//
|
|
s/}[^{]*{/, /g
|
|
# Combine held (EVENT:TYPE PARAM, ...:) and pattern (PARAM, ...) into
|
|
# FUNC:TYPE PARAM, ...:PARAM, ...
|
|
H
|
|
x
|
|
s/\n/:/g
|
|
p
|
|
}
|
|
' $texi | while read event formal actual
|
|
do
|
|
case $lang in
|
|
h) cat <<EOF >>${otmp}
|
|
|
|
/* ${event} notifications. */
|
|
|
|
typedef void (observer_${event}_ftype) (${formal});
|
|
|
|
extern struct observer *observer_attach_${event} (observer_${event}_ftype *f);
|
|
extern void observer_detach_${event} (struct observer *observer);
|
|
extern void observer_notify_${event} (${formal});
|
|
EOF
|
|
;;
|
|
|
|
inc)
|
|
cat <<EOF >>${otmp}
|
|
|
|
/* ${event} notifications. */
|
|
|
|
static struct observer_list *${event}_subject = NULL;
|
|
|
|
EOF
|
|
if test "$formal" != "void"; then
|
|
cat<<EOF >>${otmp}
|
|
struct ${event}_args { `echo "${formal}" | sed -e 's/,/;/g'`; };
|
|
|
|
EOF
|
|
fi
|
|
cat <<EOF >>${otmp}
|
|
static void
|
|
observer_${event}_notification_stub (const void *data, const void *args_data)
|
|
{
|
|
observer_${event}_ftype *notify = (observer_${event}_ftype *) data;
|
|
EOF
|
|
|
|
notify_args=`echo ${actual} | sed -e 's/\([a-z0-9_][a-z0-9_]*\)/args->\1/g'`
|
|
|
|
if test ! -z "${notify_args}"; then
|
|
cat<<EOF >>${otmp}
|
|
const struct ${event}_args *args = args_data;
|
|
EOF
|
|
fi
|
|
cat <<EOF >>${otmp}
|
|
notify (${notify_args});
|
|
}
|
|
|
|
struct observer *
|
|
observer_attach_${event} (observer_${event}_ftype *f)
|
|
{
|
|
return generic_observer_attach (&${event}_subject,
|
|
&observer_${event}_notification_stub,
|
|
(void *) f);
|
|
}
|
|
|
|
void
|
|
observer_detach_${event} (struct observer *observer)
|
|
{
|
|
generic_observer_detach (&${event}_subject, observer);
|
|
}
|
|
|
|
void
|
|
observer_notify_${event} (${formal})
|
|
{
|
|
EOF
|
|
if test "$formal" != "void"; then
|
|
cat<<EOF >>${otmp}
|
|
struct ${event}_args args;
|
|
`echo ${actual} | sed -e 's/\([a-z0-9_][a-z0-9_]*\)/args.\1 = \1/g'`;
|
|
|
|
EOF
|
|
else
|
|
echo "char *args = NULL;" >> ${otmp}
|
|
fi
|
|
cat<<EOF >>${otmp}
|
|
if (observer_debug)
|
|
fprintf_unfiltered (gdb_stdlog, "observer_notify_${event}() called\n");
|
|
generic_observer_notify (${event}_subject, &args);
|
|
}
|
|
EOF
|
|
;;
|
|
esac
|
|
done
|
|
|
|
|
|
case $lang in
|
|
h) cat <<EOF >>${otmp}
|
|
|
|
#endif /* OBSERVER_H */
|
|
EOF
|
|
esac
|
|
|
|
|
|
echo Moving ${otmp} to ${o}
|
|
mv ${otmp} ${o}
|