444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
|
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
|
-
+
-
+
-
+
+
+
-
+
|
else
return @"<0>()";
}
cArray = [array cArray];
count = [array count];
if ([self isKindOfClass: [OFMutableArray class]])
ret = [OFMutableString stringWithFormat: @"<mutable,%zd>(",
ret = [OFMutableString stringWithFormat: @"<mutable,%zd>(\n",
count];
else
ret = [OFMutableString stringWithFormat: @"<%zd>(", count];
ret = [OFMutableString stringWithFormat: @"<%zd>(\n", count];
pool = [[OFAutoreleasePool alloc] init];
append = [ret methodForSelector: @selector(appendString:)];
for (i = 0; i < count - 1; i++) {
append(ret, @selector(appendString:),
[cArray[i] stringBySerializing]);
append(ret, @selector(appendString:), @", ");
append(ret, @selector(appendString:), @",\n");
[pool releaseObjects];
}
[ret replaceOccurrencesOfString: @"\n"
withString: @"\n\t"];
[ret appendFormat: @"%@)", [cArray[i] stringBySerializing]];
[ret appendFormat: @"%@\n)", [cArray[i] stringBySerializing]];
[pool release];
/*
* Class swizzle the string to be immutable. We declared the return type
* to be OFString*, so it can't be modified anyway. But not swizzling it
* would create a real copy each time -[copy] is called.
|