From: Fariborz Jahanian Date: Mon, 7 Oct 2013 19:54:22 +0000 (+0000) Subject: ObjectiveC modern rewriter. Rewrite typedefs X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=040cd82aadd48ba50e9742881d648d53ddd2a6c9;p=clang ObjectiveC modern rewriter. Rewrite typedefs declared locally in ObjectiveC containers. // rdar://15143875 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@192127 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Rewrite/Frontend/RewriteModernObjC.cpp b/lib/Rewrite/Frontend/RewriteModernObjC.cpp index af9cda3fad..ae33ac816e 100644 --- a/lib/Rewrite/Frontend/RewriteModernObjC.cpp +++ b/lib/Rewrite/Frontend/RewriteModernObjC.cpp @@ -221,6 +221,21 @@ namespace { } return true; } + + virtual void HandleTopLevelDeclInObjCContainer(DeclGroupRef D) { + for (DeclGroupRef::iterator I = D.begin(), E = D.end(); I != E; ++I) { + if (TypedefNameDecl *TD = dyn_cast(*I)) { + if (isTopLevelBlockPointerType(TD->getUnderlyingType())) + RewriteBlockPointerDecl(TD); + else if (TD->getUnderlyingType()->isFunctionPointerType()) + CheckFunctionPointerDecl(TD->getUnderlyingType(), TD); + else + RewriteObjCQualifiedInterfaceTypes(TD); + } + } + return; + } + void HandleTopLevelSingleDecl(Decl *D); void HandleDeclInMainFile(Decl *D); RewriteModernObjC(std::string inFile, raw_ostream *OS, diff --git a/test/Rewriter/rewrite-interface-locals.mm b/test/Rewriter/rewrite-interface-locals.mm new file mode 100644 index 0000000000..ef361051c1 --- /dev/null +++ b/test/Rewriter/rewrite-interface-locals.mm @@ -0,0 +1,20 @@ +// RUN: %clang_cc1 -x objective-c++ -fblocks -fms-extensions -rewrite-objc %s -o %t-rw.cpp +// RUN: %clang_cc1 -fsyntax-only -fblocks -Wno-address-of-temporary -D"Class=void*" -D"id=void*" -D"SEL=void*" -D"__declspec(X)=" %t-rw.cpp +// rdar://15143875 + +@class NSData, NSError; + +@interface Foo + +typedef void (^Callback)(NSData *data, NSError *error); + +- (void)doSomething:(NSData *)data callback:(Callback)callback; +@end + +@implementation Foo + +- (void)doSomething:(NSData *)data callback:(Callback)callback { + callback(0, 0); +} + +@end