diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2010-09-14 23:02:38 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2010-09-14 23:02:38 +0000 |
commit | c4e1a6815235ade1a4affe3511ca5ce2dcc64467 (patch) | |
tree | f64a09c45be4cc8d3f1f853b637c9843f8efb62f /lib/AST/ExprClassification.cpp | |
parent | 5833b0b831d6afae2885e6af420e2bda639652e6 (diff) |
RHS of property expression assignment requires
copy initialization before passing it to
a setter. Fixes radar 8427922.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@113885 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/AST/ExprClassification.cpp')
-rw-r--r-- | lib/AST/ExprClassification.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/lib/AST/ExprClassification.cpp b/lib/AST/ExprClassification.cpp index 6ca18a21dd..b62a00f98e 100644 --- a/lib/AST/ExprClassification.cpp +++ b/lib/AST/ExprClassification.cpp @@ -478,7 +478,8 @@ static Cl::ModifiableType IsModifiable(ASTContext &Ctx, const Expr *E, // Records with any const fields (recursively) are not modifiable. if (const RecordType *R = CT->getAs<RecordType>()) { - assert((isa<ObjCImplicitSetterGetterRefExpr>(E) || + assert((isa<ObjCImplicitSetterGetterRefExpr>(E) || + isa<ObjCPropertyRefExpr>(E) || !Ctx.getLangOptions().CPlusPlus) && "C++ struct assignment should be resolved by the " "copy assignment operator."); |