Аргумент обработчика завершения openWithCompletionHandler всегда = НЕТ - PullRequest
3 голосов
/ 25 ноября 2011

У меня есть такой код (я пытаюсь открыть документы из облака):

NSPredicate *pred = [NSPredicate predicateWithFormat:@"%K ENDSWITH '.card'", NSMetadataItemFSNameKey];

NSMetadataQuery *query = [[NSMetadataQuery alloc] init];
[query setSearchScopes:[NSArray arrayWithObject:NSMetadataQueryUbiquitousDocumentsScope]];
[query setPredicate:pred];

[[NSNotificationCenter defaultCenter] 
 addObserver:self 
 selector:@selector(queryDidFinishGathering:) 
 name:NSMetadataQueryDidFinishGatheringNotification 
 object:query];

[[NSNotificationCenter defaultCenter] 
 addObserver:self 
 selector:@selector(queryDidStartGathering:) 
 name:NSMetadataQueryDidStartGatheringNotification 
 object:query];

[[NSNotificationCenter defaultCenter] 
 addObserver:self 
 selector:@selector(queryDidUpdate:) 
 name:NSMetadataQueryDidUpdateNotification
 object:query];

[query startQuery];

// ========================

- (void)queryDidFinishGathering:(NSNotification *)notification {

    NSMetadataQuery *query = [notification object];
    [query disableUpdates];
    [query stopQuery];

    [[NSNotificationCenter defaultCenter] removeObserver:self 
                                                    name:NSMetadataQueryDidFinishGatheringNotification
                                                  object:query];

    for (NSMetadataItem* item in [query results]) {
        NSURL *url = [item valueForAttribute:NSMetadataItemURLKey];
        BCCardDocument *doc = [[[BCCardDocument alloc] initWithFileURL:url] autorelease];
        [doc openWithCompletionHandler:^(BOOL success) {
            if (success) {
                NSLog(@"%@", doc.card.number);
            }
        }];

    }

}

Но success Аргумент блока завершения openWithCompletionHandler всегда равен NO.Что может быть причиной этого?

Ответы [ 2 ]

1 голос
/ 16 мая 2012

Я не могу сказать вам точно, что вам нужно сделать, но я могу рассказать вам, как получить сообщение об ошибке, чтобы вы могли понять его.

В @implementation классе вашего BCCardDocument классараздел, добавьте что-то вроде этого:

- (void)handleError:(NSError *)error userInteractionPermitted:(BOOL)userInteractionPermitted {
    NSLog(@"Error: %@ userInfo=%@", error.localizedDescription, error.userInfo);
    [super handleError:error userInteractionPermitted:userInteractionPermitted];
}
0 голосов
/ 16 мая 2012

У меня очень похожий код, и он отлично работает.Я предполагаю, что ваш BCCardDocument является подклассом UIDocument?Если это так, он должен иметь эти два метода:

- (id)contentsForType:(NSString *)typeName error:(NSError **)outError

- (BOOL)loadFromContents:(id)contents
              ofType:(NSString *)typeName
               error:(NSError *__autoreleasing *)outError {

Единственное другое отличие состоит в том, что я не вызываю stopQuery.

...