mirror of
https://github.com/JohnEstropia/CoreStore.git
synced 2026-03-30 14:21:49 +02:00
tidy up (WIP: queue check for NSManagedObjectContext property updates)
This commit is contained in:
@@ -106,7 +106,7 @@ public extension BaseDataTransaction {
|
|||||||
public func fetchOne<T: NSManagedObject>(from: From<T>, _ fetchClauses: FetchClause...) -> T? {
|
public func fetchOne<T: NSManagedObject>(from: From<T>, _ fetchClauses: FetchClause...) -> T? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -124,7 +124,7 @@ public extension BaseDataTransaction {
|
|||||||
public func fetchOne<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> T? {
|
public func fetchOne<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> T? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -142,7 +142,7 @@ public extension BaseDataTransaction {
|
|||||||
public func fetchAll<T: NSManagedObject>(from: From<T>, _ fetchClauses: FetchClause...) -> [T]? {
|
public func fetchAll<T: NSManagedObject>(from: From<T>, _ fetchClauses: FetchClause...) -> [T]? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -160,7 +160,7 @@ public extension BaseDataTransaction {
|
|||||||
public func fetchAll<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> [T]? {
|
public func fetchAll<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> [T]? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -178,7 +178,7 @@ public extension BaseDataTransaction {
|
|||||||
public func fetchCount<T: NSManagedObject>(from: From<T>, _ fetchClauses: FetchClause...) -> Int? {
|
public func fetchCount<T: NSManagedObject>(from: From<T>, _ fetchClauses: FetchClause...) -> Int? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -196,7 +196,7 @@ public extension BaseDataTransaction {
|
|||||||
public func fetchCount<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> Int? {
|
public func fetchCount<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> Int? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -214,7 +214,7 @@ public extension BaseDataTransaction {
|
|||||||
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ fetchClauses: FetchClause...) -> NSManagedObjectID? {
|
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ fetchClauses: FetchClause...) -> NSManagedObjectID? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -232,7 +232,7 @@ public extension BaseDataTransaction {
|
|||||||
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> NSManagedObjectID? {
|
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> NSManagedObjectID? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -250,7 +250,7 @@ public extension BaseDataTransaction {
|
|||||||
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ fetchClauses: FetchClause...) -> [NSManagedObjectID]? {
|
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ fetchClauses: FetchClause...) -> [NSManagedObjectID]? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -268,7 +268,7 @@ public extension BaseDataTransaction {
|
|||||||
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> [NSManagedObjectID]? {
|
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ fetchClauses: [FetchClause]) -> [NSManagedObjectID]? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
"Attempted to fetch from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -285,7 +285,7 @@ public extension BaseDataTransaction {
|
|||||||
public func deleteAll<T: NSManagedObject>(from: From<T>, _ deleteClauses: DeleteClause...) -> Int? {
|
public func deleteAll<T: NSManagedObject>(from: From<T>, _ deleteClauses: DeleteClause...) -> Int? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to delete from a \(typeName(self)) outside its designated queue."
|
"Attempted to delete from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -302,7 +302,7 @@ public extension BaseDataTransaction {
|
|||||||
public func deleteAll<T: NSManagedObject>(from: From<T>, _ deleteClauses: [DeleteClause]) -> Int? {
|
public func deleteAll<T: NSManagedObject>(from: From<T>, _ deleteClauses: [DeleteClause]) -> Int? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to delete from a \(typeName(self)) outside its designated queue."
|
"Attempted to delete from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -323,7 +323,7 @@ public extension BaseDataTransaction {
|
|||||||
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: QueryClause...) -> U? {
|
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: QueryClause...) -> U? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to query from a \(typeName(self)) outside its designated queue."
|
"Attempted to query from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -344,7 +344,7 @@ public extension BaseDataTransaction {
|
|||||||
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: [QueryClause]) -> U? {
|
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: [QueryClause]) -> U? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to query from a \(typeName(self)) outside its designated queue."
|
"Attempted to query from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -365,7 +365,7 @@ public extension BaseDataTransaction {
|
|||||||
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: QueryClause...) -> [[NSString: AnyObject]]? {
|
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: QueryClause...) -> [[NSString: AnyObject]]? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to query from a \(typeName(self)) outside its designated queue."
|
"Attempted to query from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -386,7 +386,7 @@ public extension BaseDataTransaction {
|
|||||||
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: [QueryClause]) -> [[NSString: AnyObject]]? {
|
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: [QueryClause]) -> [[NSString: AnyObject]]? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to query from a \(typeName(self)) outside its designated queue."
|
"Attempted to query from a \(typeName(self)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -45,7 +45,7 @@ public extension BaseDataTransaction {
|
|||||||
source: T.ImportSource) throws -> T? {
|
source: T.ImportSource) throws -> T? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to import an object of type \(typeName(into.entityClass)) outside the transaction's designated queue."
|
"Attempted to import an object of type \(typeName(into.entityClass)) outside the transaction's designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -74,7 +74,7 @@ public extension BaseDataTransaction {
|
|||||||
sourceArray: S) throws -> [T] {
|
sourceArray: S) throws -> [T] {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to import an object of type \(typeName(into.entityClass)) outside the transaction's designated queue."
|
"Attempted to import an object of type \(typeName(into.entityClass)) outside the transaction's designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -109,7 +109,7 @@ public extension BaseDataTransaction {
|
|||||||
source: T.ImportSource) throws -> T? {
|
source: T.ImportSource) throws -> T? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to import an object of type \(typeName(into.entityClass)) outside the transaction's designated queue."
|
"Attempted to import an object of type \(typeName(into.entityClass)) outside the transaction's designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -160,7 +160,7 @@ public extension BaseDataTransaction {
|
|||||||
@noescape preProcess: (mapping: [T.UniqueIDType: T.ImportSource]) throws -> [T.UniqueIDType: T.ImportSource] = { $0 }) throws -> [T] {
|
@noescape preProcess: (mapping: [T.UniqueIDType: T.ImportSource]) throws -> [T.UniqueIDType: T.ImportSource] = { $0 }) throws -> [T] {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to import an object of type \(typeName(into.entityClass)) outside the transaction's designated queue."
|
"Attempted to import an object of type \(typeName(into.entityClass)) outside the transaction's designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -55,6 +55,15 @@ internal extension NSManagedObjectContext {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal func isRunningInAllowedQueue() -> Bool {
|
||||||
|
|
||||||
|
guard let parentTransaction = self.parentTransaction else {
|
||||||
|
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return parentTransaction.isRunningInAllowedQueue()
|
||||||
|
}
|
||||||
|
|
||||||
internal func temporaryContextInTransactionWithConcurrencyType(concurrencyType: NSManagedObjectContextConcurrencyType) -> NSManagedObjectContext {
|
internal func temporaryContextInTransactionWithConcurrencyType(concurrencyType: NSManagedObjectContextConcurrencyType) -> NSManagedObjectContext {
|
||||||
|
|
||||||
let context = NSManagedObjectContext(concurrencyType: concurrencyType)
|
let context = NSManagedObjectContext(concurrencyType: concurrencyType)
|
||||||
|
|||||||
@@ -56,7 +56,7 @@ public /*abstract*/ class BaseDataTransaction {
|
|||||||
public func create<T: NSManagedObject>(into: Into<T>) -> T {
|
public func create<T: NSManagedObject>(into: Into<T>) -> T {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to create an entity of type \(typeName(T)) outside its designated queue."
|
"Attempted to create an entity of type \(typeName(T)) outside its designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -110,7 +110,7 @@ public /*abstract*/ class BaseDataTransaction {
|
|||||||
public func edit<T: NSManagedObject>(object: T?) -> T? {
|
public func edit<T: NSManagedObject>(object: T?) -> T? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to update an entity of type \(typeName(object)) outside its designated queue."
|
"Attempted to update an entity of type \(typeName(object)) outside its designated queue."
|
||||||
)
|
)
|
||||||
guard let object = object else {
|
guard let object = object else {
|
||||||
@@ -131,7 +131,7 @@ public /*abstract*/ class BaseDataTransaction {
|
|||||||
public func edit<T: NSManagedObject>(into: Into<T>, _ objectID: NSManagedObjectID) -> T? {
|
public func edit<T: NSManagedObject>(into: Into<T>, _ objectID: NSManagedObjectID) -> T? {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to update an entity of type \(typeName(T)) outside its designated queue."
|
"Attempted to update an entity of type \(typeName(T)) outside its designated queue."
|
||||||
)
|
)
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
@@ -150,7 +150,7 @@ public /*abstract*/ class BaseDataTransaction {
|
|||||||
public func delete(object: NSManagedObject?) {
|
public func delete(object: NSManagedObject?) {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to delete an entity outside its designated queue."
|
"Attempted to delete an entity outside its designated queue."
|
||||||
)
|
)
|
||||||
guard let object = object else {
|
guard let object = object else {
|
||||||
@@ -180,7 +180,7 @@ public /*abstract*/ class BaseDataTransaction {
|
|||||||
public func delete<S: SequenceType where S.Generator.Element: NSManagedObject>(objects: S) {
|
public func delete<S: SequenceType where S.Generator.Element: NSManagedObject>(objects: S) {
|
||||||
|
|
||||||
CoreStore.assert(
|
CoreStore.assert(
|
||||||
self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext(),
|
self.isRunningInAllowedQueue(),
|
||||||
"Attempted to delete entities outside their designated queue."
|
"Attempted to delete entities outside their designated queue."
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -223,4 +223,9 @@ public /*abstract*/ class BaseDataTransaction {
|
|||||||
context.undoManager = NSUndoManager()
|
context.undoManager = NSUndoManager()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal func isRunningInAllowedQueue() -> Bool {
|
||||||
|
|
||||||
|
return self.bypassesQueueing || self.transactionQueue.isCurrentExecutionContext()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user