]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
libiberty: Demangle variadic template lambdas
authorNathan Sidwell <nathan@acm.org>
Fri, 30 Sep 2022 19:11:42 +0000 (12:11 -0700)
committerNathan Sidwell <nathan@acm.org>
Fri, 7 Oct 2022 16:12:01 +0000 (09:12 -0700)
Now we have templated lambdas, we can have variadic template lambdas,
and this leads to lambda signatures containing parameter packs.  But
just like 'auto' inside such a signature, we don't have a containing
template, and thus fail.  The fix is to check is_lambda_arg, just as
for a template parameter.  This allows us to demangle g++'s manglings
of such lambdas.

It's not a totally accurate demangling, because we don't mangle the
template head (that's a separate issue), but it is better than failing
to demangle.

Due to the way we print subexprs, we add an unnecessary parens around
the argument of the pack.  That's an orthogonal problem, for which the
solution is to have better knowledge of operator precedence.

libiberty/
* cp-demangle.c (d_print_comp_inner): Allow parameter packs
in a lambda signature.
* testsuite/demangle-expected: Add tests.

libiberty/cp-demangle.c
libiberty/testsuite/demangle-expected

index 7ff225ec1aa584033eb624a25808cb09780c756b..303bfbf709e106b31f7b3b419e683180d32236d8 100644 (file)
@@ -348,7 +348,7 @@ struct d_print_info
      be bigger than MAX_RECURSION_COUNT.  */
   int recursion;
   /* Non-zero if we're printing a lambda argument.  A template
-     parameter reference actually means 'auto'.  */
+     parameter reference actually means 'auto', a pack expansion means T...  */
   int is_lambda_arg;
   /* The current index into any template argument packs we are using
      for printing, or -1 to print the whole pack.  */
@@ -5930,9 +5930,10 @@ d_print_comp_inner (struct d_print_info *dpi, int options,
 
     case DEMANGLE_COMPONENT_PACK_EXPANSION:
       {
-       int len;
-       int i;
-       struct demangle_component *a = d_find_pack (dpi, d_left (dc));
+       struct demangle_component *a = NULL;
+
+       if (!dpi->is_lambda_arg)
+         a = d_find_pack (dpi, d_left (dc));
        if (a == NULL)
          {
            /* d_find_pack won't find anything if the only packs involved
@@ -5940,17 +5941,20 @@ d_print_comp_inner (struct d_print_info *dpi, int options,
               case, just print the pattern and "...".  */
            d_print_subexpr (dpi, options, d_left (dc));
            d_append_string (dpi, "...");
-           return;
          }
-
-       len = d_pack_length (a);
-       dc = d_left (dc);
-       for (i = 0; i < len; ++i)
+       else
          {
-           dpi->pack_index = i;
-           d_print_comp (dpi, options, dc);
-           if (i < len-1)
-             d_append_string (dpi, ", ");
+           int len = d_pack_length (a);
+           int i;
+
+           dc = d_left (dc);
+           for (i = 0; i < len; ++i)
+             {
+               if (i)
+                 d_append_string (dpi, ", ");
+               dpi->pack_index = i;
+               d_print_comp (dpi, options, dc);
+             }
          }
       }
       return;
index 8fad6893ae7618cda26c3a783767ec62112b4d9f..90dd4a13945347e0e9c85a1624d89428e13460a7 100644 (file)
@@ -1574,3 +1574,10 @@ initializer for module Foo.Bar
 
 _ZGIW3FooWP3BarW3Baz
 initializer for module Foo:Bar.Baz
+
+_ZZ2L1vENKUlDpT_E_clIJiPiEEEvS0_
+void L1()::{lambda((auto:1)...)#1}::operator()<int, int*>(int, int*) const
+
+_ZZ2L1vENKUlDpT_E_clIJiPiEEEDaS0_
+auto L1()::{lambda((auto:1)...)#1}::operator()<int, int*>(int, int*) const
+