From 5814fc8caaf7bcc801b4f3072e0319979d547d51 Mon Sep 17 00:00:00 2001 From: bothner Date: Tue, 13 Jul 2004 17:19:14 +0000 Subject: [PATCH] * collect2.c (main): Handle --no-demangle and --demangle flags. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@84631 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 4 ++++ gcc/collect2.c | 35 +++++++++++++++++++++++++++++++++-- 2 files changed, 37 insertions(+), 2 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 5e87e5e3907..67fcce1e069 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2004-07-13 Per Bothner + + * collect2.c (main): Handle --no-demangle and --demangle flags. + 2004-07-13 Sebastian Pop * Makefile.in (OBJS-common): Add tree-data-ref.o. diff --git a/gcc/collect2.c b/gcc/collect2.c index 79f7885e6e7..2edbea84b0e 100644 --- a/gcc/collect2.c +++ b/gcc/collect2.c @@ -185,6 +185,7 @@ enum pass { int vflag; /* true if -v */ static int rflag; /* true if -r */ static int strip_flag; /* true if -s */ +static const char *demangle_flag; #ifdef COLLECT_EXPORT_LIST static int export_flag; /* true if -bE */ static int aix64_flag; /* true if -b64 */ @@ -1070,8 +1071,10 @@ main (int argc, char **argv) first_file = 1; #ifdef HAVE_LD_DEMANGLE - if (!no_demangle) - *ld1++ = *ld2++ = "--demangle"; + if (!demangle_flag && !no_demangle) + demangle_flag = "--demangle"; + if (demangle_flag) + *ld1++ = *ld2++ = demangle_flag; #endif while ((arg = *++argv) != (char *) 0) { @@ -1167,6 +1170,34 @@ main (int argc, char **argv) if (arg[2] == '\0') vflag = 1; break; + + case '-': + if (strcmp (arg, "--no-demangle") == 0) + { + demangle_flag = arg; + no_demangle = 1; + ld1--; + ld2--; + } + else if (strncmp (arg, "--demangle", 10) == 0) + { + demangle_flag = arg; + no_demangle = 0; +#ifndef HAVE_LD_DEMANGLE + if (arg[10] == '=') + { + enum demangling_styles style + = cplus_demangle_name_to_style (arg+11); + if (style == unknown_demangling) + error ("unknown demangling style '%s'", arg+11); + else + current_demangling_style = style; + } +#endif + ld1--; + ld2--; + } + break; } } else if ((p = strrchr (arg, '.')) != (char *) 0 -- 2.11.0