void InsertBlockLiteralsWithinMethod(ObjCMethodDecl *MD);
// Block specific rewrite rules.
- void RewriteBlockExpr(BlockExpr *Exp);
+ void RewriteBlockExpr(BlockExpr *Exp, VarDecl *VD=0);
void RewriteBlockCall(CallExpr *Exp);
void RewriteBlockPointerDecl(NamedDecl *VD);
CurMethodDef = 0;
}
}
- if (ValueDecl *ND = dyn_cast<ValueDecl>(D)) {
- if (isBlockPointerType(ND->getType()))
- RewriteBlockPointerDecl(ND);
+ if (VarDecl *VD = dyn_cast<VarDecl>(D)) {
+ if (isBlockPointerType(VD->getType())) {
+ RewriteBlockPointerDecl(VD);
+ if (VD->getInit()) {
+ if (BlockExpr *BExp = dyn_cast<BlockExpr>(VD->getInit())) {
+ RewriteBlockExpr(BExp, VD);
+ SynthesizeBlockLiterals(VD->getTypeSpecStartLoc(), VD->getName());
+ }
+ }
+ }
return;
}
if (TypedefDecl *TD = dyn_cast<TypedefDecl>(D)) {
return;
}
-void RewriteBlocks::RewriteBlockExpr(BlockExpr *Exp) {
+void RewriteBlocks::RewriteBlockExpr(BlockExpr *Exp, VarDecl *VD) {
Blocks.push_back(Exp);
bool haveByRefDecls = false;
std::string::size_type loc = 0;
while ((loc = FuncName.find(":", loc)) != std::string::npos)
FuncName.replace(loc, 1, "_");
- }
+ } else if (VD)
+ FuncName = std::string(VD->getName());
+
std::string BlockNumber = utostr(Blocks.size()-1);
std::string Tag = "__" + FuncName + "_block_impl_" + BlockNumber;