diff options
author | Paolo Carlini <paolo.carlini@oracle.com> | 2014-08-01 19:59:56 +0000 |
---|---|---|
committer | Paolo Carlini <paolo@gcc.gnu.org> | 2014-08-01 19:59:56 +0000 |
commit | e1d9e3db7e680c3a70c0d065fa587c14ddce72d5 (patch) | |
tree | ffb559f2975c40c7846e73fae38846ba2fbb8e91 | |
parent | a7f930e7c3b8a6db6d0bd25ffe2cfdcdab428f19 (diff) | |
download | gcc-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/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/cp/decl.c | 9 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/tc1/dr217-2.C | 13 |
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" } +{ } |