summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorgdr <gdr@138bc75d-0d04-0410-961f-82ee72b054a4>2002-08-07 00:38:00 +0000
committergdr <gdr@138bc75d-0d04-0410-961f-82ee72b054a4>2002-08-07 00:38:00 +0000
commit90cd798a4ed66fd5642bbfd4bdaf4ff0fe3f24e4 (patch)
tree1f4411c994c10c25ca5bac05f27ac39713d481b5
parent2222b3c62cd0deb2c26a41562e8a81e0314c789b (diff)
downloadppe42-gcc-90cd798a4ed66fd5642bbfd4bdaf4ff0fe3f24e4.tar.gz
ppe42-gcc-90cd798a4ed66fd5642bbfd4bdaf4ff0fe3f24e4.zip
cp/
* typeck.c (build_x_unary_op): Handle pointer-to-member. testsuite/ * g++.dg/README (Subdirectories): Document new subdir expr. * g++.dg/expr/pmf-1.C: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@56082 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/cp/ChangeLog4
-rw-r--r--gcc/cp/typeck.c19
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/README1
-rw-r--r--gcc/testsuite/g++.dg/expr/pmf-1.C19
5 files changed, 48 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index ddadb9c87e2..60b6cb239dc 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,7 @@
+2002-08-06 Gabriel Dos Reis <gdr@nerim.net>
+
+ * typeck.c (build_x_unary_op): Handle pointer-to-member.
+
2002-08-05 Geoffrey Keating <geoffk@redhat.com>
* class.c: Don't include obstack.h.
diff --git a/gcc/cp/typeck.c b/gcc/cp/typeck.c
index 965f3f4399d..399005bc691 100644
--- a/gcc/cp/typeck.c
+++ b/gcc/cp/typeck.c
@@ -3794,6 +3794,25 @@ build_x_unary_op (code, xarg)
}
if (code == ADDR_EXPR)
{
+ /* A pointer to member-function can be formed only by saying
+ &X::mf. */
+ if (!flag_ms_extensions && TREE_CODE (TREE_TYPE (xarg)) == METHOD_TYPE
+ && (TREE_CODE (xarg) != OFFSET_REF || !PTRMEM_OK_P (xarg)))
+ {
+ if (TREE_CODE (xarg) != OFFSET_REF)
+ {
+ error ("invalid use of '%E' to form a pointer-to-member-function. Use a qualified-id.",
+ xarg);
+ return error_mark_node;
+ }
+ else
+ {
+ error ("parenthesis around '%E' cannot be used to form a pointer-to-member-function",
+ xarg);
+ PTRMEM_OK_P (xarg) = 1;
+ }
+ }
+
if (TREE_CODE (xarg) == OFFSET_REF)
{
ptrmem = PTRMEM_OK_P (xarg);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 55fd9a1aeb2..0acf870252b 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2002-08-07 Gabriel Dos Reis <gdr@nerim.net>
+
+ * g++.dg/README (Subdirectories): Document new subdir expr.
+ * g++.dg/expr/pmf-1.C: New test.
+
2002-08-06 Neil Booth <neil@daikokuya.co.uk>
* gcc.dg/cpp/vararg3.c, gcc.dg/cpp/vararg4.c: New tests.
diff --git a/gcc/testsuite/g++.dg/README b/gcc/testsuite/g++.dg/README
index edf1d5a38a5..073913f2056 100644
--- a/gcc/testsuite/g++.dg/README
+++ b/gcc/testsuite/g++.dg/README
@@ -2,6 +2,7 @@ Subdirectories:
abi Tests for ABI compatibility -- mangling, object layout, etc.
eh Tests for exception handling.
+expr Tests for expressions.
ext Tests for GNU language extensions.
inherit Tests for inheritance -- virtual functions, multiple inheritance, etc.
init Tests for initialization semantics, constructors/destructors, etc.
diff --git a/gcc/testsuite/g++.dg/expr/pmf-1.C b/gcc/testsuite/g++.dg/expr/pmf-1.C
new file mode 100644
index 00000000000..61457ecbdc6
--- /dev/null
+++ b/gcc/testsuite/g++.dg/expr/pmf-1.C
@@ -0,0 +1,19 @@
+// C++ PR/2521
+// Copyright (C) 2002 Free Software Foundation
+// Contributed by Gabriel Dos Reis <gdr@integrable-solutions.net>
+
+// { dg-do compile }
+
+struct A
+{
+ void f();
+ void foo(void (A::*)(int)); // { dg-error "candidate" "" }
+ template<typename T>
+ void g(T);
+ void h()
+ {
+ void (A::*p)() = &A::f;
+ void (A::*q)() = &(A::f); // { dg-error "parenthesis" "" }
+ foo(&g<int>); // { dg-error "" "" }
+ }
+};
OpenPOWER on IntegriCloud