Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

'-[__NSDictionaryI length]: unrecognized selector sent to instance' - trying to figure out why

I've a UITableView with custom UILabel for title and one another to subtitle, in order to align the text to right.

My data come from web service, which I parse and store in NSArray of NSDictionary. Some of the title or the subtitle can be nil/empty-text. For this I'm putting it in try/catch.

One of the lines in my table making my app crush and I cannot figure out why.

I think one of them (title/subtitle) return as NSDictionary but I made a log print for class for my objects, for my [UILabel text], seems like everything is ok.

Exception and stack trace:

2014-04-29 10:47:55.985 Cellular Radar[3226:60b] -[__NSDictionaryI length]: unrecognized selector sent to instance 0x16d007f0
2014-04-29 10:47:55.993 Cellular Radar[3226:60b] -[Home tableView:willDisplayCell:forRowAtIndexPath:], exception.reason: -[__NSDictionaryI length]: unrecognized selector sent to instance 0x16d007f0
2014-04-29 10:47:55.999 Cellular Radar[3226:60b] -[__NSDictionaryI length]: unrecognized selector sent to instance 0x16d007f0
2014-04-29 10:47:56.006 Cellular Radar[3226:60b] CRASH:
-[__NSDictionaryI length]: unrecognized selector sent to instance 0x16d007f0
2014-04-29 10:47:56.062 Cellular Radar[3226:60b] Stack Trace:
(
    0   CoreFoundation                      0x30e02feb <redacted> + 154
    1   libobjc.A.dylib                     0x3b5b1ccf objc_exception_throw + 38
    2   CoreFoundation                      0x30e06967 <redacted> + 202
    3   CoreFoundation                      0x30e05253 <redacted> + 706
    4   CoreFoundation                      0x30d547b8 _CF_forwarding_prep_0 + 24
    5   UIKit                               0x33637ed3 <redacted> + 38
    6   UIKit                               0x337595bb <redacted> + 3682
    7   UIKit                               0x33758031 <redacted> + 60
    8   UIKit                               0x3361ed79 <redacted> + 380
    9   QuartzCore                          0x3329c62b <redacted> + 142
    10  QuartzCore                          0x33297e3b <redacted> + 350
    11  QuartzCore                          0x33297ccd <redacted> + 16
    12  QuartzCore                          0x332976df <redacted> + 230
    13  QuartzCore                          0x332974ef <redacted> + 314
    14  QuartzCore                          0x332eac49 <redacted> + 516
    15  IOMobileFramebuffer                 0x3606375d <redacted> + 104
    16  IOKit                               0x31aed451 IODispatchCalloutFromCFMessage + 248
    17  CoreFoundation                      0x30dc2ef9 <redacted> + 136
    18  CoreFoundation                      0x30dcdab7 <redacted> + 34
    19  CoreFoundation                      0x30dcda53 <redacted> + 346
    20  CoreFoundation                      0x30dcc227 <redacted> + 1398
    21  CoreFoundation                      0x30d36f0f CFRunLoopRunSpecific + 522
    22  CoreFoundation                      0x30d36cf3 CFRunLoopRunInMode + 106
    23  GraphicsServices                    0x35c3b663 GSEventRunModal + 138
    24  UIKit                               0x3368216d UIApplicationMain + 1136
    25  Cellular Radar                      0x00077757 main + 70
    26  libdyld.dylib                       0x3babeab7 <redacted> + 2
)
2014-04-29 10:47:56.075 Cellular Radar[3226:60b] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[__NSDictionaryI length]: unrecognized selector sent to instance 0x16d007f0'
*** First throw call stack:
(0x30e02fd3 0x3b5b1ccf 0x30e06967 0x30e05253 0x30d547b8 0x33637ed3 0x337595bb 0x33758031 0x3361ed79 0x3329c62b 0x33297e3b 0x33297ccd 0x332976df 0x332974ef 0x332eac49 0x3606375d 0x31aed451 0x30dc2ef9 0x30dcdab7 0x30dcda53 0x30dcc227 0x30d36f0f 0x30d36cf3 0x35c3b663 0x3368216d 0x77757 0x3babeab7)
libc++abi.dylib: terminating with uncaught exception of type NSException

Related code:

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString *CellIdentifier = @"Cell";
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier forIndexPath:indexPath];

    if (cell == nil)
    {
        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];
    }

    tableView.separatorStyle = UITableViewCellSeparatorStyleSingleLine;
    tableView.separatorColor = [UIColor lightGrayColor];

    UILabel *textLabel = (UILabel*)[cell viewWithTag:kTAG_TITLE];
    UILabel *detailTextLabel = (UILabel*)[cell viewWithTag:kTAG_SUBTITLE];
    UIImageView *imageView = (UIImageView*)[cell viewWithTag:kTAG_IMAGE];

    textLabel.frame = CGRectMake(
                                 textLabel.frame.origin.x,
                                 textLabel.frame.origin.y - 10,
                                 textLabel.frame.size.width,
                                 textLabel.frame.size.height
                                 );
    cell.textLabel.frame = textLabel.frame;

    cell.tag = indexPath.row;
    cell.backgroundColor = [UIColor whiteColor];

    cell.textLabel.font = cell.detailTextLabel.font = [UIFont fontWithName:kFONT_NAME size:kFONT_SIZE];

    imageView.layer.cornerRadius = 10.0;
    imageView.layer.borderColor = (__bridge CGColorRef)([UIColor clearColor]);
    imageView.layer.borderWidth = 0;
    imageView.clipsToBounds = YES;
    imageView.contentMode = UIViewContentModeScaleAspectFill;

    textLabel.text = @"";

    textLabel.textColor = [UIColor darkGrayColor];
    textLabel.backgroundColor = [UIColor clearColor];
    textLabel.textAlignment = NSTextAlignmentRight;
    textLabel.font = [UIFont fontWithName:kFONT_NAME size:kFONT_SIZE];
    textLabel.textColor = [UIColor darkGrayColor];

    detailTextLabel.text = @"";
    detailTextLabel.font = [UIFont fontWithName:kFONT_NAME size:kFONT_SIZE];
    detailTextLabel.backgroundColor = [UIColor clearColor];
    detailTextLabel.textAlignment = NSTextAlignmentRight;
    detailTextLabel.textColor = [UIColor darkGrayColor];

    if (self.arrayGlobal.count > 0)
    {
        NSDictionary *dict = self.arrayGlobal[indexPath.row];
        NSString *imageUrl = dict[@"imageUrl"];

        @try
        {
            cell.textLabel.text = dict[@"Title"];
        }
        @catch (NSException *exception)
        {
            NSLog(@"%s, %@", __PRETTY_FUNCTION__, exception.reason);

            cell.textLabel.text = @"";
        }

        @try
        {
            detailTextLabel.text = dict[@"Text"];
        }
        @catch (NSException *exception)
        {
            detailTextLabel.text = @"";
        }

        if (imageUrl.length > 0)
        {
            NSString *completeURL = @"";
            completeURL = [completeURL stringByAppendingString:kPROFILE_IMAGE_URL];
            completeURL = [completeURL stringByAppendingString:@"/2/"];
            completeURL = [completeURL stringByAppendingString:imageUrl];
            completeURL = [completeURL stringByAppendingString:@".png"];

            NSString *fileName = [NSString stringWithFormat:@"%@.png", imageUrl];
            NSString* path = GetMediaFolder();
            BOOL imageExists = [[NSFileManager defaultManager] fileExistsAtPath:[path stringByAppendingPathComponent:fileName]];

            if (imageExists)
            {
                dispatch_async(dispatch_get_main_queue(), ^{
                    UITableViewCell *updateCell = (id)[tableView cellForRowAtIndexPath:indexPath];

                    UIImageView *imageView = (UIImageView*)[updateCell viewWithTag:kTAG_IMAGE];
                    imageView.image=[UIImage imageWithContentsOfFile:[path stringByAppendingPathComponent:fileName]];
                    imageView.layer.cornerRadius = 23.0;
                    imageView.layer.borderColor = (__bridge CGColorRef)([UIColor clearColor]);
                    imageView.layer.borderWidth = 1.0;
                    imageView.clipsToBounds = YES;
                    imageView.contentMode = UIViewContentModeScaleAspectFill;

                    [updateCell setNeedsLayout];
                });
            }
            else
            {
                dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
                    NSURL *imageURL=[NSURL URLWithString:completeURL];
                    NSData *image=[NSData dataWithContentsOfURL:imageURL];
                    [image writeToFile:[path stringByAppendingPathComponent:fileName] atomically:YES];

                    // Update UI
                    dispatch_async(dispatch_get_main_queue(), ^{
                        UITableViewCell *updateCell = (id)[tableView cellForRowAtIndexPath:indexPath];

                        UIImageView *imageView = (UIImageView*)[updateCell viewWithTag:kTAG_IMAGE];
                        imageView.image=[UIImage imageWithContentsOfFile:[path stringByAppendingPathComponent:fileName]];
                        imageView.layer.cornerRadius = 23.0;
                        imageView.layer.borderColor = (__bridge CGColorRef)([UIColor clearColor]);
                        imageView.layer.borderWidth = 1.0;
                        imageView.clipsToBounds = YES;
                        imageView.contentMode = UIViewContentModeScaleAspectFill;

                        [updateCell setNeedsLayout];
                    });
                });
            }
        }
    }
    return cell;
}

- (void) tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath
{
    NSLog(@"4");

    @try {
        cell = [Netroads willDisplayFlatDesignCell:cell];
    }
    @catch (NSException *exception) {
        NSLog(@"%s, exception.reason: %@", __PRETTY_FUNCTION__, exception.reason);
    }
}

+ (UITableViewCell*)willDisplayFlatDesignCell:(UITableViewCell*)cell
{
    UILabel *label = [[UILabel alloc] initWithFrame:cell.frame];
    label.backgroundColor = [UIColor colorWithRed:200.0/255.0 green:200.0/255.0 blue:200.0/255.0 alpha:1]; // light gray color, native iphone
    cell.selectedBackgroundView = label;

    cell.textLabel.backgroundColor = [UIColor clearColor];
    cell.textLabel.textAlignment = NSTextAlignmentRight;
    cell.textLabel.textColor = [UIColor darkGrayColor];

    if (cell.detailTextLabel.text) {
        cell.detailTextLabel.backgroundColor = [UIColor clearColor];
        cell.detailTextLabel.textAlignment = NSTextAlignmentRight;
        cell.detailTextLabel.textColor = [UIColor darkGrayColor];
    }

    return cell;
}

EDIT - 1:

I made a log for my NSDictionary as @sleepwalkerfx pointed out and the result for my row that crush is:

2014-04-29 12:01:15.182 Cellular Radar[3331:60b] {
    Date = "22/01/14";
    Owner = "\U05de\U05e2\U05e8\U05db\U05ea";
    Text =     {
    };
    Time = "09:27";
    Title =     {
    };
    WallID = 1;
    imageUrl = system;
}

Which makes me think that how can those objects (text, title) pass the check as [NSString class]?

like image 237
Idan Moshe Avatar asked Apr 29 '14 08:04

Idan Moshe


2 Answers

You are setting the cell's text property to a dictionary:

cell.textLabel.text = dict[@"Title"];

From your log of dict:

Title =     {
    };

and:

detailTextLabel.text = dict[@"Text"];

From your log of dict:

Text =     {
    };

It's not clear exactly what values should be used from dict, but it should not be those dictionaries.

like image 106
trojanfoe Avatar answered Sep 27 '22 21:09

trojanfoe


Reason: NSDictionary doesn't have lengh method but NSString has

Change this line

    if (imageUrl.length > 0)
    {

To

    if ([imageUrl isKindOfClass:[NSString class]] && imageUrl.length > 0)
    {
like image 23
Vijay-Apple-Dev.blogspot.com Avatar answered Sep 27 '22 22:09

Vijay-Apple-Dev.blogspot.com