// Contributed by Dodji Seketeli // Origin PR debug/30161 // { dg-options "-g -dA -std=c++0x -fno-merge-debug-strings" } // { dg-do compile } // There must be 5 subprograms generated: // printf(const char*), printf, // printf, printf and foo(). // { dg-final {scan-assembler-times "DIE \\(0x.*?\\) DW_TAG_subprogram" 5 } } // That makes 6 template type parameters. // { dg-final {scan-assembler-times "DIE \\(0x.*?\\) DW_TAG_template_type_param" 6 } } // { dg-final {scan-assembler-times "\"printf.0\".*?DW_AT_name" 1 } } // { dg-final {scan-assembler-times "\"printf.0\".*?DW_AT_name" 1 } } // { dg-final {scan-assembler-times "\"printf.0\".*?DW_AT_name" 1 } } // { dg-final {scan-assembler-times "\"printf.0\".*?DW_AT_name" 1 } } // printf and printf have a pack expansion as // function parameters. In the former, the elements of the parameter pack // expansion are PackTypes#0, PackTypes#1 and the arguments are args#0 and // args#1. In the later, the element of the parameter pack expansion // is PackTypes#0 and the argument is args#0. // { dg-final {scan-assembler-times "DW_AT_name: \"PackTypes#0\"" 2 } } // { dg-final {scan-assembler-times "\"args#0.0\".*?DW_AT_name" 2 } } // { dg-final {scan-assembler-times "\"PackTypes#1.0\".*?DW_AT_name" 1 } } // { dg-final {scan-assembler-times "\"args#1.0\".*?DW_AT_name" 1 } } // { dg_final {scan-assembler-times "\.ascii \"T.0\"\[\t \]+.*?DW_AT_name" 3 } } void printf(const char* s) { /* Commented this to not pull std::cout into what should be a simple test. while (*s) std::cout << *s++; */ } template void printf(const char* s, T value, PackTypes... args) { while (*s) { if (*s == '%' && *++s != '%') { /* std::cout << value; */ return printf(++s, args...); } } } void foo () { int x; printf("%c %d", x, 'x', 3); }