summaryrefslogtreecommitdiff
path: root/gcc/collect2.c
diff options
context:
space:
mode:
authorbothner <bothner@138bc75d-0d04-0410-961f-82ee72b054a4>2004-07-13 17:19:14 +0000
committerbothner <bothner@138bc75d-0d04-0410-961f-82ee72b054a4>2004-07-13 17:19:14 +0000
commit5814fc8caaf7bcc801b4f3072e0319979d547d51 (patch)
tree6fd6a44f63731331e55c822b1b0b17c5a3961bbe /gcc/collect2.c
parent2146e26da121b973cb81745812754f3db4146fea (diff)
downloadgcc-5814fc8caaf7bcc801b4f3072e0319979d547d51.tar.gz
* 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
Diffstat (limited to 'gcc/collect2.c')
-rw-r--r--gcc/collect2.c35
1 files changed, 33 insertions, 2 deletions
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