mirror of
https://github.com/JohnEstropia/CoreStore.git
synced 2026-06-11 09:03:10 +02:00
Workaround CoreData's bug when using NSFetchRequest's affectedStores property
This commit is contained in:
@@ -104,3 +104,19 @@ internal final class CoreStoreFetchedResultsController<T: NSManagedObject>: NSFe
|
|||||||
|
|
||||||
private let reapplyAffectedStores: (fetchRequest: NSFetchRequest, context: NSManagedObjectContext) -> Bool
|
private let reapplyAffectedStores: (fetchRequest: NSFetchRequest, context: NSManagedObjectContext) -> Bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// MARK: - CoreStoreFetchRequest
|
||||||
|
|
||||||
|
// Bugfix for NSFetchRequest messing up memory management for `affectedStores`
|
||||||
|
// http://stackoverflow.com/questions/14396375/nsfetchedresultscontroller-crashes-in-ios-6-if-affectedstores-is-specified
|
||||||
|
internal final class CoreStoreFetchRequest: NSFetchRequest {
|
||||||
|
|
||||||
|
override var affectedStores: [NSPersistentStore]? {
|
||||||
|
|
||||||
|
get { return self.safeAffectedStores }
|
||||||
|
set { self.safeAffectedStores = newValue }
|
||||||
|
}
|
||||||
|
|
||||||
|
private var safeAffectedStores: [NSPersistentStore]?
|
||||||
|
}
|
||||||
|
|||||||
@@ -76,7 +76,7 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
internal func fetchOne<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> T? {
|
internal func fetchOne<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> T? {
|
||||||
|
|
||||||
let fetchRequest = NSFetchRequest()
|
let fetchRequest = CoreStoreFetchRequest()
|
||||||
from.applyToFetchRequest(fetchRequest, context: self)
|
from.applyToFetchRequest(fetchRequest, context: self)
|
||||||
|
|
||||||
fetchRequest.fetchLimit = 1
|
fetchRequest.fetchLimit = 1
|
||||||
@@ -119,7 +119,7 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
internal func fetchAll<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> [T]? {
|
internal func fetchAll<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> [T]? {
|
||||||
|
|
||||||
let fetchRequest = NSFetchRequest()
|
let fetchRequest = CoreStoreFetchRequest()
|
||||||
from.applyToFetchRequest(fetchRequest, context: self)
|
from.applyToFetchRequest(fetchRequest, context: self)
|
||||||
|
|
||||||
fetchRequest.fetchLimit = 0
|
fetchRequest.fetchLimit = 0
|
||||||
@@ -162,7 +162,7 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
internal func fetchCount<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> Int? {
|
internal func fetchCount<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> Int? {
|
||||||
|
|
||||||
let fetchRequest = NSFetchRequest()
|
let fetchRequest = CoreStoreFetchRequest()
|
||||||
from.applyToFetchRequest(fetchRequest, context: self)
|
from.applyToFetchRequest(fetchRequest, context: self)
|
||||||
|
|
||||||
for clause in fetchClauses {
|
for clause in fetchClauses {
|
||||||
@@ -195,7 +195,7 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
internal func fetchObjectID<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> NSManagedObjectID? {
|
internal func fetchObjectID<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> NSManagedObjectID? {
|
||||||
|
|
||||||
let fetchRequest = NSFetchRequest()
|
let fetchRequest = CoreStoreFetchRequest()
|
||||||
from.applyToFetchRequest(fetchRequest, context: self)
|
from.applyToFetchRequest(fetchRequest, context: self)
|
||||||
|
|
||||||
fetchRequest.fetchLimit = 1
|
fetchRequest.fetchLimit = 1
|
||||||
@@ -238,7 +238,7 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
internal func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> [NSManagedObjectID]? {
|
internal func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> [NSManagedObjectID]? {
|
||||||
|
|
||||||
let fetchRequest = NSFetchRequest()
|
let fetchRequest = CoreStoreFetchRequest()
|
||||||
from.applyToFetchRequest(fetchRequest, context: self)
|
from.applyToFetchRequest(fetchRequest, context: self)
|
||||||
|
|
||||||
fetchRequest.fetchLimit = 0
|
fetchRequest.fetchLimit = 0
|
||||||
@@ -281,7 +281,7 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
internal func deleteAll<T: NSManagedObject>(from: From<T>, _ deleteClauses: [DeleteClause]) -> Int? {
|
internal func deleteAll<T: NSManagedObject>(from: From<T>, _ deleteClauses: [DeleteClause]) -> Int? {
|
||||||
|
|
||||||
let fetchRequest = NSFetchRequest()
|
let fetchRequest = CoreStoreFetchRequest()
|
||||||
from.applyToFetchRequest(fetchRequest, context: self)
|
from.applyToFetchRequest(fetchRequest, context: self)
|
||||||
|
|
||||||
fetchRequest.fetchLimit = 0
|
fetchRequest.fetchLimit = 0
|
||||||
@@ -334,7 +334,7 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
internal func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: [QueryClause]) -> U? {
|
internal func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: [QueryClause]) -> U? {
|
||||||
|
|
||||||
let fetchRequest = NSFetchRequest()
|
let fetchRequest = CoreStoreFetchRequest()
|
||||||
from.applyToFetchRequest(fetchRequest, context: self)
|
from.applyToFetchRequest(fetchRequest, context: self)
|
||||||
|
|
||||||
fetchRequest.fetchLimit = 0
|
fetchRequest.fetchLimit = 0
|
||||||
@@ -383,7 +383,7 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
internal func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: [QueryClause]) -> [[NSString: AnyObject]]? {
|
internal func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: [QueryClause]) -> [[NSString: AnyObject]]? {
|
||||||
|
|
||||||
let fetchRequest = NSFetchRequest()
|
let fetchRequest = CoreStoreFetchRequest()
|
||||||
from.applyToFetchRequest(fetchRequest, context: self)
|
from.applyToFetchRequest(fetchRequest, context: self)
|
||||||
|
|
||||||
fetchRequest.fetchLimit = 0
|
fetchRequest.fetchLimit = 0
|
||||||
|
|||||||
@@ -991,7 +991,7 @@ public final class ListMonitor<T: NSManagedObject> {
|
|||||||
|
|
||||||
private init(context: NSManagedObjectContext, transactionQueue: GCDQueue, from: From<T>, sectionBy: SectionBy?, fetchClauses: [FetchClause], createAsynchronously: ((ListMonitor<T>) -> Void)?) {
|
private init(context: NSManagedObjectContext, transactionQueue: GCDQueue, from: From<T>, sectionBy: SectionBy?, fetchClauses: [FetchClause], createAsynchronously: ((ListMonitor<T>) -> Void)?) {
|
||||||
|
|
||||||
let fetchRequest = NSFetchRequest()
|
let fetchRequest = CoreStoreFetchRequest()
|
||||||
fetchRequest.fetchLimit = 0
|
fetchRequest.fetchLimit = 0
|
||||||
fetchRequest.resultType = .ManagedObjectResultType
|
fetchRequest.resultType = .ManagedObjectResultType
|
||||||
fetchRequest.fetchBatchSize = 20
|
fetchRequest.fetchBatchSize = 20
|
||||||
|
|||||||
@@ -175,7 +175,7 @@ public final class ObjectMonitor<T: NSManagedObject> {
|
|||||||
|
|
||||||
private init(context: NSManagedObjectContext, object: T) {
|
private init(context: NSManagedObjectContext, object: T) {
|
||||||
|
|
||||||
let fetchRequest = NSFetchRequest()
|
let fetchRequest = CoreStoreFetchRequest()
|
||||||
fetchRequest.entity = object.entity
|
fetchRequest.entity = object.entity
|
||||||
fetchRequest.fetchLimit = 0
|
fetchRequest.fetchLimit = 0
|
||||||
fetchRequest.resultType = .ManagedObjectResultType
|
fetchRequest.resultType = .ManagedObjectResultType
|
||||||
|
|||||||
Reference in New Issue
Block a user