From 1c2cb6df9ef500613988a6e691a0fbf998c635e4 Mon Sep 17 00:00:00 2001 From: Fariborz Jahanian Date: Mon, 11 Jan 2010 22:48:40 +0000 Subject: [PATCH] Fix rewriting for forward class declaration. (fixes radar 6969189). llvm-svn: 93201 --- clang/lib/Frontend/RewriteObjC.cpp | 14 +++++++++++--- clang/test/Rewriter/rewrite-forward-class.m | 8 ++++++++ 2 files changed, 19 insertions(+), 3 deletions(-) create mode 100644 clang/test/Rewriter/rewrite-forward-class.m diff --git a/clang/lib/Frontend/RewriteObjC.cpp b/clang/lib/Frontend/RewriteObjC.cpp index 28f79aa10adf..e8bb18665b5b 100644 --- a/clang/lib/Frontend/RewriteObjC.cpp +++ b/clang/lib/Frontend/RewriteObjC.cpp @@ -787,9 +787,17 @@ void RewriteObjC::RewriteForwardClassDecl(ObjCClassDecl *ClassDecl) { // as the class. As a convenience, we include the original declaration // as a comment. std::string typedefString; - typedefString += "// "; - typedefString.append(startBuf, semiPtr-startBuf+1); - typedefString += "\n"; + typedefString += "// @class "; + for (ObjCClassDecl::iterator I = ClassDecl->begin(), E = ClassDecl->end(); + I != E; ++I) { + ObjCInterfaceDecl *ForwardDecl = I->getInterface(); + typedefString += ForwardDecl->getNameAsString(); + if (I+1 != E) + typedefString += ", "; + else + typedefString += ";\n"; + } + for (ObjCClassDecl::iterator I = ClassDecl->begin(), E = ClassDecl->end(); I != E; ++I) { ObjCInterfaceDecl *ForwardDecl = I->getInterface(); diff --git a/clang/test/Rewriter/rewrite-forward-class.m b/clang/test/Rewriter/rewrite-forward-class.m new file mode 100644 index 000000000000..5a50f53a480f --- /dev/null +++ b/clang/test/Rewriter/rewrite-forward-class.m @@ -0,0 +1,8 @@ +// RUN: %clang_cc1 -rewrite-objc -o - %s +// rdar://6969189 + +@class XX; +@class YY, ZZ, QQ; +@class ISyncClient, SMSession, ISyncManager, ISyncSession, SMDataclassInfo, SMClientInfo, + DMCConfiguration, DMCStatusEntry; +