dimazen / SLCoreDataStack

CoreData stack managing independent 2 NSManagedObjectContext instances

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

SLCoreDataStack

SLCoreDataStack provides a CoreData stack managing two NSManagedObjectContext's for you:

  • SLCoreDataStack.backgroundThreadManagedObjectContext with NSPrivateQueueConcurrencyType: Perform any changes to any CoreData model you are making here with the -[NSManagedObjectContext performBlock:] API.
  • SLCoreDataStack.mainThreadManagedObjectContext with NSMainQueueConcurrencyType: Use this context for displaying models in your UI.
  • SLCoreDataStack keeps these contexts is sync by automatically merging changes between them.
  • SLCoreDataStack supports automatic database migrations. For example: If you have three different model versions, then you can provide one migration from version 1 to version 2 and one migration from version 2 to version 3. SLCoreDataStack will find and detect available migrations and migrate an existing database under the hood for you.

Check out this blog post on why we chose this NSManagedObjectContext concept.

Getting started

NSURL *location = ...; // url to database.sqlite
NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"MyModel" withExtension:@"momd"];

SLCoreDataStack *stack = [[SLCoreDataStack alloc] initWithType:NSSQLiteStoreType
    location:location
    model:modelURL
    inBundle:[NSBundle mainBundle]];

Store the stack somewhere and make it accessible as needed. You are ready to go :)

License

MIT

About

CoreData stack managing independent 2 NSManagedObjectContext instances

License:MIT License


Languages

Language:Objective-C 98.2%Language:Ruby 1.8%