Another place we need to look through the VIEW_CONVERT_EXPR we add to make a
use of a class NTTP have const type.
Tested x86_64-pc-linux-gnu, applying to trunk.
* pt.c (deducible_expression): Look through VIEW_CONVERT_EXPR.
---
gcc/cp/pt.c | 2 +-
gcc/testsuite/g++.dg/cpp2a/nontype-class26.C | 13 +++++++++++++
2 files changed, 14 insertions(+), 1 deletion(-)
create mode 100644 gcc/testsuite/g++.dg/cpp2a/nontype-class26.C
diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c
index d8ab26ec675..6f658de28ed 100644
--- a/gcc/cp/pt.c
+++ b/gcc/cp/pt.c
@@ -21183,7 +21183,7 @@ static bool
deducible_expression (tree expr)
{
/* Strip implicit conversions. */
- while (CONVERT_EXPR_P (expr))
+ while (CONVERT_EXPR_P (expr) || TREE_CODE (expr) == VIEW_CONVERT_EXPR)
expr = TREE_OPERAND (expr, 0);
return (TREE_CODE (expr) == TEMPLATE_PARM_INDEX);
}
diff --git a/gcc/testsuite/g++.dg/cpp2a/nontype-class26.C
b/gcc/testsuite/g++.dg/cpp2a/nontype-class26.C
new file mode 100644
index 00000000000..315e0ac2309
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp2a/nontype-class26.C
@@ -0,0 +1,13 @@
+// { dg-do compile { target c++2a } }
+
+struct p { unsigned p_ {}; };
+
+template <p i> struct pp {};
+struct qq : public pp <p {}> {};
+
+template <p i> int f (pp <i> const &);
+
+int main ()
+{
+ return f (qq {});
+}
base-commit: 945f2b19497eff52ef44923d291bf0fdba043299
--
2.18.1