More leaks fixed

This commit is contained in:
rfm 2024-11-16 13:34:56 +00:00
parent 87c50830e2
commit aedd13dc94
19 changed files with 174 additions and 153 deletions

View file

@ -5,7 +5,8 @@
int main()
{
NSAutoreleasePool *arp = [NSAutoreleasePool new];
id testObject = [NSMutableData new];
id testObject = [NSMutableData data];
test_alloc(@"NSMutableData");
test_NSObject(@"NSData",[NSArray arrayWithObject:testObject]);
test_NSCoding([NSArray arrayWithObject:testObject]);

View file

@ -6,52 +6,52 @@
int main()
{
NSAutoreleasePool *arp = [NSAutoreleasePool new];
char *str1,*str2,*tmp;
NSData *data1;
ENTER_POOL
char *str1, *str2, *tmp;
NSData *data1;
NSMutableData *mutable;
unsigned char *hold;
str1 = "Test string for data classes";
str2 = (char *) malloc(sizeof("insert"));
strcpy(str2,"insert");
str2 = (char *)malloc(sizeof("insert"));
strcpy(str2, "insert");
mutable = [NSMutableData dataWithLength:100];
mutable = [NSMutableData dataWithLength: 100];
hold = [mutable mutableBytes];
/* hmpf is this correct */
data1 = [NSData dataWithBytes:str1 length:(strlen(str1) * sizeof(void*))];
PASS(data1 != nil &&
[data1 isKindOfClass:[NSData class]] &&
[data1 length] == (strlen(str1) * sizeof(void*)) &&
[data1 bytes] != str1 &&
strcmp(str1,[data1 bytes]) == 0,
"+dataWithBytes:length: works");
data1 = [NSData dataWithBytes: str1 length: (strlen(str1) + 1)];
PASS(data1 != nil
&& [data1 isKindOfClass: [NSData class]]
&& [data1 length] == (strlen(str1) + 1)
&& [data1 bytes] != str1
&& strcmp(str1, [data1 bytes]) == 0,
"+dataWithBytes:length: works")
mutable = [NSMutableData data];
PASS(mutable != nil &&
[mutable isKindOfClass:[NSMutableData class]] &&
[mutable length] == 0,
"+data creates empty mutable data");
PASS(mutable != nil
&& [mutable isKindOfClass: [NSMutableData class]]
&& [mutable length] == 0,
"+data creates empty mutable data")
[mutable setData:data1];
PASS(mutable != nil &&
[mutable length] == (strlen(str1) * sizeof(void*)),
"-setData: works");
[mutable setData: data1];
PASS(mutable != nil
&& [mutable length] == (strlen(str1) + 1),
"-setData: works")
[mutable replaceBytesInRange:NSMakeRange(22,6) withBytes:str2];
[mutable replaceBytesInRange: NSMakeRange(22, 6) withBytes: str2];
tmp = (char *)malloc([mutable length]);
[mutable getBytes:tmp range:NSMakeRange(22,6)];
[mutable getBytes: tmp range: NSMakeRange(22, 6)];
tmp[6] = '\0';
PASS(mutable != nil &&
strcmp(tmp,str2) == 0,
"-replaceBytesInRange:withBytes suceeds");
PASS(mutable != nil
&& strcmp(tmp, str2) == 0,
"-replaceBytesInRange:withBytes suceeds")
free(tmp);
PASS_EXCEPTION([mutable replaceBytesInRange:NSMakeRange([mutable length]+1,6)
withBytes:str2];,
NSRangeException,"-replaceBytesInRange:withBytes out of range raises exception");
PASS_EXCEPTION([mutable
replaceBytesInRange: NSMakeRange([mutable length]+1, 6) withBytes: str2];,
NSRangeException,
"-replaceBytesInRange:withBytes out of range raises exception")
[arp release]; arp = nil;
free(str2);
LEAVE_POOL
return 0;
}