From 601d2ee8dd783503f9d556e1ed3b107abf196a1e Mon Sep 17 00:00:00 2001 From: Richard Smith Date: Wed, 26 Oct 2011 06:15:36 +0000 Subject: [PATCH] UnresolvedMemberExprs need lvalue-to-rvalue conversions during template instantiations too. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@143016 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Sema/TreeTransform.h | 7 +++++++ test/SemaCXX/warn-thread-safety-analysis.cpp | 15 +++++++++++++++ 2 files changed, 22 insertions(+) diff --git a/lib/Sema/TreeTransform.h b/lib/Sema/TreeTransform.h index 59c132cacc..7fb2d35c70 100644 --- a/lib/Sema/TreeTransform.h +++ b/lib/Sema/TreeTransform.h @@ -2145,6 +2145,13 @@ public: CXXScopeSpec SS; SS.Adopt(QualifierLoc); + if (BaseE && IsArrow) { + ExprResult BaseResult = getSema().DefaultLvalueConversion(BaseE); + if (BaseResult.isInvalid()) + return ExprError(); + BaseE = BaseResult.take(); + } + return SemaRef.BuildMemberReferenceExpr(BaseE, BaseType, OperatorLoc, IsArrow, SS, FirstQualifierInScope, diff --git a/test/SemaCXX/warn-thread-safety-analysis.cpp b/test/SemaCXX/warn-thread-safety-analysis.cpp index b4d44170fe..ff290198c0 100644 --- a/test/SemaCXX/warn-thread-safety-analysis.cpp +++ b/test/SemaCXX/warn-thread-safety-analysis.cpp @@ -1533,4 +1533,19 @@ namespace template_member_test { template struct IndirectLock; // expected-note {{here}} + struct V { + void f(int); + void f(double); + + Mutex m; + V *p GUARDED_BY(this->m); + }; + template struct W { + V v; + void f(U u) { + v.p->f(u); // expected-warning {{reading variable 'p' requires locking 'm'}} + } + }; + template struct W; // expected-note {{here}} + } -- 2.50.1