diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2011-10-25 06:33:21 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2011-10-25 06:33:21 +0000 |
commit | d4268d91e7f1df42776a8e1994c7415fc04d7571 (patch) | |
tree | 866bc335d2012fc24360b3d9b54e2f7f67d717a8 | |
parent | 7b2fbc61de0dc43dc72bec93e4bb4110b9635931 (diff) | |
download | bcm5719-llvm-d4268d91e7f1df42776a8e1994c7415fc04d7571.tar.gz bcm5719-llvm-d4268d91e7f1df42776a8e1994c7415fc04d7571.zip |
Don't forget the lvalue-to-rvalue conversion on the LHS when instantiating a
dependent ->, where the member being referred to is an anonymous struct or
union. This path was missed by the fix in r142890.
llvm-svn: 142910
-rw-r--r-- | clang/lib/Sema/TreeTransform.h | 5 | ||||
-rw-r--r-- | clang/test/SemaCXX/warn-thread-safety-analysis.cpp | 7 |
2 files changed, 12 insertions, 0 deletions
diff --git a/clang/lib/Sema/TreeTransform.h b/clang/lib/Sema/TreeTransform.h index 46bd05b14ba..3c118cb423d 100644 --- a/clang/lib/Sema/TreeTransform.h +++ b/clang/lib/Sema/TreeTransform.h @@ -1482,6 +1482,11 @@ public: FoundDecl, Member); if (BaseResult.isInvalid()) return ExprError(); + if (isArrow) { + BaseResult = getSema().DefaultLvalueConversion(BaseResult.take()); + if (BaseResult.isInvalid()) + return ExprError(); + } Base = BaseResult.take(); ExprValueKind VK = isArrow ? VK_LValue : Base->getValueKind(); MemberExpr *ME = diff --git a/clang/test/SemaCXX/warn-thread-safety-analysis.cpp b/clang/test/SemaCXX/warn-thread-safety-analysis.cpp index b020e5712a0..b4d44170fec 100644 --- a/clang/test/SemaCXX/warn-thread-safety-analysis.cpp +++ b/clang/test/SemaCXX/warn-thread-safety-analysis.cpp @@ -1516,10 +1516,17 @@ namespace template_member_test { Mutex m; S *s GUARDED_BY(this->m); }; + Mutex m; + struct U { + union { + int n; + }; + } *u GUARDED_BY(m); template<typename U> struct IndirectLock { int DoNaughtyThings(T *t) { + u->n = 0; // expected-warning {{reading variable 'u' requires locking 'm'}} return t->s->n; // expected-warning {{reading variable 's' requires locking 'm'}} } }; |