summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorNicolas Lesser <blitzrakete@gmail.com>2018-07-13 16:27:45 +0000
committerNicolas Lesser <blitzrakete@gmail.com>2018-07-13 16:27:45 +0000
commit1ad0e9f039c85a4bc7b0f7170b04eb562338c608 (patch)
tree54b1272f89336068c5c37dba103b95a9df477220 /clang
parent3f7d20904f0f01b1cf9742ee9a3f0f83072ad6a7 (diff)
downloadbcm5719-llvm-1ad0e9f039c85a4bc7b0f7170b04eb562338c608.tar.gz
bcm5719-llvm-1ad0e9f039c85a4bc7b0f7170b04eb562338c608.zip
Fix PR34668 - P0704R1 implementation is too permissive
Summary: https://bugs.llvm.org/show_bug.cgi?id=34668 Pretty straightforward. Reviewers: rsmith, Rakete1111 Reviewed By: Rakete1111 Subscribers: Rakete1111, cfe-commits Tags: #clang Differential Revision: https://reviews.llvm.org/D38075 llvm-svn: 337017
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Sema/SemaExprCXX.cpp5
-rw-r--r--clang/test/SemaCXX/cxx2a-pointer-to-const-ref-member.cpp3
2 files changed, 6 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaExprCXX.cpp b/clang/lib/Sema/SemaExprCXX.cpp
index 8ed795abbb7..fbf572e3987 100644
--- a/clang/lib/Sema/SemaExprCXX.cpp
+++ b/clang/lib/Sema/SemaExprCXX.cpp
@@ -5472,8 +5472,9 @@ QualType Sema::CheckPointerToMemberOperands(ExprResult &LHS, ExprResult &RHS,
case RQ_LValue:
if (!isIndirect && !LHS.get()->Classify(Context).isLValue()) {
- // C++2a allows functions with ref-qualifier & if they are also 'const'.
- if (Proto->isConst())
+ // C++2a allows functions with ref-qualifier & if their cv-qualifier-seq
+ // is (exactly) 'const'.
+ if (Proto->isConst() && !Proto->isVolatile())
Diag(Loc, getLangOpts().CPlusPlus2a
? diag::warn_cxx17_compat_pointer_to_const_ref_member_on_rvalue
: diag::ext_pointer_to_const_ref_member_on_rvalue);
diff --git a/clang/test/SemaCXX/cxx2a-pointer-to-const-ref-member.cpp b/clang/test/SemaCXX/cxx2a-pointer-to-const-ref-member.cpp
index 0bc40c81798..7c709d905f7 100644
--- a/clang/test/SemaCXX/cxx2a-pointer-to-const-ref-member.cpp
+++ b/clang/test/SemaCXX/cxx2a-pointer-to-const-ref-member.cpp
@@ -3,12 +3,15 @@
struct X {
void ref() & {} // expected-note{{'ref' declared here}}
void cref() const& {}
+ void cvref() const volatile & {} // expected-note{{'cvref' declared here}}
};
void test() {
X{}.ref(); // expected-error{{'this' argument to member function 'ref' is an rvalue, but function has non-const lvalue ref-qualifier}}
X{}.cref(); // expected-no-error
+ X{}.cvref(); // expected-error{{'this' argument to member function 'cvref' is an rvalue, but function has non-const lvalue ref-qualifier}}
(X{}.*&X::ref)(); // expected-error-re{{pointer-to-member function type 'void (X::*)() {{.*}}&' can only be called on an lvalue}}
(X{}.*&X::cref)(); // expected-no-error
+ (X{}.*&X::cvref)(); // expected-error-re{{pointer-to-member function type 'void (X::*)() {{.*}}&' can only be called on an lvalue}}
}
OpenPOWER on IntegriCloud