Generate correct prototype for objc_enumerationMutation.

- This was a latent bug exposed by the recent objc type changes.

llvm-svn: 75383
This commit is contained in:
Daniel Dunbar 2009-07-11 20:32:50 +00:00
parent e91900097e
commit 9d82da40ec
2 changed files with 51 additions and 4 deletions

View File

@ -314,11 +314,14 @@ public:
}
llvm::Constant *getEnumerationMutationFn() {
CodeGen::CodeGenTypes &Types = CGM.getTypes();
ASTContext &Ctx = CGM.getContext();
// void objc_enumerationMutation (id)
std::vector<const llvm::Type*> Args;
Args.push_back(ObjectPtrTy);
llvm::FunctionType *FTy =
llvm::FunctionType::get(llvm::Type::VoidTy, Args, false);
llvm::SmallVector<QualType,16> Params;
QualType IdType = Ctx.getObjCIdType();
Params.push_back(IdType);
const llvm::FunctionType *FTy =
Types.GetFunctionType(Types.getFunctionInfo(Ctx.VoidTy, Params), false);
return CGM.CreateRuntimeFunction(FTy, "objc_enumerationMutation");
}

View File

@ -0,0 +1,44 @@
// RUN: clang-cc -emit-llvm %s -o %t
void p(const char*, ...);
@interface NSArray
+(NSArray*) arrayWithObjects: (id) first, ...;
-(unsigned) count;
@end
@interface NSString
-(const char*) cString;
@end
#define S(n) @#n
#define L1(n) S(n+0),S(n+1)
#define L2(n) L1(n+0),L1(n+2)
#define L3(n) L2(n+0),L2(n+4)
#define L4(n) L3(n+0),L3(n+8)
#define L5(n) L4(n+0),L4(n+16)
#define L6(n) L5(n+0),L5(n+32)
void t0() {
NSArray *array = [NSArray arrayWithObjects: L1(0), (void*)0];
p("array.length: %d\n", [array count]);
unsigned index = 0;
for (NSString *i in array) {
p("element %d: %s\n", index++, [i cString]);
}
}
void t1() {
NSArray *array = [NSArray arrayWithObjects: L6(0), (void*)0];
p("array.length: %d\n", [array count]);
unsigned index = 0;
for (NSString *i in array) {
index++;
if (index == 10)
continue;
p("element %d: %s\n", index, [i cString]);
if (index == 55)
break;
}
}