Adam
Adam

Reputation: 933

Adding objects to NSMutableArray properties crashes with unrecognized selector?

I am getting "-[__NSArrayI addObject:]: unrecognized selector sent to instance 0x10dd15ee0" here, when I try to addObject to an NSMutableArray. I'm not sure why.

I have a set of custom classes, that are nested. WTEvent has an NSMutableArray property called mats that consists of WTMat objects. mats has an NSMutableArray of WTBout objects called bouts.

I want to be able to update one bout in bouts while leaving the rest of the bouts alone. Here, I locate the mat that I need to assign a bout to. If it's not initialized, I initialize it. Then, if it's empty, I try to add a newBout to it, and it crashes.

Shouldn't I be able to change elements of a NSMutableArray like this?

// Locate the correct mat
WTMat* mat = [self getMatFromBoutKey:[updateData valueForKey:@"boutKey"]];
WTBout* newBout = [WTBout buildBoutFromDictionary:updateData];

// need to initialize bouts
if ([mat bouts] == nil) {
    NSLog(@"Initializing bouts");
    NSMutableArray* newBouts = [[NSMutableArray alloc] init ];
    [mat setBouts:newBouts];
}

if ([[mat bouts] count]) {
    // if bouts has bouts, then adjust the bout stack

    NSLog(@"bouts is not empty");
} else {
    // if bouts is empty, just add a bout

    NSLog(@"Adding a newBout");
    NSMutableArray* oldBouts = [mat bouts];
    NSLog(@"oldbouts: %@", [oldBouts description]);
    [oldBouts addObject:newBout]; // -[__NSArrayI addObject:]: unrecognized selector sent to instance 0x10dd15ee0

}

WTMat.h:

#import <Foundation/Foundation.h>

@interface WTMat : NSObject
{
    NSString* matName;
    NSString* boutKey;
    NSString* multicastAddress;
    NSMutableArray* bouts;
}

@property (strong, nonatomic) NSString* matName;
@property (strong, nonatomic) NSString* boutKey;
@property (strong, nonatomic) NSString* multicastAddress;
@property (copy, nonatomic) NSMutableArray* bouts; 

@end

Log:

2012-05-12 08:14:00.491 Wrestling Tools[12623:403] Initializing bouts
2012-05-12 08:14:00.492 Wrestling Tools[12623:403] Adding a newBout
2012-05-12 08:14:00.492 Wrestling Tools[12623:403] oldbouts: (
)
2012-05-12 08:14:00.492 Wrestling Tools[12623:403] -[__NSArrayI addObject:]: unrecognized selector sent to instance 0x10dd15ee0
2012-05-12 08:14:00.492 Wrestling Tools[12623:403] -[__NSArrayI addObject:]: unrecognized selector sent to instance 0x10dd15ee0
2012-05-12 08:14:00.494 Wrestling Tools[12623:403] (
    0   CoreFoundation                      0x00007fff96783fc6 __exceptionPreprocess + 198
    1   libobjc.A.dylib                     0x00007fff92375d5e objc_exception_throw + 43
    2   CoreFoundation                      0x00007fff968102ae -[NSObject doesNotRecognizeSelector:] + 190
    3   CoreFoundation                      0x00007fff96770e73 ___forwarding___ + 371
    4   CoreFoundation                      0x00007fff96770c88 _CF_forwarding_prep_0 + 232
    5   Wrestling Tools                     0x000000010dc49343 -[WTUpdater fullUpdate:] + 835

Upvotes: 0

Views: 1414

Answers (3)

Dream.In.Code
Dream.In.Code

Reputation: 399

I think it's all about your NSMutableArray* oldBouts = [mat bouts]; Alloc it, and see what will happen.

Upvotes: 0

zahreelay
zahreelay

Reputation: 1742

try initializing properties using @dynamic. A very similar answer may help you.

Upvotes: -1

grahamparks
grahamparks

Reputation: 16296

This is your problem:

@property (copy, nonatomic) NSMutableArray* bouts; 

The "copy" parameter makes an immutable copy of the array, which means when this line runs:

NSMutableArray* oldBouts = [mat bouts];

You're actually getting an ordinary NSArray, which is why you get the unrecognised selector error.

The easy solution to this is to change the "copy" keyword to "strong". Slightly harder would be leave it as copy but to instead change the type of the property to NSArray, though that would complicate modifying the array.

Finally, you could make your own implementation of setBouts: which does do a copy using the -mutableCopy method to ensure the copy it makes is mutable.

Upvotes: 5

Related Questions