diff options
| author | Ted Kremenek <kremenek@apple.com> | 2008-05-01 17:26:20 +0000 |
|---|---|---|
| committer | Ted Kremenek <kremenek@apple.com> | 2008-05-01 17:26:20 +0000 |
| commit | b8861a6ccfb15ec6ac6dae1e9c06abb51730db70 (patch) | |
| tree | d49db2fc36955498086ae815c62a387c94cdf8f6 /clang/lib/AST/Expr.cpp | |
| parent | 234dc7ac396cd7eebe93b0ab0aecb11efc18330b (diff) | |
| download | bcm5719-llvm-b8861a6ccfb15ec6ac6dae1e9c06abb51730db70.tar.gz bcm5719-llvm-b8861a6ccfb15ec6ac6dae1e9c06abb51730db70.zip | |
Use pointer swizziling to unify in ObjCMessageExpr the receiver and classname "fields". This saves us a pointer.
Implemented serialization for ObjCMessageExpr.
llvm-svn: 50528
Diffstat (limited to 'clang/lib/AST/Expr.cpp')
| -rw-r--r-- | clang/lib/AST/Expr.cpp | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/clang/lib/AST/Expr.cpp b/clang/lib/AST/Expr.cpp index 67e39b64806..479b651d1fc 100644 --- a/clang/lib/AST/Expr.cpp +++ b/clang/lib/AST/Expr.cpp @@ -1091,7 +1091,7 @@ ObjCMessageExpr::ObjCMessageExpr(Expr *receiver, Selector selInfo, SourceLocation LBrac, SourceLocation RBrac, Expr **ArgExprs, unsigned nargs) : Expr(ObjCMessageExprClass, retType), SelName(selInfo), - MethodProto(mproto), ClassName(0) { + MethodProto(mproto) { NumArgs = nargs; SubExprs = new Expr*[NumArgs+1]; SubExprs[RECEIVER] = receiver; @@ -1110,10 +1110,10 @@ ObjCMessageExpr::ObjCMessageExpr(IdentifierInfo *clsName, Selector selInfo, SourceLocation LBrac, SourceLocation RBrac, Expr **ArgExprs, unsigned nargs) : Expr(ObjCMessageExprClass, retType), SelName(selInfo), - MethodProto(mproto), ClassName(clsName) { + MethodProto(mproto) { NumArgs = nargs; SubExprs = new Expr*[NumArgs+1]; - SubExprs[RECEIVER] = 0; + SubExprs[RECEIVER] = (Expr*) ((uintptr_t) clsName | 0x1); if (NumArgs) { for (unsigned i = 0; i != NumArgs; ++i) SubExprs[i+ARGS_START] = static_cast<Expr *>(ArgExprs[i]); @@ -1122,7 +1122,6 @@ ObjCMessageExpr::ObjCMessageExpr(IdentifierInfo *clsName, Selector selInfo, RBracloc = RBrac; } - bool ChooseExpr::isConditionTrue(ASTContext &C) const { llvm::APSInt CondVal(32); bool IsConst = getCond()->isIntegerConstantExpr(CondVal, C); @@ -1397,8 +1396,8 @@ Stmt::child_iterator ObjCProtocolExpr::child_end() { } // ObjCMessageExpr -Stmt::child_iterator ObjCMessageExpr::child_begin() { - return reinterpret_cast<Stmt**>(&SubExprs[0]); +Stmt::child_iterator ObjCMessageExpr::child_begin() { + return reinterpret_cast<Stmt**>(&SubExprs[ getReceiver() ? 0 : ARGS_START ]); } Stmt::child_iterator ObjCMessageExpr::child_end() { return reinterpret_cast<Stmt**>(&SubExprs[getNumArgs()+ARGS_START]); |

