diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2010-10-14 16:04:05 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2010-10-14 16:04:05 +0000 |
commit | 8ac2d449820fd0df00fcbde5bf82165c1f49854d (patch) | |
tree | e776d338a9bd913adb7265519b84826f371b897b /lib/AST/Expr.cpp | |
parent | 44270d6abff30415cdd873164823f48a45be7f8c (diff) |
Eliminate usage of ObjCSuperExpr used for
'super' as receiver of property or a setter/getter
methods. //rdar: //8525788
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@116483 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/AST/Expr.cpp')
-rw-r--r-- | lib/AST/Expr.cpp | 30 |
1 files changed, 21 insertions, 9 deletions
diff --git a/lib/AST/Expr.cpp b/lib/AST/Expr.cpp index 708512ce46..98f0656ad1 100644 --- a/lib/AST/Expr.cpp +++ b/lib/AST/Expr.cpp @@ -2348,23 +2348,35 @@ Stmt::child_iterator ObjCIvarRefExpr::child_begin() { return &Base; } Stmt::child_iterator ObjCIvarRefExpr::child_end() { return &Base+1; } // ObjCPropertyRefExpr -Stmt::child_iterator ObjCPropertyRefExpr::child_begin() { return &Base; } -Stmt::child_iterator ObjCPropertyRefExpr::child_end() { return &Base+1; } +Stmt::child_iterator ObjCPropertyRefExpr::child_begin() +{ + if (BaseExprOrSuperType.is<Stmt*>()) { + // Hack alert! + return reinterpret_cast<Stmt**> (&BaseExprOrSuperType); + } + return child_iterator(); +} + +Stmt::child_iterator ObjCPropertyRefExpr::child_end() +{ return BaseExprOrSuperType.is<Stmt*>() ? + reinterpret_cast<Stmt**> (&BaseExprOrSuperType)+1 : + child_iterator(); +} // ObjCImplicitSetterGetterRefExpr Stmt::child_iterator ObjCImplicitSetterGetterRefExpr::child_begin() { - // If this is accessing a class member, skip that entry. - if (Base) return &Base; - return &Base+1; + // If this is accessing a class member or super, skip that entry. + // Technically, 2nd condition is sufficient. But I want to be verbose + if (isSuperReceiver() || !Base) + return child_iterator(); + return &Base; } Stmt::child_iterator ObjCImplicitSetterGetterRefExpr::child_end() { + if (isSuperReceiver() || !Base) + return child_iterator(); return &Base+1; } -// ObjCSuperExpr -Stmt::child_iterator ObjCSuperExpr::child_begin() { return child_iterator(); } -Stmt::child_iterator ObjCSuperExpr::child_end() { return child_iterator(); } - // ObjCIsaExpr Stmt::child_iterator ObjCIsaExpr::child_begin() { return &Base; } Stmt::child_iterator ObjCIsaExpr::child_end() { return &Base+1; } |