aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaolo Carlini <paolo.carlini@oracle.com>2014-08-01 19:59:56 +0000
committerPaolo Carlini <paolo@gcc.gnu.org>2014-08-01 19:59:56 +0000
commite1d9e3db7e680c3a70c0d065fa587c14ddce72d5 (patch)
treeffb559f2975c40c7846e73fae38846ba2fbb8e91
parenta7f930e7c3b8a6db6d0bd25ffe2cfdcdab428f19 (diff)
downloadgcc-e1d9e3db7e680c3a70c0d065fa587c14ddce72d5.zip
gcc-e1d9e3db7e680c3a70c0d065fa587c14ddce72d5.tar.gz
gcc-e1d9e3db7e680c3a70c0d065fa587c14ddce72d5.tar.bz2
DR 217 again
/cp 2014-08-01 Paolo Carlini <paolo.carlini@oracle.com> DR 217 again * decl.c (duplicate_decls): Handle static member functions too. /testsuite 2014-08-01 Paolo Carlini <paolo.carlini@oracle.com> DR 217 again * g++.dg/tc1/dr217-2.C: New. From-SVN: r213505
-rw-r--r--gcc/cp/ChangeLog5
-rw-r--r--gcc/cp/decl.c9
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/tc1/dr217-2.C13
4 files changed, 26 insertions, 6 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 6a4e57d..5d06ade 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,8 @@
+2014-08-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 217 again
+ * decl.c (duplicate_decls): Handle static member functions too.
+
2014-08-01 Igor Zamyatin <igor.zamyatin@intel.com>
* cp-array-notation.c (expand_an_in_modify_expr): Fix the misprint
diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c
index fd5e2e5..4e4c589 100644
--- a/gcc/cp/decl.c
+++ b/gcc/cp/decl.c
@@ -1706,14 +1706,11 @@ duplicate_decls (tree newdecl, tree olddecl, bool newdecl_is_friend)
;
else if (TREE_CODE (olddecl) == FUNCTION_DECL)
{
- tree t1 = TYPE_ARG_TYPES (TREE_TYPE (olddecl));
- tree t2 = TYPE_ARG_TYPES (TREE_TYPE (newdecl));
+ tree t1 = FUNCTION_FIRST_USER_PARMTYPE (olddecl);
+ tree t2 = FUNCTION_FIRST_USER_PARMTYPE (newdecl);
int i = 1;
- if (TREE_CODE (TREE_TYPE (newdecl)) == METHOD_TYPE)
- t1 = TREE_CHAIN (t1), t2 = TREE_CHAIN (t2);
-
- if (TREE_CODE (TREE_TYPE (newdecl)) == METHOD_TYPE
+ if (DECL_FUNCTION_MEMBER_P (newdecl)
&& CLASSTYPE_TEMPLATE_INFO (CP_DECL_CONTEXT (newdecl)))
{
/* C++11 8.3.6/6.
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 1bf38ab..81b20e0 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2014-08-01 Paolo Carlini <paolo.carlini@oracle.com>
+
+ DR 217 again
+ * g++.dg/tc1/dr217-2.C: New.
+
2014-08-01 Igor Zamyatin <igor.zamyatin@intel.com>
PR other/61963
diff --git a/gcc/testsuite/g++.dg/tc1/dr217-2.C b/gcc/testsuite/g++.dg/tc1/dr217-2.C
new file mode 100644
index 0000000..75c40f8
--- /dev/null
+++ b/gcc/testsuite/g++.dg/tc1/dr217-2.C
@@ -0,0 +1,13 @@
+// { dg-do compile }
+// DR217: Default arguments for non-template member functions of class
+// templates
+
+template <class T>
+struct S
+{
+ static void foo (int);
+};
+
+template <class T>
+void S<T>::foo (int = 0) // { dg-error "" "default arguments for parameters of member functions of class templates can be specified in the initial declaration only" }
+{ }