]> gcc.gnu.org Git - gcc.git/commitdiff
re PR c++/55223 ([C++11] Default lambda expression of a templated class member)
authorJason Merrill <jason@redhat.com>
Fri, 15 Feb 2013 01:26:44 +0000 (20:26 -0500)
committerJason Merrill <jason@gcc.gnu.org>
Fri, 15 Feb 2013 01:26:44 +0000 (20:26 -0500)
PR c++/55223
gcc/cp/
* pt.c (tsubst_copy_and_build) [LAMBDA_EXPR]: Fix handling of
default argument scope.
* mangle.c (write_name): Likewise.
libiberty/
* cp-demangle.c (d_dump): Handle DEMANGLE_COMPONENT_DEFAULT_ARG.
(d_print_comp): Likewise.

From-SVN: r196065

gcc/common.opt
gcc/cp/ChangeLog
gcc/cp/mangle.c
gcc/cp/pt.c
gcc/testsuite/g++.dg/cpp0x/lambda/lambda-defarg3.C [new file with mode: 0644]
libiberty/ChangeLog
libiberty/cp-demangle.c
libiberty/testsuite/demangle-expected

index b6592e09aaaf08ab20bd377ab5b93e4f7666a368..3c7b4153846d0cfd331b328b649f7b02e6077637 100644 (file)
@@ -785,7 +785,8 @@ Driver Undocumented
 ;    argument.
 ;    First selectable in G++ 4.7.
 ;
-; 7: The version of the ABI that treats nullptr_t as a builtin type.
+; 7: The version of the ABI that treats nullptr_t as a builtin type and
+;    corrects the mangling of lambdas in default argument scope.
 ;    First selectable in G++ 4.8.
 ; Additional positive integers will be assigned as new versions of
 ; the ABI become the default version of the ABI.
index 4784a3cf8393b8b4456fae07867256b9a6868927..de03a7a64581c5abfd1f754b3a391ddcdf373825 100644 (file)
@@ -1,5 +1,10 @@
 2013-02-14  Jason Merrill  <jason@redhat.com>
 
+       PR c++/55223
+       * pt.c (tsubst_copy_and_build) [LAMBDA_EXPR]: Fix handling of
+       default argument scope.
+       * mangle.c (write_name): Likewise.
+
        PR c++/55232
        * error.c (find_typenames_r): Don't walk into a pack expansion.
 
index f6b3443e9392418f40890d83e19845242ea4da63..a48d476856c4ba997c8e9ab889e0875d6cb3cef7 100644 (file)
@@ -802,7 +802,10 @@ write_name (tree decl, const int ignore_local_scope)
   if (context == NULL
       || context == global_namespace
       || DECL_NAMESPACE_STD_P (context)
-      || (ignore_local_scope && TREE_CODE (context) == FUNCTION_DECL))
+      || (ignore_local_scope
+         && (TREE_CODE (context) == FUNCTION_DECL
+             || (abi_version_at_least (7)
+                 && TREE_CODE (context) == PARM_DECL))))
     {
       tree template_info;
       /* Is this a template instance?  */
index bd44fdebb8c3774c5296d69b27790a9d38f6d91c..aa868a45a63453e9ba747c5c4e1a6859dfc24b69 100644 (file)
@@ -14444,8 +14444,20 @@ tsubst_copy_and_build (tree t,
           than build a new one.  */
        tree scope = LAMBDA_EXPR_EXTRA_SCOPE (t);
        if (scope && TREE_CODE (scope) == FUNCTION_DECL)
-         scope = tsubst (LAMBDA_EXPR_EXTRA_SCOPE (t), args,
-                         complain, in_decl);
+         scope = tsubst (scope, args, complain, in_decl);
+       else if (scope && TREE_CODE (scope) == PARM_DECL)
+         {
+           /* Look up the parameter we want directly, as tsubst_copy
+              doesn't do what we need.  */
+           tree fn = tsubst (DECL_CONTEXT (scope), args, complain, in_decl);
+           tree parm = FUNCTION_FIRST_USER_PARM (fn);
+           while (DECL_PARM_INDEX (parm) != DECL_PARM_INDEX (scope))
+             parm = DECL_CHAIN (parm);
+           scope = parm;
+           /* FIXME Work around the parm not having DECL_CONTEXT set.  */
+           if (DECL_CONTEXT (scope) == NULL_TREE)
+             DECL_CONTEXT (scope) = fn;
+         }
        else
          scope = RECUR (scope);
        LAMBDA_EXPR_EXTRA_SCOPE (r) = scope;
diff --git a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-defarg3.C b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-defarg3.C
new file mode 100644 (file)
index 0000000..f02fb29
--- /dev/null
@@ -0,0 +1,18 @@
+// PR c++/55223
+// { dg-options "-std=c++11 -fabi-version=0" }
+// { dg-final { scan-assembler "_ZN8functionC1IZN1CIiE4testES_Ed_UliE_EET_" } }
+
+struct function
+{
+  template <class U> function(U u) { }
+};
+
+template<typename T> struct C
+{
+  static T test(function f = [](int i){return i;}) { }
+};
+
+int main()
+{
+  C<int>::test();
+}
index d7f1fd021bfde7cb08b6fbf952a019c617c20458..7935ad69f44eb972c481fdac074712586ecfb279 100644 (file)
@@ -1,3 +1,8 @@
+2013-02-14  Jason Merrill  <jason@redhat.com>
+
+       * cp-demangle.c (d_dump): Handle DEMANGLE_COMPONENT_DEFAULT_ARG.
+       (d_print_comp): Likewise.
+
 2013-02-09  Jakub Jelinek  <jakub@redhat.com>
 
        PR other/56245
index 913d4bf09d4bf6f70bde8005409c3d4a801a5068..39be0314ceadfbec8989242d7b225ef718ae5ebf 100644 (file)
@@ -707,6 +707,14 @@ d_dump (struct demangle_component *dc, int indent)
     case DEMANGLE_COMPONENT_TLS_WRAPPER:
       printf ("tls wrapper function\n");
       break;
+    case DEMANGLE_COMPONENT_DEFAULT_ARG:
+      printf ("default argument %d\n", dc->u.s_unary_num.num);
+      d_dump (dc->u.s_unary_num.sub, indent+2);
+      return;
+    case DEMANGLE_COMPONENT_LAMBDA:
+      printf ("lambda %d\n", dc->u.s_unary_num.num);
+      d_dump (dc->u.s_unary_num.sub, indent+2);
+      return;
     }
 
   d_dump (d_left (dc), indent + 2);
@@ -3168,6 +3176,7 @@ d_expr_primary (struct d_info *di)
 
 /* <local-name> ::= Z <(function) encoding> E <(entity) name> [<discriminator>]
                 ::= Z <(function) encoding> E s [<discriminator>]
+                ::= Z <(function) encoding> E d [<parameter> number>] _ <entity name>
 */
 
 static struct demangle_component *
@@ -3869,7 +3878,17 @@ d_print_comp (struct d_print_info *dpi, int options,
        d_append_string (dpi, "::");
       else
        d_append_char (dpi, '.');
-      d_print_comp (dpi, options, d_right (dc));
+      {
+       struct demangle_component *local_name = d_right (dc);
+       if (local_name->type == DEMANGLE_COMPONENT_DEFAULT_ARG)
+         {
+           d_append_string (dpi, "{default arg#");
+           d_append_num (dpi, local_name->u.s_unary_num.num + 1);
+           d_append_string (dpi, "}::");
+           local_name = local_name->u.s_unary_num.sub;
+         }
+       d_print_comp (dpi, options, local_name);
+      }
       return;
 
     case DEMANGLE_COMPONENT_TYPED_NAME:
index 5b41b03f9faa1b81b7221ca12a50d143eab6f7de..17eacaaa8d0e08c148c8b020dd2e022ab9b8ee55 100644 (file)
@@ -3951,6 +3951,9 @@ S::f(int, int)::{default arg#2}::{lambda()#2}::operator()() const
 _ZNK1SIiE1xMUlvE1_clEv
 S<int>::x::{lambda()#3}::operator()() const
 --format=gnu-v3
+_ZN8functionC1IZN1CIiE4testES_Ed_UliE_EET_
+function::function<C<int>::test(function)::{default arg#1}::{lambda(int)#1}>(C<int>::test(function)::{default arg#1}::{lambda(int)#1})
+--format=gnu-v3
 _Z1fN1SUt_E
 f(S::{unnamed type#1})
 --format=gnu-v3
This page took 0.126816 seconds and 5 git commands to generate.