merge from gcc
This commit is contained in:
parent
eb2a6f420b
commit
f2917a30d0
3 changed files with 32 additions and 7 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
2011-07-04 Jason Merrill <jason@redhat.com>
|
||||||
|
|
||||||
|
* cp-demangle.c (d_expression): Handle 'this'.
|
||||||
|
(d_print_comp) [DEMANGLE_COMPONENT_FUNCTION_PARAM]: Likewise.
|
||||||
|
|
||||||
2011-07-01 Joel Brobecker <brobecker@adacore.com>
|
2011-07-01 Joel Brobecker <brobecker@adacore.com>
|
||||||
|
|
||||||
* filename_cmp.c (filename_cmp, filename_ncmp): Add handling of
|
* filename_cmp.c (filename_cmp, filename_ncmp): Add handling of
|
||||||
|
|
|
@ -2738,10 +2738,18 @@ d_expression (struct d_info *di)
|
||||||
/* Function parameter used in a late-specified return type. */
|
/* Function parameter used in a late-specified return type. */
|
||||||
int index;
|
int index;
|
||||||
d_advance (di, 2);
|
d_advance (di, 2);
|
||||||
index = d_compact_number (di);
|
if (d_peek_char (di) == 'T')
|
||||||
if (index < 0)
|
{
|
||||||
return NULL;
|
/* 'this' parameter. */
|
||||||
|
d_advance (di, 1);
|
||||||
|
index = 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
index = d_compact_number (di) + 1;
|
||||||
|
if (index == 0)
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
return d_make_function_param (di, index);
|
return d_make_function_param (di, index);
|
||||||
}
|
}
|
||||||
else if (IS_DIGIT (peek)
|
else if (IS_DIGIT (peek)
|
||||||
|
@ -4400,9 +4408,17 @@ d_print_comp (struct d_print_info *dpi, int options,
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case DEMANGLE_COMPONENT_FUNCTION_PARAM:
|
case DEMANGLE_COMPONENT_FUNCTION_PARAM:
|
||||||
d_append_string (dpi, "{parm#");
|
{
|
||||||
d_append_num (dpi, dc->u.s_number.number + 1);
|
long num = dc->u.s_number.number;
|
||||||
d_append_char (dpi, '}');
|
if (num == 0)
|
||||||
|
d_append_string (dpi, "this");
|
||||||
|
else
|
||||||
|
{
|
||||||
|
d_append_string (dpi, "{parm#");
|
||||||
|
d_append_num (dpi, num);
|
||||||
|
d_append_char (dpi, '}');
|
||||||
|
}
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS:
|
case DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS:
|
||||||
|
|
|
@ -3905,6 +3905,10 @@ decltype ({parm#1}+{parm#2}) add<int, double>(int, double)
|
||||||
--format=gnu-v3
|
--format=gnu-v3
|
||||||
_Z4add3IidEDTclL_Z1gEfp_fp0_EET_T0_
|
_Z4add3IidEDTclL_Z1gEfp_fp0_EET_T0_
|
||||||
decltype (g({parm#1}, {parm#2})) add3<int, double>(int, double)
|
decltype (g({parm#1}, {parm#2})) add3<int, double>(int, double)
|
||||||
|
# 'this' test
|
||||||
|
--format=gnu-v3
|
||||||
|
_ZN1A1fIiEEDTcldtdtdefpT1b1fIT_EEEv
|
||||||
|
decltype ((((*this).b).(f<int>))()) A::f<int>()
|
||||||
# new (2008) built in types test
|
# new (2008) built in types test
|
||||||
--format=gnu-v3
|
--format=gnu-v3
|
||||||
_Z1fDfDdDeDhDsDi
|
_Z1fDfDdDeDhDsDi
|
||||||
|
|
Loading…
Reference in a new issue