1

誰かがここで私を助けてくれますか?私は本当に立ち往生しています。

私のコードでは、ドキュメントの場所にファイルが存在しない場合。ストアを作成し、そこにデータを入れて、そこから読み戻します。これは正常に機能します。ただし、その場所にファイルがすでに存在する場合、そのファイルから読み戻すことはできません。私はたくさん試しましたが、なぜそれが機能しないのか本当にわかりません。場合によっては(実際にはごくわずかですが)、まったく同じコードが機能する場合もあれば、機能しない場合もあります。

これがコードです。それが機能しない場合、useDocumentメソッドのデバッグメッセージ「EndofuseDocument」はログに記録されません。これは、UIManagedDocumentでopenWithCompletionHandlerが呼び出されるメソッドです。コードはメソッドに入りますが、そのメソッドの最後に到達することはありません。

- (void)setupFetchedResultsController
{   NSLog(@"In setupFetchedResultsController");

NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"WorkOutTypes"];
request.sortDescriptors = [NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"workoutName" ascending:YES]];


self.fetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:request 
                                                                    managedObjectContext:self.workoutDatabase.managedObjectContext
                                                                      sectionNameKeyPath:nil 
                                                                               cacheName:nil];

NSLog(@"End of setupFetchedResultsController");
}

- (void)pushWorkoutDataIntoDocument:(UIManagedDocument *)document
{   NSLog(@"In pushWorkoutDataIntoDocument");
dispatch_queue_t pushQ = dispatch_queue_create("Push data", NULL);
dispatch_async(pushQ, ^{
    NSArray *workOuts = [NSArray arrayWithObjects:@"Squats", @"Bench Press", @"Overhead Press", @"Bent Over Rows", nil];
    [document.managedObjectContext performBlock:^{
        for (NSString *workout in workOuts) {
            [WorkOutTypes workoutName:workout inManagedObjectContext:document.managedObjectContext];
        }
    }];        
});
dispatch_release(pushQ);
}

- (void)useDocument
{   NSLog(@"In useDocument");
NSLog(@"File path - %@", [self.workoutDatabase.fileURL path]);
if (![[NSFileManager defaultManager] fileExistsAtPath:[self.workoutDatabase.fileURL path]]) {
    NSLog(@"1");
    [self.workoutDatabase saveToURL:self.workoutDatabase.fileURL 
                 forSaveOperation:UIDocumentSaveForCreating 
                completionHandler:^(BOOL success){
                    [self setupFetchedResultsController];
                    [self pushWorkoutDataIntoDocument:self.workoutDatabase];
                }];
}
else 
    if (self.workoutDatabase.documentState == UIDocumentStateClosed) {
        NSLog(@"2");
        [self.workoutDatabase openWithCompletionHandler:^(BOOL success){
            NSLog(@"handler called");[self setupFetchedResultsController];}];
    }
    else
        if (self.workoutDatabase.documentState == UIDocumentStateNormal) {
            NSLog(@"3");
            [self setupFetchedResultsController];
        }
NSLog(@"End of useDocument");

}

- (void)setWorkoutDatabase:(UIManagedDocument *)workoutDatabase
{   NSLog(@"In setWorkoutDatabase");
if (_workoutDatabase != workoutDatabase) {
    _workoutDatabase = workoutDatabase;
    [self useDocument];
}
}

- (void)viewWillAppear:(BOOL)animated
{   
[super viewWillAppear:animated];
//    self.navigationItem.rightBarButtonItem = self.editButtonItem;

if (!self.workoutDatabase) {
    NSLog(@"Came in");
    NSURL *url = [[[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject];
    url = [url URLByAppendingPathComponent:@"Default Workouts Database"];
    self.workoutDatabase = [[UIManagedDocument alloc] initWithFileURL:url];
    NSLog(@"URL - %@", [url path]);
}
if (self.workoutDatabase) {
    NSLog(@"workoutDatabase created");
}
else
    NSLog(@"workoutDatabase not created");
}
4

1 に答える 1

0

とりあえず質問を締め切ります。UIManagedDocument の代わりに従来の Core Data スタックを使用するように戻しました。かなり頼りにならなかった。

于 2012-05-25T22:29:49.013 に答える