I have a class and I want to setup what is printed when I call NSLog with that class. For example,
NSLog(@"%@",nonstandardObject);
How do I setup the object so it prints out what I'd want?
I have a class and I want to setup what is printed when I call NSLog with that class. For example,
NSLog(@"%@",nonstandardObject);
How do I setup the object so it prints out what I'd want?
Override the -description
method. It takes no parameters and returns an NSString
that get's printf
'd out.
There's another variant called -debugDescription
(returns NSString
, no parameters) that's used when po'ing the object from gdb.
@interface MyObject : NSObject
{
int myInt;
}
@end
@implementation MyObject
- (id) init
{
myInt = 4;
}
- (NSString *) description
{
return [NSString stringWithFormat:@"myInt is %d", myInt];
}
@end
int main (int argc, char *argv[])
{
MyObject *anInstance = [[MyObject alloc] init];
NSLog (@"%@", anInstance);
[anInstance release];
return 0;
}