summaryrefslogtreecommitdiffstats
path: root/clang/lib/AST/StmtSerialization.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2008-05-01 17:26:20 +0000
committerTed Kremenek <kremenek@apple.com>2008-05-01 17:26:20 +0000
commitb8861a6ccfb15ec6ac6dae1e9c06abb51730db70 (patch)
treed49db2fc36955498086ae815c62a387c94cdf8f6 /clang/lib/AST/StmtSerialization.cpp
parent234dc7ac396cd7eebe93b0ab0aecb11efc18330b (diff)
downloadbcm5719-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/StmtSerialization.cpp')
-rw-r--r--clang/lib/AST/StmtSerialization.cpp61
1 files changed, 58 insertions, 3 deletions
diff --git a/clang/lib/AST/StmtSerialization.cpp b/clang/lib/AST/StmtSerialization.cpp
index 3bec7437406..adaa559b06f 100644
--- a/clang/lib/AST/StmtSerialization.cpp
+++ b/clang/lib/AST/StmtSerialization.cpp
@@ -181,6 +181,9 @@ Stmt* Stmt::Create(Deserializer& D, ASTContext& C) {
case ObjCIvarRefExprClass:
return ObjCIvarRefExpr::CreateImpl(D, C);
+ case ObjCMessageExprClass:
+ return ObjCMessageExpr::CreateImpl(D, C);
+
case ObjCSelectorExprClass:
return ObjCSelectorExpr::CreateImpl(D, C);
@@ -190,9 +193,9 @@ Stmt* Stmt::Create(Deserializer& D, ASTContext& C) {
//==--------------------------------------==//
// C++
//==--------------------------------------==//
- case CXXDefaultArgExprClass:
- return CXXDefaultArgExpr::CreateImpl(D, C);
+ case CXXDefaultArgExprClass:
+ return CXXDefaultArgExpr::CreateImpl(D, C);
}
}
@@ -327,7 +330,7 @@ void CallExpr::EmitImpl(Serializer& S) const {
S.Emit(getType());
S.Emit(RParenLoc);
S.EmitInt(NumArgs);
- S.BatchEmitOwnedPtrs(NumArgs+1,SubExprs);
+ S.BatchEmitOwnedPtrs(NumArgs+1, SubExprs);
}
CallExpr* CallExpr::CreateImpl(Deserializer& D, ASTContext& C) {
@@ -984,6 +987,58 @@ ObjCIvarRefExpr* ObjCIvarRefExpr::CreateImpl(Deserializer& D, ASTContext& C) {
return dr;
}
+void ObjCMessageExpr::EmitImpl(Serializer& S) const {
+ S.EmitBool(getReceiver() ? true : false);
+ S.Emit(getType());
+ S.Emit(SelName);
+ S.Emit(LBracloc);
+ S.Emit(RBracloc);
+ S.EmitInt(NumArgs);
+ S.EmitPtr(MethodProto);
+
+ if (getReceiver())
+ S.BatchEmitOwnedPtrs(NumArgs+1, SubExprs);
+ else {
+ S.EmitPtr(getClassName());
+ S.BatchEmitOwnedPtrs(NumArgs, &SubExprs[ARGS_START]);
+ }
+}
+
+ObjCMessageExpr* ObjCMessageExpr::CreateImpl(Deserializer& D, ASTContext& C) {
+ bool isReceiver = D.ReadBool();
+ QualType t = QualType::ReadVal(D);
+ Selector S = Selector::ReadVal(D);
+ SourceLocation L = SourceLocation::ReadVal(D);
+ SourceLocation R = SourceLocation::ReadVal(D);
+
+ // Construct an array for the subexpressions.
+ unsigned NumArgs = D.ReadInt();
+ Expr** SubExprs = new Expr*[NumArgs+1];
+
+ // Construct the ObjCMessageExpr object using the special ctor.
+ ObjCMessageExpr* ME = new ObjCMessageExpr(S, t, L, R, SubExprs, NumArgs);
+
+ // Read in the MethodProto. Read the instance variable directly
+ // allows it to be backpatched.
+ D.ReadPtr(ME->MethodProto);
+
+ // Now read in the arguments.
+
+ if (isReceiver)
+ D.BatchReadOwnedPtrs(NumArgs+1, SubExprs, C);
+ else {
+ // Read the pointer for ClassName. The Deserializer will handle the
+ // bit-mangling automatically.
+ SubExprs[RECEIVER] = (Expr*) ((uintptr_t) 0x1);
+ D.ReadUIntPtr((uintptr_t&) SubExprs[RECEIVER]);
+
+ // Read the arguments.
+ D.BatchReadOwnedPtrs(NumArgs, &SubExprs[ARGS_START], C);
+ }
+
+ return ME;
+}
+
void ObjCSelectorExpr::EmitImpl(Serializer& S) const {
S.Emit(AtLoc);
S.Emit(RParenLoc);
OpenPOWER on IntegriCloud