allow public access to bridgeToObjectiveC and bridgeToSwift properties

This commit is contained in:
John Estropia
2016-03-28 19:07:35 +09:00
parent eda398d758
commit b0b0df2861
29 changed files with 528 additions and 469 deletions

View File

@@ -930,6 +930,7 @@
B5DBE2CB1C99148100B5CEFA /* ObjectiveC */ = { B5DBE2CB1C99148100B5CEFA /* ObjectiveC */ = {
isa = PBXGroup; isa = PBXGroup;
children = ( children = (
B5AEFAB41C9962AE00AD137F /* CoreStoreBridge.swift */,
B5DBE2CC1C9914A900B5CEFA /* CSCoreStore.swift */, B5DBE2CC1C9914A900B5CEFA /* CSCoreStore.swift */,
B5519A491CA1F4FB002BEF78 /* CSError.swift */, B5519A491CA1F4FB002BEF78 /* CSError.swift */,
B546F9611C9A13F400D5AC55 /* Setup */, B546F9611C9A13F400D5AC55 /* Setup */,
@@ -944,7 +945,6 @@
B5E222211CA4DE5700BA2E95 /* Internal */ = { B5E222211CA4DE5700BA2E95 /* Internal */ = {
isa = PBXGroup; isa = PBXGroup;
children = ( children = (
B5AEFAB41C9962AE00AD137F /* CoreStoreBridge.swift */,
B5ECDBF81CA804FD00C7F112 /* NSManagedObjectContext+ObjectiveC.swift */, B5ECDBF81CA804FD00C7F112 /* NSManagedObjectContext+ObjectiveC.swift */,
); );
name = Internal; name = Internal;

View File

@@ -40,14 +40,14 @@ class ErrorTests: XCTestCase {
let userInfo: NSDictionary = [:] let userInfo: NSDictionary = [:]
let objcError = error.objc let objcError = error.bridgeToObjectiveC
XCTAssertEqual(error, objcError.swift) XCTAssertEqual(error, objcError.bridgeToSwift)
XCTAssertEqual(objcError.domain, CoreStoreErrorDomain) XCTAssertEqual(objcError.domain, CoreStoreErrorDomain)
XCTAssertEqual(objcError.code, CoreStoreErrorCode.UnknownError.rawValue) XCTAssertEqual(objcError.code, CoreStoreErrorCode.UnknownError.rawValue)
XCTAssertEqual(objcError.userInfo, userInfo) XCTAssertEqual(objcError.userInfo, userInfo)
let objcError2 = objcError.swift.objc let objcError2 = objcError.bridgeToSwift.bridgeToObjectiveC
XCTAssertEqual(error, objcError2.swift) XCTAssertEqual(error, objcError2.bridgeToSwift)
XCTAssertEqual(objcError2.domain, CoreStoreErrorDomain) XCTAssertEqual(objcError2.domain, CoreStoreErrorDomain)
XCTAssertEqual(objcError2.code, CoreStoreErrorCode.UnknownError.rawValue) XCTAssertEqual(objcError2.code, CoreStoreErrorCode.UnknownError.rawValue)
XCTAssertEqual(objcError2.userInfo, userInfo) XCTAssertEqual(objcError2.userInfo, userInfo)
@@ -63,14 +63,14 @@ class ErrorTests: XCTestCase {
let userInfo: NSDictionary = [ let userInfo: NSDictionary = [
"existingPersistentStoreURL": dummyURL "existingPersistentStoreURL": dummyURL
] ]
let objcError = error.objc let objcError = error.bridgeToObjectiveC
XCTAssertEqual(error, objcError.swift) XCTAssertEqual(error, objcError.bridgeToSwift)
XCTAssertEqual(objcError.domain, CoreStoreErrorDomain) XCTAssertEqual(objcError.domain, CoreStoreErrorDomain)
XCTAssertEqual(objcError.code, CoreStoreErrorCode.DifferentPersistentStoreExistsAtURL.rawValue) XCTAssertEqual(objcError.code, CoreStoreErrorCode.DifferentPersistentStoreExistsAtURL.rawValue)
XCTAssertEqual(objcError.userInfo, userInfo) XCTAssertEqual(objcError.userInfo, userInfo)
let objcError2 = objcError.swift.objc let objcError2 = objcError.bridgeToSwift.bridgeToObjectiveC
XCTAssertEqual(error, objcError2.swift) XCTAssertEqual(error, objcError2.bridgeToSwift)
XCTAssertEqual(objcError2.domain, CoreStoreErrorDomain) XCTAssertEqual(objcError2.domain, CoreStoreErrorDomain)
XCTAssertEqual(objcError2.code, CoreStoreErrorCode.DifferentPersistentStoreExistsAtURL.rawValue) XCTAssertEqual(objcError2.code, CoreStoreErrorCode.DifferentPersistentStoreExistsAtURL.rawValue)
XCTAssertEqual(objcError2.userInfo, userInfo) XCTAssertEqual(objcError2.userInfo, userInfo)
@@ -90,14 +90,14 @@ class ErrorTests: XCTestCase {
"targetModel": model, "targetModel": model,
"targetModelVersion": version "targetModelVersion": version
] ]
let objcError = error.objc let objcError = error.bridgeToObjectiveC
XCTAssertEqual(error, objcError.swift) XCTAssertEqual(error, objcError.bridgeToSwift)
XCTAssertEqual(objcError.domain, CoreStoreErrorDomain) XCTAssertEqual(objcError.domain, CoreStoreErrorDomain)
XCTAssertEqual(objcError.code, CoreStoreErrorCode.MappingModelNotFound.rawValue) XCTAssertEqual(objcError.code, CoreStoreErrorCode.MappingModelNotFound.rawValue)
XCTAssertEqual(objcError.userInfo, userInfo) XCTAssertEqual(objcError.userInfo, userInfo)
let objcError2 = objcError.swift.objc let objcError2 = objcError.bridgeToSwift.bridgeToObjectiveC
XCTAssertEqual(error, objcError2.swift) XCTAssertEqual(error, objcError2.bridgeToSwift)
XCTAssertEqual(objcError2.domain, CoreStoreErrorDomain) XCTAssertEqual(objcError2.domain, CoreStoreErrorDomain)
XCTAssertEqual(objcError2.code, CoreStoreErrorCode.MappingModelNotFound.rawValue) XCTAssertEqual(objcError2.code, CoreStoreErrorCode.MappingModelNotFound.rawValue)
XCTAssertEqual(objcError2.userInfo, userInfo) XCTAssertEqual(objcError2.userInfo, userInfo)
@@ -112,14 +112,14 @@ class ErrorTests: XCTestCase {
let userInfo: NSDictionary = [ let userInfo: NSDictionary = [
"localStoreURL": dummyURL "localStoreURL": dummyURL
] ]
let objcError = error.objc let objcError = error.bridgeToObjectiveC
XCTAssertEqual(error, objcError.swift) XCTAssertEqual(error, objcError.bridgeToSwift)
XCTAssertEqual(objcError.domain, CoreStoreErrorDomain) XCTAssertEqual(objcError.domain, CoreStoreErrorDomain)
XCTAssertEqual(objcError.code, CoreStoreErrorCode.ProgressiveMigrationRequired.rawValue) XCTAssertEqual(objcError.code, CoreStoreErrorCode.ProgressiveMigrationRequired.rawValue)
XCTAssertEqual(objcError.userInfo, userInfo) XCTAssertEqual(objcError.userInfo, userInfo)
let objcError2 = objcError.swift.objc let objcError2 = objcError.bridgeToSwift.bridgeToObjectiveC
XCTAssertEqual(error, objcError2.swift) XCTAssertEqual(error, objcError2.bridgeToSwift)
XCTAssertEqual(objcError2.domain, CoreStoreErrorDomain) XCTAssertEqual(objcError2.domain, CoreStoreErrorDomain)
XCTAssertEqual(objcError2.code, CoreStoreErrorCode.ProgressiveMigrationRequired.rawValue) XCTAssertEqual(objcError2.code, CoreStoreErrorCode.ProgressiveMigrationRequired.rawValue)
XCTAssertEqual(objcError2.userInfo, userInfo) XCTAssertEqual(objcError2.userInfo, userInfo)
@@ -143,14 +143,14 @@ class ErrorTests: XCTestCase {
let userInfo: NSDictionary = [ let userInfo: NSDictionary = [
"NSError": internalError "NSError": internalError
] ]
let objcError = error.objc let objcError = error.bridgeToObjectiveC
XCTAssertEqual(error, objcError.swift) XCTAssertEqual(error, objcError.bridgeToSwift)
XCTAssertEqual(objcError.domain, CoreStoreErrorDomain) XCTAssertEqual(objcError.domain, CoreStoreErrorDomain)
XCTAssertEqual(objcError.code, CoreStoreErrorCode.InternalError.rawValue) XCTAssertEqual(objcError.code, CoreStoreErrorCode.InternalError.rawValue)
XCTAssertEqual(objcError.userInfo, userInfo) XCTAssertEqual(objcError.userInfo, userInfo)
let objcError2 = objcError.swift.objc let objcError2 = objcError.bridgeToSwift.bridgeToObjectiveC
XCTAssertEqual(error, objcError2.swift) XCTAssertEqual(error, objcError2.bridgeToSwift)
XCTAssertEqual(objcError2.domain, CoreStoreErrorDomain) XCTAssertEqual(objcError2.domain, CoreStoreErrorDomain)
XCTAssertEqual(objcError2.code, CoreStoreErrorCode.InternalError.rawValue) XCTAssertEqual(objcError2.code, CoreStoreErrorCode.InternalError.rawValue)
XCTAssertEqual(objcError2.userInfo, userInfo) XCTAssertEqual(objcError2.userInfo, userInfo)

View File

@@ -82,7 +82,7 @@ public enum CoreStoreError: ErrorType, CustomStringConvertible, CustomDebugStrin
public var description: String { public var description: String {
// TODO: // TODO:
return self.objc.description return self.bridgeToObjectiveC.description
} }
@@ -123,7 +123,7 @@ public enum CoreStoreError: ErrorType, CustomStringConvertible, CustomDebugStrin
internal init(_ error: ErrorType?) { internal init(_ error: ErrorType?) {
self = error.flatMap { $0.swift } ?? .Unknown self = error.flatMap { $0.bridgeToSwift } ?? .Unknown
} }
} }

View File

@@ -98,7 +98,7 @@ extension CoreStoreLogger {
@available(*, deprecated=2.0.0, message="Use log(error:message:fileName:lineNumber:functionName:) instead.") @available(*, deprecated=2.0.0, message="Use log(error:message:fileName:lineNumber:functionName:) instead.")
public func handleError(error error: NSError, message: String, fileName: StaticString, lineNumber: Int, functionName: StaticString) { public func handleError(error error: NSError, message: String, fileName: StaticString, lineNumber: Int, functionName: StaticString) {
self.log(error: error.swift, message: message, fileName: fileName, lineNumber: lineNumber, functionName: functionName) self.log(error: error.bridgeToSwift, message: message, fileName: fileName, lineNumber: lineNumber, functionName: functionName)
} }
} }

View File

@@ -43,9 +43,9 @@ public final class CSAsynchronousDataTransaction: CSBaseDataTransaction {
@objc @objc
public func commitWithCompletion(completion: ((result: CSSaveResult) -> Void)?) { public func commitWithCompletion(completion: ((result: CSSaveResult) -> Void)?) {
self.swift.commit { (result) in self.bridgeToSwift.commit { (result) in
completion?(result: result.objc) completion?(result: result.bridgeToObjectiveC)
} }
} }
@@ -60,9 +60,9 @@ public final class CSAsynchronousDataTransaction: CSBaseDataTransaction {
return bridge { return bridge {
self.swift.beginSynchronous { (transaction) in self.bridgeToSwift.beginSynchronous { (transaction) in
closure(transaction: transaction.objc) closure(transaction: transaction.bridgeToObjectiveC)
} }
} }
} }
@@ -79,7 +79,7 @@ public final class CSAsynchronousDataTransaction: CSBaseDataTransaction {
@objc @objc
public override func createInto(into: CSInto) -> NSManagedObject { public override func createInto(into: CSInto) -> NSManagedObject {
return self.swift.create(into.swift) return self.bridgeToSwift.create(into.bridgeToSwift)
} }
/** /**
@@ -92,7 +92,7 @@ public final class CSAsynchronousDataTransaction: CSBaseDataTransaction {
@warn_unused_result @warn_unused_result
public override func editObject(object: NSManagedObject?) -> NSManagedObject? { public override func editObject(object: NSManagedObject?) -> NSManagedObject? {
return self.swift.edit(object) return self.bridgeToSwift.edit(object)
} }
/** /**
@@ -106,7 +106,7 @@ public final class CSAsynchronousDataTransaction: CSBaseDataTransaction {
@warn_unused_result @warn_unused_result
public override func editInto(into: CSInto, objectID: NSManagedObjectID) -> NSManagedObject? { public override func editInto(into: CSInto, objectID: NSManagedObjectID) -> NSManagedObject? {
return self.swift.edit(into.swift, objectID) return self.bridgeToSwift.edit(into.bridgeToSwift, objectID)
} }
/** /**
@@ -117,7 +117,7 @@ public final class CSAsynchronousDataTransaction: CSBaseDataTransaction {
@objc @objc
public override func deleteObject(object: NSManagedObject?) { public override func deleteObject(object: NSManagedObject?) {
self.swift.delete(object) self.bridgeToSwift.delete(object)
} }
/** /**
@@ -128,27 +128,27 @@ public final class CSAsynchronousDataTransaction: CSBaseDataTransaction {
@objc @objc
public override func deleteObjects(objects: [NSManagedObject]) { public override func deleteObjects(objects: [NSManagedObject]) {
self.swift.delete(objects) self.bridgeToSwift.delete(objects)
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal typealias SwiftType = AsynchronousDataTransaction internal typealias SwiftType = AsynchronousDataTransaction
internal override var swift: AsynchronousDataTransaction { public override var bridgeToSwift: AsynchronousDataTransaction {
return super.swift as! AsynchronousDataTransaction return super.bridgeToSwift as! AsynchronousDataTransaction
} }
public required init(_ swiftObject: AsynchronousDataTransaction) { public required init(_ swiftValue: AsynchronousDataTransaction) {
super.init(swiftObject) super.init(swiftValue)
} }
required public init(_ swiftObject: BaseDataTransaction) { public required init(_ swiftValue: BaseDataTransaction) {
fatalError("init has not been implemented") fatalError("init(_:) requires an AsynchronousDataTransaction instance")
} }
} }
@@ -157,7 +157,7 @@ public final class CSAsynchronousDataTransaction: CSBaseDataTransaction {
extension AsynchronousDataTransaction { extension AsynchronousDataTransaction {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSAsynchronousDataTransaction internal typealias ObjectiveCType = CSAsynchronousDataTransaction
} }

View File

@@ -43,7 +43,7 @@ public extension CSBaseDataTransaction {
do { do {
return try self.swift.context.existingObjectWithID(object.objectID) return try self.bridgeToSwift.context.existingObjectWithID(object.objectID)
} }
catch _ { catch _ {
@@ -63,7 +63,7 @@ public extension CSBaseDataTransaction {
do { do {
return try self.swift.context.existingObjectWithID(objectID) return try self.bridgeToSwift.context.existingObjectWithID(objectID)
} }
catch _ { catch _ {
@@ -81,7 +81,7 @@ public extension CSBaseDataTransaction {
@warn_unused_result @warn_unused_result
public func fetchExistingObjects(objects: [NSManagedObject]) -> [NSManagedObject] { public func fetchExistingObjects(objects: [NSManagedObject]) -> [NSManagedObject] {
return objects.flatMap { try? self.swift.context.existingObjectWithID($0.objectID) } return objects.flatMap { try? self.bridgeToSwift.context.existingObjectWithID($0.objectID) }
} }
/** /**
@@ -94,7 +94,7 @@ public extension CSBaseDataTransaction {
@warn_unused_result @warn_unused_result
public func fetchExistingObjectsWithIDs(objectIDs: [NSManagedObjectID]) -> [NSManagedObject] { public func fetchExistingObjectsWithIDs(objectIDs: [NSManagedObjectID]) -> [NSManagedObject] {
return objectIDs.flatMap { try? self.swift.context.existingObjectWithID($0) } return objectIDs.flatMap { try? self.bridgeToSwift.context.existingObjectWithID($0) }
} }
/** /**
@@ -109,10 +109,10 @@ public extension CSBaseDataTransaction {
public func fetchOneFrom(from: CSFrom, fetchClauses: [CSFetchClause]) -> NSManagedObject? { public func fetchOneFrom(from: CSFrom, fetchClauses: [CSFetchClause]) -> NSManagedObject? {
CoreStore.assert( CoreStore.assert(
self.swift.isRunningInAllowedQueue(), self.bridgeToSwift.isRunningInAllowedQueue(),
"Attempted to fetch from a \(typeName(self)) outside its designated queue." "Attempted to fetch from a \(typeName(self)) outside its designated queue."
) )
return self.swift.context.fetchOne(from, fetchClauses) return self.bridgeToSwift.context.fetchOne(from, fetchClauses)
} }
/** /**
@@ -127,10 +127,10 @@ public extension CSBaseDataTransaction {
public func fetchAllFrom(from: CSFrom, fetchClauses: [CSFetchClause]) -> [NSManagedObject]? { public func fetchAllFrom(from: CSFrom, fetchClauses: [CSFetchClause]) -> [NSManagedObject]? {
CoreStore.assert( CoreStore.assert(
self.swift.isRunningInAllowedQueue(), self.bridgeToSwift.isRunningInAllowedQueue(),
"Attempted to fetch from a \(typeName(self)) outside its designated queue." "Attempted to fetch from a \(typeName(self)) outside its designated queue."
) )
return self.swift.context.fetchAll(from, fetchClauses) return self.bridgeToSwift.context.fetchAll(from, fetchClauses)
} }
/** /**
@@ -145,10 +145,10 @@ public extension CSBaseDataTransaction {
public func fetchCountFrom(from: CSFrom, fetchClauses: [CSFetchClause]) -> NSNumber? { public func fetchCountFrom(from: CSFrom, fetchClauses: [CSFetchClause]) -> NSNumber? {
CoreStore.assert( CoreStore.assert(
self.swift.isRunningInAllowedQueue(), self.bridgeToSwift.isRunningInAllowedQueue(),
"Attempted to fetch from a \(typeName(self)) outside its designated queue." "Attempted to fetch from a \(typeName(self)) outside its designated queue."
) )
return self.swift.context.fetchCount(from, fetchClauses) return self.bridgeToSwift.context.fetchCount(from, fetchClauses)
} }
/** /**
@@ -163,10 +163,10 @@ public extension CSBaseDataTransaction {
public func fetchObjectIDFrom(from: CSFrom, fetchClauses: [CSFetchClause]) -> NSManagedObjectID? { public func fetchObjectIDFrom(from: CSFrom, fetchClauses: [CSFetchClause]) -> NSManagedObjectID? {
CoreStore.assert( CoreStore.assert(
self.swift.isRunningInAllowedQueue(), self.bridgeToSwift.isRunningInAllowedQueue(),
"Attempted to fetch from a \(typeName(self)) outside its designated queue." "Attempted to fetch from a \(typeName(self)) outside its designated queue."
) )
return self.swift.context.fetchObjectID(from, fetchClauses) return self.bridgeToSwift.context.fetchObjectID(from, fetchClauses)
} }
/** /**
@@ -181,10 +181,10 @@ public extension CSBaseDataTransaction {
public func fetchObjectIDsFrom(from: CSFrom, fetchClauses: [CSFetchClause]) -> [NSManagedObjectID]? { public func fetchObjectIDsFrom(from: CSFrom, fetchClauses: [CSFetchClause]) -> [NSManagedObjectID]? {
CoreStore.assert( CoreStore.assert(
self.swift.isRunningInAllowedQueue(), self.bridgeToSwift.isRunningInAllowedQueue(),
"Attempted to fetch from a \(typeName(self)) outside its designated queue." "Attempted to fetch from a \(typeName(self)) outside its designated queue."
) )
return self.swift.context.fetchObjectIDs(from, fetchClauses) return self.bridgeToSwift.context.fetchObjectIDs(from, fetchClauses)
} }
/** /**
@@ -198,9 +198,9 @@ public extension CSBaseDataTransaction {
public func deleteAllFrom(from: CSFrom, deleteClauses: [CSDeleteClause]) -> NSNumber? { public func deleteAllFrom(from: CSFrom, deleteClauses: [CSDeleteClause]) -> NSNumber? {
CoreStore.assert( CoreStore.assert(
self.swift.isRunningInAllowedQueue(), self.bridgeToSwift.isRunningInAllowedQueue(),
"Attempted to delete from a \(typeName(self)) outside its designated queue." "Attempted to delete from a \(typeName(self)) outside its designated queue."
) )
return self.swift.context.deleteAll(from, deleteClauses) return self.bridgeToSwift.context.deleteAll(from, deleteClauses)
} }
} }

View File

@@ -33,7 +33,7 @@ import CoreData
The `CSBaseDataTransaction` serves as the Objective-C bridging type for `BaseDataTransaction`. The `CSBaseDataTransaction` serves as the Objective-C bridging type for `BaseDataTransaction`.
*/ */
@objc @objc
public class CSBaseDataTransaction: NSObject, CoreStoreBridge { public class CSBaseDataTransaction: NSObject, CoreStoreObjectiveCType {
// MARK: Object management // MARK: Object management
@@ -43,7 +43,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@objc @objc
public var hasChanges: Bool { public var hasChanges: Bool {
return self.swift.hasChanges return self.bridgeToSwift.hasChanges
} }
/** /**
@@ -55,7 +55,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@objc @objc
public func createInto(into: CSInto) -> NSManagedObject { public func createInto(into: CSInto) -> NSManagedObject {
return self.swift.create(into.swift) return self.bridgeToSwift.create(into.bridgeToSwift)
} }
/** /**
@@ -68,7 +68,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func editObject(object: NSManagedObject?) -> NSManagedObject? { public func editObject(object: NSManagedObject?) -> NSManagedObject? {
return self.swift.edit(object) return self.bridgeToSwift.edit(object)
} }
/** /**
@@ -82,7 +82,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func editInto(into: CSInto, objectID: NSManagedObjectID) -> NSManagedObject? { public func editInto(into: CSInto, objectID: NSManagedObjectID) -> NSManagedObject? {
return self.swift.edit(into.swift, objectID) return self.bridgeToSwift.edit(into.bridgeToSwift, objectID)
} }
/** /**
@@ -93,7 +93,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@objc @objc
public func deleteObject(object: NSManagedObject?) { public func deleteObject(object: NSManagedObject?) {
self.swift.delete(object) self.bridgeToSwift.delete(object)
} }
/** /**
@@ -104,7 +104,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@objc @objc
public func deleteObjects(objects: [NSManagedObject]) { public func deleteObjects(objects: [NSManagedObject]) {
self.swift.delete(objects) self.bridgeToSwift.delete(objects)
} }
/** /**
@@ -113,7 +113,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@objc @objc
public func refreshAllObjectsAsFaults() { public func refreshAllObjectsAsFaults() {
self.swift.refreshAllObjectsAsFaults() self.bridgeToSwift.refreshAllObjectsAsFaults()
} }
@@ -128,7 +128,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func insertedObjects() -> Set<NSManagedObject> { public func insertedObjects() -> Set<NSManagedObject> {
return self.swift.insertedObjects() return self.bridgeToSwift.insertedObjects()
} }
/** /**
@@ -141,7 +141,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func insertedObjectsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObject> { public func insertedObjectsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObject> {
return self.swift.insertedObjects(entity) return self.bridgeToSwift.insertedObjects(entity)
} }
/** /**
@@ -153,7 +153,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func insertedObjectIDs() -> Set<NSManagedObjectID> { public func insertedObjectIDs() -> Set<NSManagedObjectID> {
return self.swift.insertedObjectIDs() return self.bridgeToSwift.insertedObjectIDs()
} }
/** /**
@@ -166,7 +166,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func insertedObjectIDsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObjectID> { public func insertedObjectIDsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObjectID> {
return self.swift.insertedObjectIDs(entity) return self.bridgeToSwift.insertedObjectIDs(entity)
} }
/** /**
@@ -178,7 +178,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func updatedObjects() -> Set<NSManagedObject> { public func updatedObjects() -> Set<NSManagedObject> {
return self.swift.updatedObjects() return self.bridgeToSwift.updatedObjects()
} }
/** /**
@@ -191,7 +191,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func updatedObjectsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObject> { public func updatedObjectsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObject> {
return self.swift.updatedObjects(entity) return self.bridgeToSwift.updatedObjects(entity)
} }
/** /**
@@ -203,7 +203,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func updatedObjectIDs() -> Set<NSManagedObjectID> { public func updatedObjectIDs() -> Set<NSManagedObjectID> {
return self.swift.updatedObjectIDs() return self.bridgeToSwift.updatedObjectIDs()
} }
/** /**
@@ -216,7 +216,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func updatedObjectIDsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObjectID> { public func updatedObjectIDsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObjectID> {
return self.swift.updatedObjectIDs(entity) return self.bridgeToSwift.updatedObjectIDs(entity)
} }
/** /**
@@ -228,7 +228,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func deletedObjects() -> Set<NSManagedObject> { public func deletedObjects() -> Set<NSManagedObject> {
return self.swift.deletedObjects() return self.bridgeToSwift.deletedObjects()
} }
/** /**
@@ -241,7 +241,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func deletedObjectsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObject> { public func deletedObjectsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObject> {
return self.swift.deletedObjects(entity) return self.bridgeToSwift.deletedObjects(entity)
} }
/** /**
@@ -254,7 +254,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func deletedObjectIDs() -> Set<NSManagedObjectID> { public func deletedObjectIDs() -> Set<NSManagedObjectID> {
return self.swift.deletedObjectIDs() return self.bridgeToSwift.deletedObjectIDs()
} }
/** /**
@@ -267,7 +267,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func deletedObjectIDsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObjectID> { public func deletedObjectIDsOfType(entity: NSManagedObject.Type) -> Set<NSManagedObjectID> {
return self.swift.deletedObjectIDs(entity) return self.bridgeToSwift.deletedObjectIDs(entity)
} }
@@ -275,7 +275,7 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
public override var hash: Int { public override var hash: Int {
return ObjectIdentifier(self.swift).hashValue return ObjectIdentifier(self.bridgeToSwift).hashValue
} }
public override func isEqual(object: AnyObject?) -> Bool { public override func isEqual(object: AnyObject?) -> Bool {
@@ -284,34 +284,37 @@ public class CSBaseDataTransaction: NSObject, CoreStoreBridge {
return false return false
} }
return self.swift === object.swift return self.bridgeToSwift === object.bridgeToSwift
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal typealias SwiftType = BaseDataTransaction public typealias SwiftType = BaseDataTransaction
public required init(_ swiftObject: BaseDataTransaction) { public required init(_ swiftValue: BaseDataTransaction) {
self.swiftObject = swiftObject self.swiftTransaction = swiftValue
super.init() super.init()
} }
internal var swift: BaseDataTransaction { public var bridgeToSwift: BaseDataTransaction {
return self.swiftObject return self.swiftTransaction
} }
private let swiftObject: BaseDataTransaction
// MARK: Private
private let swiftTransaction: BaseDataTransaction
} }
// MARK: - BaseDataTransaction // MARK: - BaseDataTransaction
extension BaseDataTransaction: CoreStoreBridgeable { extension BaseDataTransaction: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSBaseDataTransaction public typealias ObjectiveCType = CSBaseDataTransaction
} }

View File

@@ -120,7 +120,7 @@ public extension CSCoreStore {
return try bridge { return try bridge {
try CoreStore.addStorageAndWait(storage.swift) try CoreStore.addStorageAndWait(storage.bridgeToSwift)
} }
} }
@@ -141,7 +141,7 @@ public extension CSCoreStore {
return try bridge { return try bridge {
try CoreStore.addStorageAndWait(storage.swift) try CoreStore.addStorageAndWait(storage.bridgeToSwift)
} }
} }
} }

View File

@@ -40,7 +40,7 @@ public extension CSCoreStore {
return CoreStore.beginAsynchronous { (transaction) in return CoreStore.beginAsynchronous { (transaction) in
closure(transaction: transaction.objc) closure(transaction: transaction.bridgeToObjectiveC)
} }
} }
@@ -57,7 +57,7 @@ public extension CSCoreStore {
CoreStore.beginSynchronous { (transaction) in CoreStore.beginSynchronous { (transaction) in
closure(transaction: transaction.objc) closure(transaction: transaction.bridgeToObjectiveC)
} }
} }
} }

View File

@@ -44,11 +44,11 @@ public final class CSCoreStore: NSObject {
get { get {
return CoreStore.defaultStack.objc return CoreStore.defaultStack.bridgeToObjectiveC
} }
set { set {
CoreStore.defaultStack = newValue.swift CoreStore.defaultStack = newValue.bridgeToSwift
} }
} }

View File

@@ -43,7 +43,7 @@ public extension CSDataStack {
do { do {
return try self.swift.mainContext.existingObjectWithID(object.objectID) return try self.bridgeToSwift.mainContext.existingObjectWithID(object.objectID)
} }
catch _ { catch _ {
@@ -63,7 +63,7 @@ public extension CSDataStack {
do { do {
return try self.swift.mainContext.existingObjectWithID(objectID) return try self.bridgeToSwift.mainContext.existingObjectWithID(objectID)
} }
catch _ { catch _ {
@@ -81,7 +81,7 @@ public extension CSDataStack {
@warn_unused_result @warn_unused_result
public func fetchExistingObjects(objects: [NSManagedObject]) -> [NSManagedObject] { public func fetchExistingObjects(objects: [NSManagedObject]) -> [NSManagedObject] {
return objects.flatMap { try? self.swift.mainContext.existingObjectWithID($0.objectID) } return objects.flatMap { try? self.bridgeToSwift.mainContext.existingObjectWithID($0.objectID) }
} }
/** /**
@@ -94,7 +94,7 @@ public extension CSDataStack {
@warn_unused_result @warn_unused_result
public func fetchExistingObjectsWithIDs(objectIDs: [NSManagedObjectID]) -> [NSManagedObject] { public func fetchExistingObjectsWithIDs(objectIDs: [NSManagedObjectID]) -> [NSManagedObject] {
return objectIDs.flatMap { try? self.swift.mainContext.existingObjectWithID($0) } return objectIDs.flatMap { try? self.bridgeToSwift.mainContext.existingObjectWithID($0) }
} }
/** /**
@@ -112,7 +112,7 @@ public extension CSDataStack {
NSThread.isMainThread(), NSThread.isMainThread(),
"Attempted to fetch from a \(typeName(self)) outside the main thread." "Attempted to fetch from a \(typeName(self)) outside the main thread."
) )
return self.swift.mainContext.fetchOne(from, fetchClauses) return self.bridgeToSwift.mainContext.fetchOne(from, fetchClauses)
} }
/** /**
@@ -130,7 +130,7 @@ public extension CSDataStack {
NSThread.isMainThread(), NSThread.isMainThread(),
"Attempted to fetch from a \(typeName(self)) outside the main thread." "Attempted to fetch from a \(typeName(self)) outside the main thread."
) )
return self.swift.mainContext.fetchAll(from, fetchClauses) return self.bridgeToSwift.mainContext.fetchAll(from, fetchClauses)
} }
/** /**
@@ -148,7 +148,7 @@ public extension CSDataStack {
NSThread.isMainThread(), NSThread.isMainThread(),
"Attempted to fetch from a \(typeName(self)) outside the main thread." "Attempted to fetch from a \(typeName(self)) outside the main thread."
) )
return self.swift.mainContext.fetchCount(from, fetchClauses) return self.bridgeToSwift.mainContext.fetchCount(from, fetchClauses)
} }
/** /**
@@ -166,7 +166,7 @@ public extension CSDataStack {
NSThread.isMainThread(), NSThread.isMainThread(),
"Attempted to fetch from a \(typeName(self)) outside the main thread." "Attempted to fetch from a \(typeName(self)) outside the main thread."
) )
return self.swift.mainContext.fetchObjectID(from, fetchClauses) return self.bridgeToSwift.mainContext.fetchObjectID(from, fetchClauses)
} }
/** /**
@@ -184,7 +184,7 @@ public extension CSDataStack {
NSThread.isMainThread(), NSThread.isMainThread(),
"Attempted to fetch from a \(typeName(self)) outside the main thread." "Attempted to fetch from a \(typeName(self)) outside the main thread."
) )
return self.swift.mainContext.fetchObjectIDs(from, fetchClauses) return self.bridgeToSwift.mainContext.fetchObjectIDs(from, fetchClauses)
} }
/** /**
@@ -201,6 +201,6 @@ public extension CSDataStack {
NSThread.isMainThread(), NSThread.isMainThread(),
"Attempted to delete from a \(typeName(self)) outside the main thread." "Attempted to delete from a \(typeName(self)) outside the main thread."
) )
return self.swift.mainContext.deleteAll(from, deleteClauses) return self.bridgeToSwift.mainContext.deleteAll(from, deleteClauses)
} }
} }

View File

@@ -38,9 +38,9 @@ public extension CSDataStack {
@objc @objc
public func beginAsynchronous(closure: (transaction: CSAsynchronousDataTransaction) -> Void) { public func beginAsynchronous(closure: (transaction: CSAsynchronousDataTransaction) -> Void) {
return self.swift.beginAsynchronous { (transaction) in return self.bridgeToSwift.beginAsynchronous { (transaction) in
closure(transaction: transaction.objc) closure(transaction: transaction.bridgeToObjectiveC)
} }
} }
@@ -55,9 +55,9 @@ public extension CSDataStack {
return bridge { return bridge {
self.swift.beginSynchronous { (transaction) in self.bridgeToSwift.beginSynchronous { (transaction) in
closure(transaction: transaction.objc) closure(transaction: transaction.bridgeToObjectiveC)
} }
} }
} }
@@ -74,7 +74,7 @@ public extension CSDataStack {
return bridge { return bridge {
self.swift.beginUnsafe() self.bridgeToSwift.beginUnsafe()
} }
} }
@@ -90,7 +90,7 @@ public extension CSDataStack {
return bridge { return bridge {
self.swift.beginUnsafe(supportsUndo: supportsUndo) self.bridgeToSwift.beginUnsafe(supportsUndo: supportsUndo)
} }
} }
@@ -100,6 +100,6 @@ public extension CSDataStack {
@objc @objc
public func refreshAllObjectsAsFaults() { public func refreshAllObjectsAsFaults() {
self.swift.refreshAllObjectsAsFaults() self.bridgeToSwift.refreshAllObjectsAsFaults()
} }
} }

View File

@@ -33,7 +33,7 @@ import CoreData
The `CSDataStack` serves as the Objective-C bridging type for `DataStack`. The `CSDataStack` serves as the Objective-C bridging type for `DataStack`.
*/ */
@objc @objc
public final class CSDataStack: NSObject, CoreStoreBridge { public final class CSDataStack: NSObject, CoreStoreObjectiveCType {
/** /**
Initializes a `CSDataStack` with default settings. CoreStore searches for <CFBundleName>.xcdatamodeld from the main `NSBundle` and loads an `NSManagedObjectModel` from it. An assertion is raised if the model could not be found. Initializes a `CSDataStack` with default settings. CoreStore searches for <CFBundleName>.xcdatamodeld from the main `NSBundle` and loads an `NSManagedObjectModel` from it. An assertion is raised if the model could not be found.
@@ -122,7 +122,7 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
@objc @objc
public var modelVersion: String { public var modelVersion: String {
return self.swift.modelVersion return self.bridgeToSwift.modelVersion
} }
/** /**
@@ -131,7 +131,7 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
@objc @objc
public var entityClassesByName: [String: NSManagedObject.Type] { public var entityClassesByName: [String: NSManagedObject.Type] {
return self.swift.entityTypesByName return self.bridgeToSwift.entityTypesByName
} }
/** /**
@@ -142,7 +142,7 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
@objc @objc
public func entityClassWithName(name: String) -> NSManagedObject.Type? { public func entityClassWithName(name: String) -> NSManagedObject.Type? {
return self.swift.entityTypesByName[name] return self.bridgeToSwift.entityTypesByName[name]
} }
/** /**
@@ -151,7 +151,7 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
@objc @objc
public func entityDescriptionForClass(type: NSManagedObject.Type) -> NSEntityDescription? { public func entityDescriptionForClass(type: NSManagedObject.Type) -> NSEntityDescription? {
return self.swift.entityDescriptionForType(type) return self.bridgeToSwift.entityDescriptionForType(type)
} }
/** /**
@@ -167,7 +167,7 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
return try bridge { return try bridge {
try self.swift.addStorageAndWait(InMemoryStore) try self.bridgeToSwift.addStorageAndWait(InMemoryStore)
} }
} }
@@ -184,7 +184,7 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
return try bridge { return try bridge {
return try self.swift.addStorageAndWait(SQLiteStore) return try self.bridgeToSwift.addStorageAndWait(SQLiteStore)
} }
} }
@@ -205,7 +205,7 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
return try bridge { return try bridge {
return try self.swift.addStorageAndWait(storage.swift) return try self.bridgeToSwift.addStorageAndWait(storage.bridgeToSwift)
} }
} }
@@ -226,7 +226,7 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
return try bridge { return try bridge {
return try self.swift.addStorageAndWait(storage.swift) return try self.bridgeToSwift.addStorageAndWait(storage.bridgeToSwift)
} }
} }
@@ -235,7 +235,7 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
public override var hash: Int { public override var hash: Int {
return ObjectIdentifier(self.swift).hashValue return ObjectIdentifier(self.bridgeToSwift).hashValue
} }
public override func isEqual(object: AnyObject?) -> Bool { public override func isEqual(object: AnyObject?) -> Bool {
@@ -244,17 +244,17 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
return false return false
} }
return self.swift === object.swift return self.bridgeToSwift === object.bridgeToSwift
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: DataStack public let bridgeToSwift: DataStack
internal init(_ swiftObject: DataStack) { public init(_ swiftValue: DataStack) {
self.swift = swiftObject self.bridgeToSwift = swiftValue
super.init() super.init()
} }
} }
@@ -262,9 +262,9 @@ public final class CSDataStack: NSObject, CoreStoreBridge {
// MARK: - DataStack // MARK: - DataStack
extension DataStack: CoreStoreBridgeable { extension DataStack: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSDataStack public typealias ObjectiveCType = CSDataStack
} }

View File

@@ -32,20 +32,147 @@ import CoreData
/** /**
The `CSError` provides a facade for global CoreStore error declarations. The `CSError` provides a facade for global CoreStore error declarations.
*/ */
public final class CSError: NSObject { @objc
public final class CSError: NSError, CoreStoreObjectiveCType {
/** /**
The `NSError` error domain for `CSCoreStore`. The `NSError` error domain for `CSCoreStore`.
*/ */
@objc @objc
public static let domain = CoreStoreErrorDomain public static let errorDomain = CoreStoreErrorDomain
// MARK: Private // MARK: NSObject
private override init() { public override var hash: Int {
fatalError() return self.bridgeToSwift.hashValue
}
public override func isEqual(object: AnyObject?) -> Bool {
guard let object = object as? CSError else {
return false
}
return self.bridgeToSwift == object.bridgeToSwift
}
// MARK: CoreStoreObjectiveCType
private var swiftError: CoreStoreError?
public var bridgeToSwift: CoreStoreError {
if let swift = self.swiftError {
return swift
}
func createSwiftObject(error: CSError) -> CoreStoreError {
guard error.domain == CoreStoreErrorDomain else {
return .InternalError(NSError: self)
}
guard let code = CoreStoreErrorCode(rawValue: error.code) else {
return .Unknown
}
let info = error.userInfo
switch code {
case .UnknownError:
return .Unknown
case .DifferentPersistentStoreExistsAtURL:
guard case let existingPersistentStoreURL as NSURL = info["existingPersistentStoreURL"] else {
return .Unknown
}
return .DifferentStorageExistsAtURL(existingPersistentStoreURL: existingPersistentStoreURL)
case .MappingModelNotFound:
guard let localStoreURL = info["localStoreURL"] as? NSURL,
let targetModel = info["targetModel"] as? NSManagedObjectModel,
let targetModelVersion = info["targetModelVersion"] as? String else {
return .Unknown
}
return .MappingModelNotFound(localStoreURL: localStoreURL, targetModel: targetModel, targetModelVersion: targetModelVersion)
case .ProgressiveMigrationRequired:
guard let localStoreURL = info["localStoreURL"] as? NSURL else {
return .Unknown
}
return .ProgressiveMigrationRequired(localStoreURL: localStoreURL)
case .InternalError:
guard case let NSError as NSError = info["NSError"] else {
return .Unknown
}
return .InternalError(NSError: NSError)
}
}
let swift = createSwiftObject(self)
self.swiftError = swift
return swift
}
/**
Do not call directly!
*/
public init(_ swiftValue: CoreStoreError) {
self.swiftError = swiftValue
let code: CoreStoreErrorCode
let info: [NSObject: AnyObject]
switch swiftValue {
case .Unknown:
code = .UnknownError
info = [:]
case .DifferentStorageExistsAtURL(let existingPersistentStoreURL):
code = .DifferentPersistentStoreExistsAtURL
info = [
"existingPersistentStoreURL": existingPersistentStoreURL
]
case .MappingModelNotFound(let localStoreURL, let targetModel, let targetModelVersion):
code = .MappingModelNotFound
info = [
"localStoreURL": localStoreURL,
"targetModel": targetModel,
"targetModelVersion": targetModelVersion
]
case .ProgressiveMigrationRequired(let localStoreURL):
code = .ProgressiveMigrationRequired
info = [
"localStoreURL": localStoreURL
]
case .InternalError(let NSError):
code = .InternalError
info = [
"NSError": NSError
]
}
super.init(domain: CoreStoreErrorDomain, code: code.rawValue, userInfo: info)
}
public required init?(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
} }
} }
@@ -85,112 +212,40 @@ public enum CSErrorCode: Int {
} }
// MARK: - CoreStoreError
extension CoreStoreError: CoreStoreSwiftType {
// MARK: CoreStoreSwiftType
public var bridgeToObjectiveC: CSError {
return CSError(self)
}
}
// MARK: Internal // MARK: Internal
internal extension ErrorType { internal extension ErrorType {
internal var swift: CoreStoreError { internal var bridgeToSwift: CoreStoreError {
if case let error as CoreStoreError = self { switch self {
return error case let error as CoreStoreError: return error
} case let error as CSError: return error.bridgeToSwift
default: return .Unknown
guard let error = (self as Any) as? NSError else {
return .Unknown
}
guard error.domain == CoreStoreErrorDomain else {
return .InternalError(NSError: error)
}
guard let code = CoreStoreErrorCode(rawValue: error.code) else {
return .Unknown
}
let info = error.userInfo
switch code {
case .UnknownError:
return .Unknown
case .DifferentPersistentStoreExistsAtURL:
guard case let existingPersistentStoreURL as NSURL = info["existingPersistentStoreURL"] else {
return .Unknown
}
return .DifferentStorageExistsAtURL(existingPersistentStoreURL: existingPersistentStoreURL)
case .MappingModelNotFound:
guard let localStoreURL = info["localStoreURL"] as? NSURL,
let targetModel = info["targetModel"] as? NSManagedObjectModel,
let targetModelVersion = info["targetModelVersion"] as? String else {
return .Unknown
}
return .MappingModelNotFound(localStoreURL: localStoreURL, targetModel: targetModel, targetModelVersion: targetModelVersion)
case .ProgressiveMigrationRequired:
guard let localStoreURL = info["localStoreURL"] as? NSURL else {
return .Unknown
}
return .ProgressiveMigrationRequired(localStoreURL: localStoreURL)
case .InternalError:
guard case let NSError as NSError = info["NSError"] else {
return .Unknown
}
return .InternalError(NSError: NSError)
} }
} }
internal var objc: NSError { internal var bridgeToObjectiveC: NSError {
guard let error = self as? CoreStoreError else { switch self {
return ((self as Any) as? NSError) ?? self as NSError case let error as CoreStoreError: return error.bridgeToObjectiveC
case let error as CSError: return error
default: return self as NSError
} }
let code: CoreStoreErrorCode
let info: [NSObject: AnyObject]
switch error {
case .Unknown:
code = .UnknownError
info = [:]
case .DifferentStorageExistsAtURL(let existingPersistentStoreURL):
code = .DifferentPersistentStoreExistsAtURL
info = [
"existingPersistentStoreURL": existingPersistentStoreURL
]
case .MappingModelNotFound(let localStoreURL, let targetModel, let targetModelVersion):
code = .MappingModelNotFound
info = [
"localStoreURL": localStoreURL,
"targetModel": targetModel,
"targetModelVersion": targetModelVersion
]
case .ProgressiveMigrationRequired(let localStoreURL):
code = .ProgressiveMigrationRequired
info = [
"localStoreURL": localStoreURL
]
case .InternalError(let NSError):
code = .InternalError
info = [
"NSError": NSError
]
}
return NSError(domain: CoreStoreErrorDomain, code: code.rawValue, userInfo: info)
} }
} }

View File

@@ -33,7 +33,7 @@ import CoreData
The `CSFrom` serves as the Objective-C bridging type for `From`. The `CSFrom` serves as the Objective-C bridging type for `From`.
*/ */
@objc @objc
public final class CSFrom: NSObject, CoreStoreBridge { public final class CSFrom: NSObject, CoreStoreObjectiveCType {
/** /**
Initializes a `CSFrom` clause with the specified entity class. Initializes a `CSFrom` clause with the specified entity class.
@@ -106,13 +106,13 @@ public final class CSFrom: NSObject, CoreStoreBridge {
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: From<NSManagedObject> public let bridgeToSwift: From<NSManagedObject>
internal init<T: NSManagedObject>(_ swiftObject: From<T>) { public init<T: NSManagedObject>(_ swiftValue: From<T>) {
self.swift = swiftObject.upcast() self.bridgeToSwift = swiftValue.upcast()
super.init() super.init()
} }
} }
@@ -120,11 +120,11 @@ public final class CSFrom: NSObject, CoreStoreBridge {
// MARK: - From // MARK: - From
extension From: CoreStoreBridgeable { extension From: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal var objc: CSFrom { public var bridgeToObjectiveC: CSFrom {
return CSFrom(self) return CSFrom(self)
} }

View File

@@ -33,7 +33,7 @@ import CoreData
The `CSGroupBy` serves as the Objective-C bridging type for `GroupBy`. The `CSGroupBy` serves as the Objective-C bridging type for `GroupBy`.
*/ */
@objc @objc
public final class CSGroupBy: NSObject, CSQueryClause, CoreStoreBridge { public final class CSGroupBy: NSObject, CSQueryClause, CoreStoreObjectiveCType {
/** /**
Initializes a `CSGroupBy` clause with a list of key path strings Initializes a `CSGroupBy` clause with a list of key path strings
@@ -52,7 +52,7 @@ public final class CSGroupBy: NSObject, CSQueryClause, CoreStoreBridge {
public override var hash: Int { public override var hash: Int {
return self.swift.hashValue return self.bridgeToSwift.hashValue
} }
public override func isEqual(object: AnyObject?) -> Bool { public override func isEqual(object: AnyObject?) -> Bool {
@@ -61,7 +61,7 @@ public final class CSGroupBy: NSObject, CSQueryClause, CoreStoreBridge {
return false return false
} }
return self.swift == object.swift return self.bridgeToSwift == object.bridgeToSwift
} }
@@ -70,17 +70,17 @@ public final class CSGroupBy: NSObject, CSQueryClause, CoreStoreBridge {
@objc @objc
public func applyToFetchRequest(fetchRequest: NSFetchRequest) { public func applyToFetchRequest(fetchRequest: NSFetchRequest) {
self.swift.applyToFetchRequest(fetchRequest) self.bridgeToSwift.applyToFetchRequest(fetchRequest)
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: GroupBy public let bridgeToSwift: GroupBy
internal init(_ swiftObject: GroupBy) { public init(_ swiftValue: GroupBy) {
self.swift = swiftObject self.bridgeToSwift = swiftValue
super.init() super.init()
} }
} }
@@ -88,9 +88,9 @@ public final class CSGroupBy: NSObject, CSQueryClause, CoreStoreBridge {
// MARK: - GroupBy // MARK: - GroupBy
extension GroupBy: CoreStoreBridgeable { extension GroupBy: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSGroupBy public typealias ObjectiveCType = CSGroupBy
} }

View File

@@ -33,7 +33,7 @@ import CoreData
The `CSInMemoryStore` serves as the Objective-C bridging type for `InMemoryStore`. The `CSInMemoryStore` serves as the Objective-C bridging type for `InMemoryStore`.
*/ */
@objc @objc
public final class CSInMemoryStore: NSObject, CSStorageInterface, CoreStoreBridge { public final class CSInMemoryStore: NSObject, CSStorageInterface, CoreStoreObjectiveCType {
/** /**
Initializes a `CSInMemoryStore` for the specified configuration Initializes a `CSInMemoryStore` for the specified configuration
@@ -70,7 +70,7 @@ public final class CSInMemoryStore: NSObject, CSStorageInterface, CoreStoreBridg
@objc @objc
public var configuration: String? { public var configuration: String? {
return self.swift.configuration return self.bridgeToSwift.configuration
} }
/** /**
@@ -79,7 +79,7 @@ public final class CSInMemoryStore: NSObject, CSStorageInterface, CoreStoreBridg
@objc @objc
public var storeOptions: [String: AnyObject]? { public var storeOptions: [String: AnyObject]? {
return self.swift.storeOptions return self.bridgeToSwift.storeOptions
} }
@@ -87,7 +87,7 @@ public final class CSInMemoryStore: NSObject, CSStorageInterface, CoreStoreBridg
public override var hash: Int { public override var hash: Int {
return ObjectIdentifier(self.swift).hashValue return ObjectIdentifier(self.bridgeToSwift).hashValue
} }
public override func isEqual(object: AnyObject?) -> Bool { public override func isEqual(object: AnyObject?) -> Bool {
@@ -96,17 +96,17 @@ public final class CSInMemoryStore: NSObject, CSStorageInterface, CoreStoreBridg
return false return false
} }
return self.swift === object.swift return self.bridgeToSwift === object.bridgeToSwift
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: InMemoryStore public let bridgeToSwift: InMemoryStore
public required init(_ swiftObject: InMemoryStore) { public required init(_ swiftValue: InMemoryStore) {
self.swift = swiftObject self.bridgeToSwift = swiftValue
super.init() super.init()
} }
} }
@@ -114,9 +114,9 @@ public final class CSInMemoryStore: NSObject, CSStorageInterface, CoreStoreBridg
// MARK: - InMemoryStore // MARK: - InMemoryStore
extension InMemoryStore: CoreStoreBridgeable { extension InMemoryStore: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSInMemoryStore public typealias ObjectiveCType = CSInMemoryStore
} }

View File

@@ -33,7 +33,7 @@ import CoreData
The `CSInto` serves as the Objective-C bridging type for `Into<T>`. The `CSInto` serves as the Objective-C bridging type for `Into<T>`.
*/ */
@objc @objc
public final class CSInto: NSObject, CoreStoreBridge { public final class CSInto: NSObject, CoreStoreObjectiveCType {
/** /**
Initializes a `CSInto` clause with the specified entity class. Initializes a `CSInto` clause with the specified entity class.
@@ -69,7 +69,7 @@ public final class CSInto: NSObject, CoreStoreBridge {
public override var hash: Int { public override var hash: Int {
return self.swift.hashValue return self.bridgeToSwift.hashValue
} }
public override func isEqual(object: AnyObject?) -> Bool { public override func isEqual(object: AnyObject?) -> Bool {
@@ -78,17 +78,17 @@ public final class CSInto: NSObject, CoreStoreBridge {
return false return false
} }
return self.swift == object.swift return self.bridgeToSwift == object.bridgeToSwift
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: Into<NSManagedObject> public let bridgeToSwift: Into<NSManagedObject>
public required init<T: NSManagedObject>(_ swiftObject: Into<T>) { public required init<T: NSManagedObject>(_ swiftValue: Into<T>) {
self.swift = swiftObject.upcast() self.bridgeToSwift = swiftValue.upcast()
super.init() super.init()
} }
} }
@@ -96,11 +96,11 @@ public final class CSInto: NSObject, CoreStoreBridge {
// MARK: - Into // MARK: - Into
extension Into: CoreStoreBridgeable { extension Into: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal var objc: CSInto { public var bridgeToObjectiveC: CSInto {
return CSInto(self) return CSInto(self)
} }

View File

@@ -34,7 +34,7 @@ import CoreData
*/ */
@available(OSX, unavailable) @available(OSX, unavailable)
@objc @objc
public final class CSListMonitor: NSObject, CoreStoreBridge { public final class CSListMonitor: NSObject, CoreStoreObjectiveCType {
// MARK: Public (Accessors) // MARK: Public (Accessors)
@@ -47,7 +47,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@objc @objc
public subscript(index: Int) -> NSManagedObject { public subscript(index: Int) -> NSManagedObject {
return self.swift[index] return self.bridgeToSwift[index]
} }
/** /**
@@ -59,7 +59,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@objc @objc
public func objectAtSafeIndex(index: Int) -> NSManagedObject? { public func objectAtSafeIndex(index: Int) -> NSManagedObject? {
return self.swift[safeIndex: index] return self.bridgeToSwift[safeIndex: index]
} }
/** /**
@@ -72,7 +72,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@objc @objc
public func objectAtSectionIndex(sectionIndex: Int, itemIndex: Int) -> NSManagedObject { public func objectAtSectionIndex(sectionIndex: Int, itemIndex: Int) -> NSManagedObject {
return self.swift[sectionIndex, itemIndex] return self.bridgeToSwift[sectionIndex, itemIndex]
} }
/** /**
@@ -85,7 +85,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@objc @objc
public func objectAtSafeSectionIndex(sectionIndex: Int, safeItemIndex itemIndex: Int) -> NSManagedObject? { public func objectAtSafeSectionIndex(sectionIndex: Int, safeItemIndex itemIndex: Int) -> NSManagedObject? {
return self.swift[safeSectionIndex: sectionIndex, safeItemIndex: itemIndex] return self.bridgeToSwift[safeSectionIndex: sectionIndex, safeItemIndex: itemIndex]
} }
/** /**
@@ -97,7 +97,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@objc @objc
public func objectAtIndexPath(indexPath: NSIndexPath) -> NSManagedObject { public func objectAtIndexPath(indexPath: NSIndexPath) -> NSManagedObject {
return self.swift[indexPath] return self.bridgeToSwift[indexPath]
} }
/** /**
@@ -109,7 +109,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@objc @objc
public func objectAtSafeIndexPath(indexPath: NSIndexPath) -> NSManagedObject? { public func objectAtSafeIndexPath(indexPath: NSIndexPath) -> NSManagedObject? {
return self.swift[safeIndexPath: indexPath] return self.bridgeToSwift[safeIndexPath: indexPath]
} }
/** /**
@@ -121,7 +121,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func hasObjects() -> Bool { public func hasObjects() -> Bool {
return self.swift.hasObjects() return self.bridgeToSwift.hasObjects()
} }
/** /**
@@ -134,7 +134,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func hasObjectsInSection(section: Int) -> Bool { public func hasObjectsInSection(section: Int) -> Bool {
return self.swift.hasObjectsInSection(section) return self.bridgeToSwift.hasObjectsInSection(section)
} }
/** /**
@@ -146,7 +146,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func objectsInAllSections() -> [NSManagedObject] { public func objectsInAllSections() -> [NSManagedObject] {
return self.swift.objectsInAllSections() return self.bridgeToSwift.objectsInAllSections()
} }
/** /**
@@ -159,7 +159,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func objectsInSection(section: Int) -> [NSManagedObject] { public func objectsInSection(section: Int) -> [NSManagedObject] {
return self.swift.objectsInSection(section) return self.bridgeToSwift.objectsInSection(section)
} }
/** /**
@@ -172,7 +172,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func objectsInSafeSection(safeSectionIndex section: Int) -> [NSManagedObject]? { public func objectsInSafeSection(safeSectionIndex section: Int) -> [NSManagedObject]? {
return self.swift.objectsInSection(safeSectionIndex: section) return self.bridgeToSwift.objectsInSection(safeSectionIndex: section)
} }
/** /**
@@ -184,7 +184,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func numberOfSections() -> Int { public func numberOfSections() -> Int {
return self.swift.numberOfSections() return self.bridgeToSwift.numberOfSections()
} }
/** /**
@@ -196,7 +196,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func numberOfObjects() -> Int { public func numberOfObjects() -> Int {
return self.swift.numberOfObjects() return self.bridgeToSwift.numberOfObjects()
} }
/** /**
@@ -209,7 +209,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func numberOfObjectsInSection(section: Int) -> Int { public func numberOfObjectsInSection(section: Int) -> Int {
return self.swift.numberOfObjectsInSection(section) return self.bridgeToSwift.numberOfObjectsInSection(section)
} }
/** /**
@@ -222,7 +222,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func numberOfObjectsInSafeSection(safeSectionIndex section: Int) -> NSNumber? { public func numberOfObjectsInSafeSection(safeSectionIndex section: Int) -> NSNumber? {
return self.swift.numberOfObjectsInSection(safeSectionIndex: section) return self.bridgeToSwift.numberOfObjectsInSection(safeSectionIndex: section)
} }
/** /**
@@ -235,7 +235,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func sectionInfoAtIndex(section: Int) -> NSFetchedResultsSectionInfo { public func sectionInfoAtIndex(section: Int) -> NSFetchedResultsSectionInfo {
return self.swift.sectionInfoAtIndex(section) return self.bridgeToSwift.sectionInfoAtIndex(section)
} }
/** /**
@@ -248,7 +248,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func sectionInfoAtSafeSectionIndex(safeSectionIndex section: Int) -> NSFetchedResultsSectionInfo? { public func sectionInfoAtSafeSectionIndex(safeSectionIndex section: Int) -> NSFetchedResultsSectionInfo? {
return self.swift.sectionInfoAtIndex(safeSectionIndex: section) return self.bridgeToSwift.sectionInfoAtIndex(safeSectionIndex: section)
} }
/** /**
@@ -260,7 +260,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func sections() -> [NSFetchedResultsSectionInfo] { public func sections() -> [NSFetchedResultsSectionInfo] {
return self.swift.sections() return self.bridgeToSwift.sections()
} }
/** /**
@@ -274,7 +274,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func targetSectionForSectionIndexTitle(title title: String, index: Int) -> Int { public func targetSectionForSectionIndexTitle(title title: String, index: Int) -> Int {
return self.swift.targetSectionForSectionIndex(title: title, index: index) return self.bridgeToSwift.targetSectionForSectionIndex(title: title, index: index)
} }
/** /**
@@ -286,7 +286,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func sectionIndexTitles() -> [String] { public func sectionIndexTitles() -> [String] {
return self.swift.sectionIndexTitles() return self.bridgeToSwift.sectionIndexTitles()
} }
/** /**
@@ -299,7 +299,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func indexOf(object: NSManagedObject) -> NSNumber? { public func indexOf(object: NSManagedObject) -> NSNumber? {
return self.swift.indexOf(object) return self.bridgeToSwift.indexOf(object)
} }
/** /**
@@ -312,7 +312,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@warn_unused_result @warn_unused_result
public func indexPathOf(object: NSManagedObject) -> NSIndexPath? { public func indexPathOf(object: NSManagedObject) -> NSIndexPath? {
return self.swift.indexPathOf(object) return self.bridgeToSwift.indexPathOf(object)
} }
@@ -332,25 +332,25 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@objc @objc
public func addListObserver(observer: CSListObserver) { public func addListObserver(observer: CSListObserver) {
let swift = self.swift let swift = self.bridgeToSwift
swift.unregisterObserver(observer) swift.unregisterObserver(observer)
swift.registerObserver( swift.registerObserver(
observer, observer,
willChange: { (observer, monitor) in willChange: { (observer, monitor) in
observer.listMonitorWillChange?(monitor.objc) observer.listMonitorWillChange?(monitor.bridgeToObjectiveC)
}, },
didChange: { (observer, monitor) in didChange: { (observer, monitor) in
observer.listMonitorDidChange?(monitor.objc) observer.listMonitorDidChange?(monitor.bridgeToObjectiveC)
}, },
willRefetch: { (observer, monitor) in willRefetch: { (observer, monitor) in
observer.listMonitorWillRefetch?(monitor.objc) observer.listMonitorWillRefetch?(monitor.bridgeToObjectiveC)
}, },
didRefetch: { (observer, monitor) in didRefetch: { (observer, monitor) in
observer.listMonitorDidRefetch?(monitor.objc) observer.listMonitorDidRefetch?(monitor.bridgeToObjectiveC)
} }
) )
} }
@@ -368,44 +368,44 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
*/ */
public func addListObjectObserver(observer: CSListObjectObserver) { public func addListObjectObserver(observer: CSListObjectObserver) {
let swift = self.swift let swift = self.bridgeToSwift
swift.unregisterObserver(observer) swift.unregisterObserver(observer)
swift.registerObserver( swift.registerObserver(
observer, observer,
willChange: { (observer, monitor) in willChange: { (observer, monitor) in
observer.listMonitorWillChange?(monitor.objc) observer.listMonitorWillChange?(monitor.bridgeToObjectiveC)
}, },
didChange: { (observer, monitor) in didChange: { (observer, monitor) in
observer.listMonitorDidChange?(monitor.objc) observer.listMonitorDidChange?(monitor.bridgeToObjectiveC)
}, },
willRefetch: { (observer, monitor) in willRefetch: { (observer, monitor) in
observer.listMonitorWillRefetch?(monitor.objc) observer.listMonitorWillRefetch?(monitor.bridgeToObjectiveC)
}, },
didRefetch: { (observer, monitor) in didRefetch: { (observer, monitor) in
observer.listMonitorDidRefetch?(monitor.objc) observer.listMonitorDidRefetch?(monitor.bridgeToObjectiveC)
} }
) )
swift.registerObserver( swift.registerObserver(
observer, observer,
didInsertObject: { (observer, monitor, object, toIndexPath) in didInsertObject: { (observer, monitor, object, toIndexPath) in
observer.listMonitor?(monitor.objc, didInsertObject: object, toIndexPath: toIndexPath) observer.listMonitor?(monitor.bridgeToObjectiveC, didInsertObject: object, toIndexPath: toIndexPath)
}, },
didDeleteObject: { (observer, monitor, object, fromIndexPath) in didDeleteObject: { (observer, monitor, object, fromIndexPath) in
observer.listMonitor?(monitor.objc, didDeleteObject: object, fromIndexPath: fromIndexPath) observer.listMonitor?(monitor.bridgeToObjectiveC, didDeleteObject: object, fromIndexPath: fromIndexPath)
}, },
didUpdateObject: { (observer, monitor, object, atIndexPath) in didUpdateObject: { (observer, monitor, object, atIndexPath) in
observer.listMonitor?(monitor.objc, didUpdateObject: object, atIndexPath: atIndexPath) observer.listMonitor?(monitor.bridgeToObjectiveC, didUpdateObject: object, atIndexPath: atIndexPath)
}, },
didMoveObject: { (observer, monitor, object, fromIndexPath, toIndexPath) in didMoveObject: { (observer, monitor, object, fromIndexPath, toIndexPath) in
observer.listMonitor?(monitor.objc, didMoveObject: object, fromIndexPath: fromIndexPath, toIndexPath: toIndexPath) observer.listMonitor?(monitor.bridgeToObjectiveC, didMoveObject: object, fromIndexPath: fromIndexPath, toIndexPath: toIndexPath)
} }
) )
} }
@@ -424,55 +424,55 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@objc @objc
public func addListSectionObserver(observer: CSListSectionObserver) { public func addListSectionObserver(observer: CSListSectionObserver) {
let swift = self.swift let swift = self.bridgeToSwift
swift.unregisterObserver(observer) swift.unregisterObserver(observer)
swift.registerObserver( swift.registerObserver(
observer, observer,
willChange: { (observer, monitor) in willChange: { (observer, monitor) in
observer.listMonitorWillChange?(monitor.objc) observer.listMonitorWillChange?(monitor.bridgeToObjectiveC)
}, },
didChange: { (observer, monitor) in didChange: { (observer, monitor) in
observer.listMonitorDidChange?(monitor.objc) observer.listMonitorDidChange?(monitor.bridgeToObjectiveC)
}, },
willRefetch: { (observer, monitor) in willRefetch: { (observer, monitor) in
observer.listMonitorWillRefetch?(monitor.objc) observer.listMonitorWillRefetch?(monitor.bridgeToObjectiveC)
}, },
didRefetch: { (observer, monitor) in didRefetch: { (observer, monitor) in
observer.listMonitorDidRefetch?(monitor.objc) observer.listMonitorDidRefetch?(monitor.bridgeToObjectiveC)
} }
) )
swift.registerObserver( swift.registerObserver(
observer, observer,
didInsertObject: { (observer, monitor, object, toIndexPath) in didInsertObject: { (observer, monitor, object, toIndexPath) in
observer.listMonitor?(monitor.objc, didInsertObject: object, toIndexPath: toIndexPath) observer.listMonitor?(monitor.bridgeToObjectiveC, didInsertObject: object, toIndexPath: toIndexPath)
}, },
didDeleteObject: { (observer, monitor, object, fromIndexPath) in didDeleteObject: { (observer, monitor, object, fromIndexPath) in
observer.listMonitor?(monitor.objc, didDeleteObject: object, fromIndexPath: fromIndexPath) observer.listMonitor?(monitor.bridgeToObjectiveC, didDeleteObject: object, fromIndexPath: fromIndexPath)
}, },
didUpdateObject: { (observer, monitor, object, atIndexPath) in didUpdateObject: { (observer, monitor, object, atIndexPath) in
observer.listMonitor?(monitor.objc, didUpdateObject: object, atIndexPath: atIndexPath) observer.listMonitor?(monitor.bridgeToObjectiveC, didUpdateObject: object, atIndexPath: atIndexPath)
}, },
didMoveObject: { (observer, monitor, object, fromIndexPath, toIndexPath) in didMoveObject: { (observer, monitor, object, fromIndexPath, toIndexPath) in
observer.listMonitor?(monitor.objc, didMoveObject: object, fromIndexPath: fromIndexPath, toIndexPath: toIndexPath) observer.listMonitor?(monitor.bridgeToObjectiveC, didMoveObject: object, fromIndexPath: fromIndexPath, toIndexPath: toIndexPath)
} }
) )
swift.registerObserver( swift.registerObserver(
observer, observer,
didInsertSection: { (observer, monitor, sectionInfo, toIndex) in didInsertSection: { (observer, monitor, sectionInfo, toIndex) in
observer.listMonitor?(monitor.objc, didInsertSection: sectionInfo, toSectionIndex: toIndex) observer.listMonitor?(monitor.bridgeToObjectiveC, didInsertSection: sectionInfo, toSectionIndex: toIndex)
}, },
didDeleteSection: { (observer, monitor, sectionInfo, fromIndex) in didDeleteSection: { (observer, monitor, sectionInfo, fromIndex) in
observer.listMonitor?(monitor.objc, didDeleteSection: sectionInfo, fromSectionIndex: fromIndex) observer.listMonitor?(monitor.bridgeToObjectiveC, didDeleteSection: sectionInfo, fromSectionIndex: fromIndex)
} }
) )
} }
@@ -487,7 +487,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@objc @objc
public func removeObserver(observer: CSListObserver) { public func removeObserver(observer: CSListObserver) {
self.swift.unregisterObserver(observer) self.bridgeToSwift.unregisterObserver(observer)
} }
@@ -499,7 +499,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
@objc @objc
public var isPendingRefetch: Bool { public var isPendingRefetch: Bool {
return self.swift.isPendingRefetch return self.bridgeToSwift.isPendingRefetch
} }
/** /**
@@ -511,7 +511,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
*/ */
public func refetch(fetchClauses: [CSFetchClause]) { public func refetch(fetchClauses: [CSFetchClause]) {
self.swift.refetch { (fetchRequest) in self.bridgeToSwift.refetch { (fetchRequest) in
fetchClauses.forEach { $0.applyToFetchRequest(fetchRequest) } fetchClauses.forEach { $0.applyToFetchRequest(fetchRequest) }
} }
@@ -522,7 +522,7 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
public override var hash: Int { public override var hash: Int {
return self.swift.hashValue return self.bridgeToSwift.hashValue
} }
public override func isEqual(object: AnyObject?) -> Bool { public override func isEqual(object: AnyObject?) -> Bool {
@@ -531,17 +531,18 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
return false return false
} }
return self.swift == object.swift return self.bridgeToSwift == object.bridgeToSwift
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: ListMonitor<NSManagedObject> public let bridgeToSwift: ListMonitor<NSManagedObject>
public required init<T: NSManagedObject>(_ swiftObject: ListMonitor<T>) { @nonobjc
public required init<T: NSManagedObject>(_ swiftValue: ListMonitor<T>) {
self.swift = swiftObject.upcast() self.bridgeToSwift = swiftValue.upcast()
super.init() super.init()
} }
} }
@@ -549,11 +550,11 @@ public final class CSListMonitor: NSObject, CoreStoreBridge {
// MARK: - ListMonitor // MARK: - ListMonitor
extension ListMonitor: CoreStoreBridgeable { extension ListMonitor: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal var objc: CSListMonitor { public var bridgeToObjectiveC: CSListMonitor {
return CSListMonitor(self) return CSListMonitor(self)
} }

View File

@@ -56,7 +56,7 @@ public final class CSSortKey: NSSortDescriptor {
The `CSOrderBy` serves as the Objective-C bridging type for `OrderBy`. The `CSOrderBy` serves as the Objective-C bridging type for `OrderBy`.
*/ */
@objc @objc
public final class CSOrderBy: NSObject, CSFetchClause, CSQueryClause, CSDeleteClause, CoreStoreBridge { public final class CSOrderBy: NSObject, CSFetchClause, CSQueryClause, CSDeleteClause, CoreStoreObjectiveCType {
/** /**
Initializes a `CSOrderBy` clause with a list of sort descriptors Initializes a `CSOrderBy` clause with a list of sort descriptors
@@ -87,7 +87,7 @@ public final class CSOrderBy: NSObject, CSFetchClause, CSQueryClause, CSDeleteCl
public override var hash: Int { public override var hash: Int {
return self.swift.hashValue return self.bridgeToSwift.hashValue
} }
public override func isEqual(object: AnyObject?) -> Bool { public override func isEqual(object: AnyObject?) -> Bool {
@@ -96,7 +96,7 @@ public final class CSOrderBy: NSObject, CSFetchClause, CSQueryClause, CSDeleteCl
return false return false
} }
return self.swift == object.swift return self.bridgeToSwift == object.bridgeToSwift
} }
@@ -105,17 +105,17 @@ public final class CSOrderBy: NSObject, CSFetchClause, CSQueryClause, CSDeleteCl
@objc @objc
public func applyToFetchRequest(fetchRequest: NSFetchRequest) { public func applyToFetchRequest(fetchRequest: NSFetchRequest) {
self.swift.applyToFetchRequest(fetchRequest) self.bridgeToSwift.applyToFetchRequest(fetchRequest)
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: OrderBy public let bridgeToSwift: OrderBy
internal init(_ swiftObject: OrderBy) { public init(_ swiftValue: OrderBy) {
self.swift = swiftObject self.bridgeToSwift = swiftValue
super.init() super.init()
} }
} }
@@ -123,9 +123,9 @@ public final class CSOrderBy: NSObject, CSFetchClause, CSQueryClause, CSDeleteCl
// MARK: - OrderBy // MARK: - OrderBy
extension OrderBy: CoreStoreBridgeable { extension OrderBy: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSOrderBy public typealias ObjectiveCType = CSOrderBy
} }

View File

@@ -33,7 +33,7 @@ import CoreData
The `CSSQLiteStore` serves as the Objective-C bridging type for `SQLiteStore`. The `CSSQLiteStore` serves as the Objective-C bridging type for `SQLiteStore`.
*/ */
@objc @objc
public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreBridge { public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreObjectiveCType {
/** /**
Initializes an SQLite store interface from the given SQLite file URL. When this instance is passed to the `CSDataStack`'s `-addStorage*:` methods, a new SQLite file will be created if it does not exist. Initializes an SQLite store interface from the given SQLite file URL. When this instance is passed to the `CSDataStack`'s `-addStorage*:` methods, a new SQLite file will be created if it does not exist.
@@ -97,7 +97,7 @@ public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreBridge {
@objc @objc
public var fileURL: NSURL { public var fileURL: NSURL {
return self.swift.fileURL return self.bridgeToSwift.fileURL
} }
/** /**
@@ -106,7 +106,7 @@ public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreBridge {
@objc @objc
public var mappingModelBundles: [NSBundle] { public var mappingModelBundles: [NSBundle] {
return self.swift.mappingModelBundles return self.bridgeToSwift.mappingModelBundles
} }
/** /**
@@ -115,7 +115,7 @@ public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreBridge {
@objc @objc
public var localStorageOptions: Int { public var localStorageOptions: Int {
return self.swift.localStorageOptions.rawValue return self.bridgeToSwift.localStorageOptions.rawValue
} }
@@ -132,7 +132,7 @@ public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreBridge {
*/ */
public var configuration: String? { public var configuration: String? {
return self.swift.configuration return self.bridgeToSwift.configuration
} }
/** /**
@@ -144,7 +144,7 @@ public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreBridge {
@objc @objc
public var storeOptions: [String: AnyObject]? { public var storeOptions: [String: AnyObject]? {
return self.swift.storeOptions return self.bridgeToSwift.storeOptions
} }
/** /**
@@ -155,7 +155,7 @@ public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreBridge {
try bridge { try bridge {
try self.swift.eraseStorageAndWait(soureModel: soureModel) try self.bridgeToSwift.eraseStorageAndWait(soureModel: soureModel)
} }
} }
@@ -164,7 +164,7 @@ public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreBridge {
public override var hash: Int { public override var hash: Int {
return ObjectIdentifier(self.swift).hashValue return ObjectIdentifier(self.bridgeToSwift).hashValue
} }
public override func isEqual(object: AnyObject?) -> Bool { public override func isEqual(object: AnyObject?) -> Bool {
@@ -173,17 +173,17 @@ public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreBridge {
return false return false
} }
return self.swift === object.swift return self.bridgeToSwift === object.bridgeToSwift
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: SQLiteStore public let bridgeToSwift: SQLiteStore
public required init(_ swiftObject: SQLiteStore) { public required init(_ swiftValue: SQLiteStore) {
self.swift = swiftObject self.bridgeToSwift = swiftValue
super.init() super.init()
} }
} }
@@ -191,9 +191,9 @@ public final class CSSQLiteStore: NSObject, CSLocalStorage, CoreStoreBridge {
// MARK: - SQLiteStore // MARK: - SQLiteStore
extension SQLiteStore: CoreStoreBridgeable { extension SQLiteStore: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSSQLiteStore public typealias ObjectiveCType = CSSQLiteStore
} }

View File

@@ -33,7 +33,7 @@ import CoreData
The `CSSaveResult` serves as the Objective-C bridging type for `SaveResult`. The `CSSaveResult` serves as the Objective-C bridging type for `SaveResult`.
*/ */
@objc @objc
public final class CSSaveResult: NSObject, CoreStoreBridge { public final class CSSaveResult: NSObject, CoreStoreObjectiveCType {
/** /**
`YES` if the `commit` operation for the transaction succeeded, either because the save succeeded or because there were no changes to save. Returns `NO` to indicate failure. `YES` if the `commit` operation for the transaction succeeded, either because the save succeeded or because there were no changes to save. Returns `NO` to indicate failure.
@@ -41,7 +41,7 @@ public final class CSSaveResult: NSObject, CoreStoreBridge {
@objc @objc
public var isSuccess: Bool { public var isSuccess: Bool {
return self.swift.boolValue return self.bridgeToSwift.boolValue
} }
/** /**
@@ -50,7 +50,7 @@ public final class CSSaveResult: NSObject, CoreStoreBridge {
@objc @objc
public var isFailure: Bool { public var isFailure: Bool {
return !self.swift.boolValue return !self.bridgeToSwift.boolValue
} }
/** /**
@@ -59,7 +59,7 @@ public final class CSSaveResult: NSObject, CoreStoreBridge {
@objc @objc
public var hasChanges: Bool { public var hasChanges: Bool {
guard case .Success(let hasChanges) = self.swift else { guard case .Success(let hasChanges) = self.bridgeToSwift else {
return false return false
} }
@@ -72,11 +72,11 @@ public final class CSSaveResult: NSObject, CoreStoreBridge {
@objc @objc
public var error: NSError? { public var error: NSError? {
guard case .Failure(let error) = self.swift else { guard case .Failure(let error) = self.bridgeToSwift else {
return nil return nil
} }
return error.objc return error.bridgeToObjectiveC
} }
/** /**
@@ -90,13 +90,13 @@ public final class CSSaveResult: NSObject, CoreStoreBridge {
@objc @objc
public func handleSuccess(@noescape success: (hasChanges: Bool) -> Void, @noescape failure: (error: NSError) -> Void) { public func handleSuccess(@noescape success: (hasChanges: Bool) -> Void, @noescape failure: (error: NSError) -> Void) {
switch self.swift { switch self.bridgeToSwift {
case .Success(let hasChanges): case .Success(let hasChanges):
success(hasChanges: hasChanges) success(hasChanges: hasChanges)
case .Failure(let error): case .Failure(let error):
failure(error: error.objc) failure(error: error.bridgeToObjectiveC)
} }
} }
@@ -110,7 +110,7 @@ public final class CSSaveResult: NSObject, CoreStoreBridge {
@objc @objc
public func handleSuccess(@noescape success: (hasChanges: Bool) -> Void) { public func handleSuccess(@noescape success: (hasChanges: Bool) -> Void) {
guard case .Success(let hasChanges) = self.swift else { guard case .Success(let hasChanges) = self.bridgeToSwift else {
return return
} }
@@ -127,11 +127,11 @@ public final class CSSaveResult: NSObject, CoreStoreBridge {
@objc @objc
public func handleFailure(@noescape failure: (error: NSError) -> Void) { public func handleFailure(@noescape failure: (error: NSError) -> Void) {
guard case .Failure(let error) = self.swift else { guard case .Failure(let error) = self.bridgeToSwift else {
return return
} }
failure(error: error.objc) failure(error: error.bridgeToObjectiveC)
} }
@@ -139,7 +139,7 @@ public final class CSSaveResult: NSObject, CoreStoreBridge {
public override var hash: Int { public override var hash: Int {
return self.swift.hashValue return self.bridgeToSwift.hashValue
} }
public override func isEqual(object: AnyObject?) -> Bool { public override func isEqual(object: AnyObject?) -> Bool {
@@ -148,17 +148,17 @@ public final class CSSaveResult: NSObject, CoreStoreBridge {
return false return false
} }
return self.swift == object.swift return self.bridgeToSwift == object.bridgeToSwift
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: SaveResult public let bridgeToSwift: SaveResult
public required init(_ swiftObject: SaveResult) { public required init(_ swiftValue: SaveResult) {
self.swift = swiftObject self.bridgeToSwift = swiftValue
super.init() super.init()
} }
} }
@@ -166,9 +166,9 @@ public final class CSSaveResult: NSObject, CoreStoreBridge {
// MARK: - SaveResult // MARK: - SaveResult
extension SaveResult: CoreStoreBridgeable { extension SaveResult: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSSaveResult public typealias ObjectiveCType = CSSaveResult
} }

View File

@@ -34,7 +34,7 @@ import CoreData
*/ */
@available(OSX, unavailable) @available(OSX, unavailable)
@objc @objc
public final class CSSectionBy: NSObject, CoreStoreBridge { public final class CSSectionBy: NSObject, CoreStoreObjectiveCType {
/** /**
Initializes a `CSSectionBy` clause with the key path to use to group `CSListMonitor` objects into sections Initializes a `CSSectionBy` clause with the key path to use to group `CSListMonitor` objects into sections
@@ -62,13 +62,13 @@ public final class CSSectionBy: NSObject, CoreStoreBridge {
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: SectionBy public let bridgeToSwift: SectionBy
internal init(_ swiftObject: SectionBy) { public init(_ swiftValue: SectionBy) {
self.swift = swiftObject self.bridgeToSwift = swiftValue
super.init() super.init()
} }
} }
@@ -76,9 +76,9 @@ public final class CSSectionBy: NSObject, CoreStoreBridge {
// MARK: - SectionBy // MARK: - SectionBy
extension SectionBy: CoreStoreBridgeable { extension SectionBy: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSSectionBy public typealias ObjectiveCType = CSSectionBy
} }

View File

@@ -45,7 +45,7 @@ public final class CSSynchronousDataTransaction: CSBaseDataTransaction {
return bridge { return bridge {
self.swift.commitAndWait() self.bridgeToSwift.commitAndWait()
} }
} }
@@ -60,9 +60,9 @@ public final class CSSynchronousDataTransaction: CSBaseDataTransaction {
return bridge { return bridge {
self.swift.beginSynchronous { (transaction) in self.bridgeToSwift.beginSynchronous { (transaction) in
closure(transaction: transaction.objc) closure(transaction: transaction.bridgeToObjectiveC)
} }
} }
} }
@@ -79,7 +79,7 @@ public final class CSSynchronousDataTransaction: CSBaseDataTransaction {
@objc @objc
public override func createInto(into: CSInto) -> NSManagedObject { public override func createInto(into: CSInto) -> NSManagedObject {
return self.swift.create(into.swift) return self.bridgeToSwift.create(into.bridgeToSwift)
} }
/** /**
@@ -92,7 +92,7 @@ public final class CSSynchronousDataTransaction: CSBaseDataTransaction {
@warn_unused_result @warn_unused_result
public override func editObject(object: NSManagedObject?) -> NSManagedObject? { public override func editObject(object: NSManagedObject?) -> NSManagedObject? {
return self.swift.edit(object) return self.bridgeToSwift.edit(object)
} }
/** /**
@@ -106,7 +106,7 @@ public final class CSSynchronousDataTransaction: CSBaseDataTransaction {
@warn_unused_result @warn_unused_result
public override func editInto(into: CSInto, objectID: NSManagedObjectID) -> NSManagedObject? { public override func editInto(into: CSInto, objectID: NSManagedObjectID) -> NSManagedObject? {
return self.swift.edit(into.swift, objectID) return self.bridgeToSwift.edit(into.bridgeToSwift, objectID)
} }
/** /**
@@ -117,7 +117,7 @@ public final class CSSynchronousDataTransaction: CSBaseDataTransaction {
@objc @objc
public override func deleteObject(object: NSManagedObject?) { public override func deleteObject(object: NSManagedObject?) {
return self.swift.delete(object) return self.bridgeToSwift.delete(object)
} }
/** /**
@@ -127,27 +127,27 @@ public final class CSSynchronousDataTransaction: CSBaseDataTransaction {
*/ */
public override func deleteObjects(objects: [NSManagedObject]) { public override func deleteObjects(objects: [NSManagedObject]) {
self.swift.delete(objects) self.bridgeToSwift.delete(objects)
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal typealias SwiftType = SynchronousDataTransaction internal typealias SwiftType = SynchronousDataTransaction
internal override var swift: SynchronousDataTransaction { public override var bridgeToSwift: SynchronousDataTransaction {
return super.swift as! SynchronousDataTransaction return super.bridgeToSwift as! SynchronousDataTransaction
} }
public required init(_ swiftObject: SynchronousDataTransaction) { public required init(_ swiftValue: SynchronousDataTransaction) {
super.init(swiftObject) super.init(swiftValue)
} }
required public init(_ swiftObject: BaseDataTransaction) { public required init(_ swiftValue: BaseDataTransaction) {
fatalError("init has not been implemented") fatalError("init(_:) requires a BaseDataTransaction instance")
} }
} }
@@ -156,7 +156,7 @@ public final class CSSynchronousDataTransaction: CSBaseDataTransaction {
extension SynchronousDataTransaction { extension SynchronousDataTransaction {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSSynchronousDataTransaction internal typealias ObjectiveCType = CSSynchronousDataTransaction
} }

View File

@@ -33,7 +33,7 @@ import CoreData
The `CSTweak` serves as the Objective-C bridging type for `Tweak`. The `CSTweak` serves as the Objective-C bridging type for `Tweak`.
*/ */
@objc @objc
public final class CSTweak: NSObject, CSFetchClause, CSQueryClause, CSDeleteClause, CoreStoreBridge { public final class CSTweak: NSObject, CSFetchClause, CSQueryClause, CSDeleteClause, CoreStoreObjectiveCType {
/** /**
Initializes a `CSTweak` clause with a closure where the `NSFetchRequest` may be configured. Initializes a `CSTweak` clause with a closure where the `NSFetchRequest` may be configured.
@@ -53,17 +53,17 @@ public final class CSTweak: NSObject, CSFetchClause, CSQueryClause, CSDeleteClau
@objc @objc
public func applyToFetchRequest(fetchRequest: NSFetchRequest) { public func applyToFetchRequest(fetchRequest: NSFetchRequest) {
self.swift.applyToFetchRequest(fetchRequest) self.bridgeToSwift.applyToFetchRequest(fetchRequest)
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: Tweak public let bridgeToSwift: Tweak
internal init(_ swiftObject: Tweak) { public init(_ swiftValue: Tweak) {
self.swift = swiftObject self.bridgeToSwift = swiftValue
super.init() super.init()
} }
} }
@@ -71,9 +71,9 @@ public final class CSTweak: NSObject, CSFetchClause, CSQueryClause, CSDeleteClau
// MARK: - Tweak // MARK: - Tweak
extension Tweak: CoreStoreBridgeable { extension Tweak: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSTweak public typealias ObjectiveCType = CSTweak
} }

View File

@@ -43,9 +43,9 @@ public final class CSUnsafeDataTransaction: CSBaseDataTransaction {
@objc @objc
public func commit(completion: ((result: CSSaveResult) -> Void)?) { public func commit(completion: ((result: CSSaveResult) -> Void)?) {
self.swift.commit { (result) in self.bridgeToSwift.commit { (result) in
completion?(result: result.objc) completion?(result: result.bridgeToObjectiveC)
} }
} }
@@ -59,7 +59,7 @@ public final class CSUnsafeDataTransaction: CSBaseDataTransaction {
return bridge { return bridge {
self.swift.commitAndWait() self.bridgeToSwift.commitAndWait()
} }
} }
@@ -69,7 +69,7 @@ public final class CSUnsafeDataTransaction: CSBaseDataTransaction {
@objc @objc
public func rollback() { public func rollback() {
self.swift.rollback() self.bridgeToSwift.rollback()
} }
/** /**
@@ -78,7 +78,7 @@ public final class CSUnsafeDataTransaction: CSBaseDataTransaction {
@objc @objc
public func undo() { public func undo() {
self.swift.undo() self.bridgeToSwift.undo()
} }
/** /**
@@ -87,7 +87,7 @@ public final class CSUnsafeDataTransaction: CSBaseDataTransaction {
@objc @objc
public func redo() { public func redo() {
self.swift.redo() self.bridgeToSwift.redo()
} }
/** /**
@@ -102,7 +102,7 @@ public final class CSUnsafeDataTransaction: CSBaseDataTransaction {
return bridge { return bridge {
self.swift.beginUnsafe() self.bridgeToSwift.beginUnsafe()
} }
} }
@@ -118,7 +118,7 @@ public final class CSUnsafeDataTransaction: CSBaseDataTransaction {
return bridge { return bridge {
self.swift.beginUnsafe(supportsUndo: supportsUndo) self.bridgeToSwift.beginUnsafe(supportsUndo: supportsUndo)
} }
} }
@@ -132,27 +132,27 @@ public final class CSUnsafeDataTransaction: CSBaseDataTransaction {
@objc @objc
public var internalContext: NSManagedObjectContext { public var internalContext: NSManagedObjectContext {
return self.swift.context return self.bridgeToSwift.context
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal typealias SwiftType = UnsafeDataTransaction internal typealias SwiftType = UnsafeDataTransaction
internal override var swift: UnsafeDataTransaction { public override var bridgeToSwift: UnsafeDataTransaction {
return super.swift as! UnsafeDataTransaction return super.bridgeToSwift as! UnsafeDataTransaction
} }
public required init(_ swiftObject: UnsafeDataTransaction) { public required init(_ swiftValue: UnsafeDataTransaction) {
super.init(swiftObject) super.init(swiftValue)
} }
required public init(_ swiftObject: BaseDataTransaction) { public required init(_ swiftValue: BaseDataTransaction) {
fatalError("init has not been implemented") fatalError("init(_:) requires an UnsafeDataTransaction instance")
} }
} }
@@ -161,7 +161,7 @@ public final class CSUnsafeDataTransaction: CSBaseDataTransaction {
extension UnsafeDataTransaction { extension UnsafeDataTransaction {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSUnsafeDataTransaction internal typealias ObjectiveCType = CSUnsafeDataTransaction
} }

View File

@@ -33,7 +33,7 @@ import CoreData
The `CSWhere` serves as the Objective-C bridging type for `Where`. The `CSWhere` serves as the Objective-C bridging type for `Where`.
*/ */
@objc @objc
public final class CSWhere: NSObject, CSFetchClause, CSQueryClause, CSDeleteClause, CoreStoreBridge { public final class CSWhere: NSObject, CSFetchClause, CSQueryClause, CSDeleteClause, CoreStoreObjectiveCType {
/** /**
Initializes a `CSWhere` clause with an `NSPredicate` Initializes a `CSWhere` clause with an `NSPredicate`
@@ -103,7 +103,7 @@ public final class CSWhere: NSObject, CSFetchClause, CSQueryClause, CSDeleteClau
public override var hash: Int { public override var hash: Int {
return self.swift.hashValue return self.bridgeToSwift.hashValue
} }
public override func isEqual(object: AnyObject?) -> Bool { public override func isEqual(object: AnyObject?) -> Bool {
@@ -112,7 +112,7 @@ public final class CSWhere: NSObject, CSFetchClause, CSQueryClause, CSDeleteClau
return false return false
} }
return self.swift == object.swift return self.bridgeToSwift == object.bridgeToSwift
} }
@@ -121,17 +121,17 @@ public final class CSWhere: NSObject, CSFetchClause, CSQueryClause, CSDeleteClau
@objc @objc
public func applyToFetchRequest(fetchRequest: NSFetchRequest) { public func applyToFetchRequest(fetchRequest: NSFetchRequest) {
self.swift.applyToFetchRequest(fetchRequest) self.bridgeToSwift.applyToFetchRequest(fetchRequest)
} }
// MARK: CoreStoreBridge // MARK: CoreStoreObjectiveCType
internal let swift: Where public let bridgeToSwift: Where
internal init(_ swiftObject: Where) { public init(_ swiftValue: Where) {
self.swift = swiftObject self.bridgeToSwift = swiftValue
super.init() super.init()
} }
} }
@@ -139,9 +139,9 @@ public final class CSWhere: NSObject, CSFetchClause, CSQueryClause, CSDeleteClau
// MARK: - Where // MARK: - Where
extension Where: CoreStoreBridgeable { extension Where: CoreStoreSwiftType {
// MARK: CoreStoreBridgeable // MARK: CoreStoreSwiftType
internal typealias ObjCType = CSWhere public typealias ObjectiveCType = CSWhere
} }

View File

@@ -1,5 +1,5 @@
// //
// CoreStoreBridge.swift // CoreStoreObjectiveCType.swift
// CoreStore // CoreStore
// //
// Copyright © 2016 John Rommel Estropia // Copyright © 2016 John Rommel Estropia
@@ -26,57 +26,57 @@
import Foundation import Foundation
// MARK: - CoreStoreBridge // MARK: - CoreStoreObjectiveCType
internal protocol CoreStoreBridge: class, AnyObject { public protocol CoreStoreObjectiveCType: class, AnyObject {
associatedtype SwiftType associatedtype SwiftType
var swift: SwiftType { get } var bridgeToSwift: SwiftType { get }
init(_ swiftObject: SwiftType) init(_ swiftValue: SwiftType)
} }
// MARK: - CoreStoreBridgeable // MARK: - CoreStoreSwiftType
internal protocol CoreStoreBridgeable { public protocol CoreStoreSwiftType {
associatedtype ObjCType: CoreStoreBridge associatedtype ObjectiveCType: CoreStoreObjectiveCType
var objc: ObjCType { get } var bridgeToObjectiveC: ObjectiveCType { get }
} }
internal extension CoreStoreBridgeable where Self == ObjCType.SwiftType { public extension CoreStoreSwiftType where Self == ObjectiveCType.SwiftType {
var objc: ObjCType { public var bridgeToObjectiveC: ObjectiveCType {
return ObjCType(self) return ObjectiveCType(self)
} }
} }
// MARK: - Internal // MARK: - Internal
internal func bridge<T: CoreStoreBridgeable where T == T.ObjCType.SwiftType>(@noescape closure: () -> T) -> T.ObjCType { internal func bridge<T: CoreStoreSwiftType where T == T.ObjectiveCType.SwiftType>(@noescape closure: () -> T) -> T.ObjectiveCType {
return closure().objc return closure().bridgeToObjectiveC
} }
internal func bridge<T: CoreStoreBridgeable where T == T.ObjCType.SwiftType>(@noescape closure: () -> T?) -> T.ObjCType? { internal func bridge<T: CoreStoreSwiftType where T == T.ObjectiveCType.SwiftType>(@noescape closure: () -> T?) -> T.ObjectiveCType? {
return closure()?.objc return closure()?.bridgeToObjectiveC
} }
internal func bridge<T: CoreStoreBridgeable where T == T.ObjCType.SwiftType>(@noescape closure: () throws -> T) throws -> T.ObjCType { internal func bridge<T: CoreStoreSwiftType where T == T.ObjectiveCType.SwiftType>(@noescape closure: () throws -> T) throws -> T.ObjectiveCType {
do { do {
return try closure().objc return try closure().bridgeToObjectiveC
} }
catch { catch {
throw error.objc throw error.bridgeToObjectiveC
} }
} }
@@ -88,7 +88,7 @@ internal func bridge(@noescape closure: () throws -> Void) throws {
} }
catch { catch {
throw error.objc throw error.bridgeToObjectiveC
} }
} }
@@ -102,7 +102,7 @@ internal func bridge<T>(error: NSErrorPointer, @noescape _ closure: () throws ->
} }
catch let swiftError { catch let swiftError {
error.memory = swiftError.objc error.memory = swiftError.bridgeToObjectiveC
return nil return nil
} }
} }

View File

@@ -37,7 +37,7 @@ internal extension NSManagedObjectContext {
internal func fetchOne(from: CSFrom, _ fetchClauses: [CSFetchClause]) -> NSManagedObject? { internal func fetchOne(from: CSFrom, _ fetchClauses: [CSFetchClause]) -> NSManagedObject? {
let fetchRequest = NSFetchRequest() let fetchRequest = NSFetchRequest()
from.swift.applyToFetchRequest(fetchRequest, context: self) from.bridgeToSwift.applyToFetchRequest(fetchRequest, context: self)
fetchRequest.fetchLimit = 1 fetchRequest.fetchLimit = 1
fetchRequest.resultType = .ManagedObjectResultType fetchRequest.resultType = .ManagedObjectResultType
@@ -50,7 +50,7 @@ internal extension NSManagedObjectContext {
internal func fetchAll(from: CSFrom, _ fetchClauses: [CSFetchClause]) -> [NSManagedObject]? { internal func fetchAll(from: CSFrom, _ fetchClauses: [CSFetchClause]) -> [NSManagedObject]? {
let fetchRequest = NSFetchRequest() let fetchRequest = NSFetchRequest()
from.swift.applyToFetchRequest(fetchRequest, context: self) from.bridgeToSwift.applyToFetchRequest(fetchRequest, context: self)
fetchRequest.fetchLimit = 0 fetchRequest.fetchLimit = 0
fetchRequest.resultType = .ManagedObjectResultType fetchRequest.resultType = .ManagedObjectResultType
@@ -63,7 +63,7 @@ internal extension NSManagedObjectContext {
internal func fetchCount(from: CSFrom, _ fetchClauses: [CSFetchClause]) -> Int? { internal func fetchCount(from: CSFrom, _ fetchClauses: [CSFetchClause]) -> Int? {
let fetchRequest = NSFetchRequest() let fetchRequest = NSFetchRequest()
from.swift.applyToFetchRequest(fetchRequest, context: self) from.bridgeToSwift.applyToFetchRequest(fetchRequest, context: self)
fetchClauses.forEach { $0.applyToFetchRequest(fetchRequest) } fetchClauses.forEach { $0.applyToFetchRequest(fetchRequest) }
return self.fetchCount(fetchRequest) return self.fetchCount(fetchRequest)
@@ -73,7 +73,7 @@ internal extension NSManagedObjectContext {
internal func fetchObjectID(from: CSFrom, _ fetchClauses: [CSFetchClause]) -> NSManagedObjectID? { internal func fetchObjectID(from: CSFrom, _ fetchClauses: [CSFetchClause]) -> NSManagedObjectID? {
let fetchRequest = NSFetchRequest() let fetchRequest = NSFetchRequest()
from.swift.applyToFetchRequest(fetchRequest, context: self) from.bridgeToSwift.applyToFetchRequest(fetchRequest, context: self)
fetchRequest.fetchLimit = 1 fetchRequest.fetchLimit = 1
fetchRequest.resultType = .ManagedObjectIDResultType fetchRequest.resultType = .ManagedObjectIDResultType
@@ -86,7 +86,7 @@ internal extension NSManagedObjectContext {
internal func fetchObjectIDs(from: CSFrom, _ fetchClauses: [CSFetchClause]) -> [NSManagedObjectID]? { internal func fetchObjectIDs(from: CSFrom, _ fetchClauses: [CSFetchClause]) -> [NSManagedObjectID]? {
let fetchRequest = NSFetchRequest() let fetchRequest = NSFetchRequest()
from.swift.applyToFetchRequest(fetchRequest, context: self) from.bridgeToSwift.applyToFetchRequest(fetchRequest, context: self)
fetchRequest.fetchLimit = 0 fetchRequest.fetchLimit = 0
fetchRequest.resultType = .ManagedObjectIDResultType fetchRequest.resultType = .ManagedObjectIDResultType
@@ -99,7 +99,7 @@ internal extension NSManagedObjectContext {
internal func deleteAll(from: CSFrom, _ deleteClauses: [CSDeleteClause]) -> Int? { internal func deleteAll(from: CSFrom, _ deleteClauses: [CSDeleteClause]) -> Int? {
let fetchRequest = NSFetchRequest() let fetchRequest = NSFetchRequest()
from.swift.applyToFetchRequest(fetchRequest, context: self) from.bridgeToSwift.applyToFetchRequest(fetchRequest, context: self)
fetchRequest.fetchLimit = 0 fetchRequest.fetchLimit = 0
fetchRequest.resultType = .ManagedObjectResultType fetchRequest.resultType = .ManagedObjectResultType