aboutsummaryrefslogtreecommitdiff
path: root/gdb/demangle.c
diff options
context:
space:
mode:
authorDaniel Berlin <dberlin@dberlin.org>2000-11-14 16:46:24 +0000
committerDaniel Berlin <dberlin@dberlin.org>2000-11-14 16:46:24 +0000
commit770de1994eb8868df21770e4439921a005493757 (patch)
treea4c39f1066b60cd1c49246b1e125f68f8d095d0c /gdb/demangle.c
parent4ad5b0f7164ad77f26cce121fc78fd8a55591147 (diff)
downloadgdb-770de1994eb8868df21770e4439921a005493757.zip
gdb-770de1994eb8868df21770e4439921a005493757.tar.gz
gdb-770de1994eb8868df21770e4439921a005493757.tar.bz2
From Kenneth Block <kenneth.block@compaq.com>
* demangle.c: Use libibery list of demanglers instead of out of date local copy.
Diffstat (limited to 'gdb/demangle.c')
-rw-r--r--gdb/demangle.c71
1 files changed, 12 insertions, 59 deletions
diff --git a/gdb/demangle.c b/gdb/demangle.c
index b4a76a1..23ebcde 100644
--- a/gdb/demangle.c
+++ b/gdb/demangle.c
@@ -49,58 +49,6 @@ extern void _initialize_demangler (void);
static char *current_demangling_style_string;
-/* List of supported demangling styles. Contains the name of the style as
- seen by the user, and the enum value that corresponds to that style. */
-
-static const struct demangler
- {
- char *demangling_style_name;
- enum demangling_styles demangling_style;
- char *demangling_style_doc;
- }
-demanglers[] =
-{
- {
- AUTO_DEMANGLING_STYLE_STRING,
- auto_demangling,
- "Automatic selection based on executable"
- }
- ,
- {
- GNU_DEMANGLING_STYLE_STRING,
- gnu_demangling,
- "GNU (g++) style demangling"
- }
- ,
- {
- LUCID_DEMANGLING_STYLE_STRING,
- lucid_demangling,
- "Lucid (lcc) style demangling"
- }
- ,
- {
- ARM_DEMANGLING_STYLE_STRING,
- arm_demangling,
- "ARM style demangling"
- }
- ,
- {
- HP_DEMANGLING_STYLE_STRING,
- hp_demangling,
- "HP (aCC) style demangling"
- }
- ,
- {
- EDG_DEMANGLING_STYLE_STRING,
- edg_demangling,
- "EDG style demangling"
- }
- ,
- {
- NULL, unknown_demangling, NULL
- }
-};
-
static void set_demangling_command (char *, int, struct cmd_list_element *);
/* Set current demangling style. Called by the "set demangle-style"
@@ -122,14 +70,16 @@ static void set_demangling_command (char *, int, struct cmd_list_element *);
static void
set_demangling_command (char *ignore, int from_tty, struct cmd_list_element *c)
{
- const struct demangler *dem;
+ const struct demangler_engine *dem;
/* First just try to match whatever style name the user supplied with
one of the known ones. Don't bother special casing for an empty
name, we just treat it as any other style name that doesn't match.
If we match, update the current demangling style enum. */
- for (dem = demanglers; dem->demangling_style_name != NULL; dem++)
+ for (dem = libiberty_demanglers;
+ dem->demangling_style != unknown_demangling;
+ dem++)
{
if (STREQ (current_demangling_style_string,
dem->demangling_style_name))
@@ -143,7 +93,7 @@ set_demangling_command (char *ignore, int from_tty, struct cmd_list_element *c)
style name and supply a list of valid ones. FIXME: This should
probably be done with some sort of completion and with help. */
- if (dem->demangling_style_name == NULL)
+ if (dem->demangling_style == unknown_demangling)
{
if (*current_demangling_style_string != '\0')
{
@@ -151,7 +101,9 @@ set_demangling_command (char *ignore, int from_tty, struct cmd_list_element *c)
current_demangling_style_string);
}
printf_unfiltered ("The currently understood settings are:\n\n");
- for (dem = demanglers; dem->demangling_style_name != NULL; dem++)
+ for (dem = libiberty_demanglers;
+ dem->demangling_style != unknown_demangling;
+ dem++)
{
printf_unfiltered ("%-10s %s\n", dem->demangling_style_name,
dem->demangling_style_doc);
@@ -168,10 +120,11 @@ set_demangling_command (char *ignore, int from_tty, struct cmd_list_element *c)
/* This can happen during initialization if gdb is compiled with
a DEMANGLING_STYLE value that is unknown, so pick the first
one as the default. */
- current_demangling_style = demanglers[0].demangling_style;
+ current_demangling_style = libiberty_demanglers[0].demangling_style;
current_demangling_style_string =
- savestring (demanglers[0].demangling_style_name,
- strlen (demanglers[0].demangling_style_name));
+ savestring (
+ libiberty_demanglers[0].demangling_style_name,
+ strlen (libiberty_demanglers[0].demangling_style_name));
warning ("`%s' style demangling chosen as the default.\n",
current_demangling_style_string);
}