diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2012-08-21 18:56:50 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2012-08-21 18:56:50 +0000 |
| commit | f1f36c6a9ae13c4956617e1d866f507907e0838a (patch) | |
| tree | 5774f137e3e7ee753b5801f0fecde65abb9ec301 /clang | |
| parent | 5bd4c2ace46501f475a6b59e1edfd94777b9362b (diff) | |
| download | bcm5719-llvm-f1f36c6a9ae13c4956617e1d866f507907e0838a.tar.gz bcm5719-llvm-f1f36c6a9ae13c4956617e1d866f507907e0838a.zip | |
Modern objc translator: Fixes a crash in rewriter when rewriting the API
for structure valued method messaging. // rdar://12142241
llvm-svn: 162303
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/Rewrite/RewriteModernObjC.cpp | 9 | ||||
| -rw-r--r-- | clang/test/Rewriter/objc-modern-StretAPI-2.mm | 30 |
2 files changed, 38 insertions, 1 deletions
diff --git a/clang/lib/Rewrite/RewriteModernObjC.cpp b/clang/lib/Rewrite/RewriteModernObjC.cpp index dcd003f5016..9c98a7ff2ba 100644 --- a/clang/lib/Rewrite/RewriteModernObjC.cpp +++ b/clang/lib/Rewrite/RewriteModernObjC.cpp @@ -3140,7 +3140,14 @@ Expr *RewriteModernObjC::SynthMsgSendStretCallExpr(FunctionDecl *MsgSendStretFla str += "\t"; str += returnType.getAsString(Context->getPrintingPolicy()); str += " s;\n"; str += "};\n\n"; - SourceLocation FunLocStart = getFunctionSourceLocation(*this, CurFunctionDef); + SourceLocation FunLocStart; + if (CurFunctionDef) + FunLocStart = getFunctionSourceLocation(*this, CurFunctionDef); + else { + assert(CurMethodDef && "SynthMsgSendStretCallExpr - CurMethodDef is null"); + FunLocStart = CurMethodDef->getLocStart(); + } + InsertText(FunLocStart, str); ++stretCount; diff --git a/clang/test/Rewriter/objc-modern-StretAPI-2.mm b/clang/test/Rewriter/objc-modern-StretAPI-2.mm new file mode 100644 index 00000000000..961fc168be9 --- /dev/null +++ b/clang/test/Rewriter/objc-modern-StretAPI-2.mm @@ -0,0 +1,30 @@ +// 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://12142241 + +extern "C" void *sel_registerName(const char *); +typedef unsigned long size_t; + +typedef unsigned long NSUInteger; +typedef struct _NSRange { + NSUInteger location; + NSUInteger length; +} NSRange; + + +@interface NSIndexSet +- (NSRange)rangeAtIndex:(NSUInteger)rangeIndex; +@end + +@interface NSArray +@end + +@implementation NSArray +- (NSArray *)objectsAtIndexes:(NSIndexSet *)iset { + + NSUInteger ridx = 0; + NSRange range = [iset rangeAtIndex:ridx]; + return 0; +} +@end + |

