mirror of
https://github.com/JohnEstropia/CoreStore.git
synced 2026-03-23 09:51:30 +01:00
demo app
This commit is contained in:
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1 +1,3 @@
|
|||||||
HardcoreData.xcodeproj/xcuserdata
|
HardcoreData.xcodeproj/xcuserdata
|
||||||
|
HardcoreDataDemo/HardcoreDataDemo.xcodeproj/xcuserdata
|
||||||
|
HardcoreDataDemo/HardcoreDataDemo.xcodeproj/project.xcworkspace/xcuserdata
|
||||||
|
|||||||
@@ -45,7 +45,7 @@
|
|||||||
B5D5E0CF1A4D6AAB006468AF /* TestEntity2.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5D5E0CE1A4D6AAB006468AF /* TestEntity2.swift */; };
|
B5D5E0CF1A4D6AAB006468AF /* TestEntity2.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5D5E0CE1A4D6AAB006468AF /* TestEntity2.swift */; };
|
||||||
B5D8080E1A3471A500A44484 /* GCDKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = B5D808021A34715700A44484 /* GCDKit.framework */; };
|
B5D8080E1A3471A500A44484 /* GCDKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = B5D808021A34715700A44484 /* GCDKit.framework */; };
|
||||||
B5D808161A34947300A44484 /* NotificationObserver.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5D808151A34947300A44484 /* NotificationObserver.swift */; };
|
B5D808161A34947300A44484 /* NotificationObserver.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5D808151A34947300A44484 /* NotificationObserver.swift */; };
|
||||||
B5D8081A1A3495BD00A44484 /* NSObject+HardcoreData.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5D808191A3495BD00A44484 /* NSObject+HardcoreData.swift */; };
|
B5D8081A1A3495BD00A44484 /* AssociatedObjects.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5D808191A3495BD00A44484 /* AssociatedObjects.swift */; };
|
||||||
B5E126551A7DCE1400AD8B39 /* Where.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5E126541A7DCE1400AD8B39 /* Where.swift */; };
|
B5E126551A7DCE1400AD8B39 /* Where.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5E126541A7DCE1400AD8B39 /* Where.swift */; };
|
||||||
B5E126571A7DCE5900AD8B39 /* SortedBy.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5E126561A7DCE5900AD8B39 /* SortedBy.swift */; };
|
B5E126571A7DCE5900AD8B39 /* SortedBy.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5E126561A7DCE5900AD8B39 /* SortedBy.swift */; };
|
||||||
B5E209E01A0726460089C9D4 /* NSManagedObject+Transaction.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5E209DF1A0726460089C9D4 /* NSManagedObject+Transaction.swift */; };
|
B5E209E01A0726460089C9D4 /* NSManagedObject+Transaction.swift in Sources */ = {isa = PBXBuildFile; fileRef = B5E209DF1A0726460089C9D4 /* NSManagedObject+Transaction.swift */; };
|
||||||
@@ -124,7 +124,7 @@
|
|||||||
B5D5E0CE1A4D6AAB006468AF /* TestEntity2.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TestEntity2.swift; sourceTree = "<group>"; };
|
B5D5E0CE1A4D6AAB006468AF /* TestEntity2.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TestEntity2.swift; sourceTree = "<group>"; };
|
||||||
B5D806C51A34715700A44484 /* GCDKit.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; path = GCDKit.xcodeproj; sourceTree = "<group>"; };
|
B5D806C51A34715700A44484 /* GCDKit.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; path = GCDKit.xcodeproj; sourceTree = "<group>"; };
|
||||||
B5D808151A34947300A44484 /* NotificationObserver.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; lineEnding = 0; path = NotificationObserver.swift; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.swift; };
|
B5D808151A34947300A44484 /* NotificationObserver.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; lineEnding = 0; path = NotificationObserver.swift; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.swift; };
|
||||||
B5D808191A3495BD00A44484 /* NSObject+HardcoreData.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = "NSObject+HardcoreData.swift"; sourceTree = "<group>"; };
|
B5D808191A3495BD00A44484 /* AssociatedObjects.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AssociatedObjects.swift; sourceTree = "<group>"; };
|
||||||
B5E126541A7DCE1400AD8B39 /* Where.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Where.swift; sourceTree = "<group>"; };
|
B5E126541A7DCE1400AD8B39 /* Where.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Where.swift; sourceTree = "<group>"; };
|
||||||
B5E126561A7DCE5900AD8B39 /* SortedBy.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = SortedBy.swift; sourceTree = "<group>"; };
|
B5E126561A7DCE5900AD8B39 /* SortedBy.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = SortedBy.swift; sourceTree = "<group>"; };
|
||||||
B5E209DF1A0726460089C9D4 /* NSManagedObject+Transaction.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = "NSManagedObject+Transaction.swift"; sourceTree = "<group>"; };
|
B5E209DF1A0726460089C9D4 /* NSManagedObject+Transaction.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = "NSManagedObject+Transaction.swift"; sourceTree = "<group>"; };
|
||||||
@@ -349,7 +349,7 @@
|
|||||||
children = (
|
children = (
|
||||||
B5D808151A34947300A44484 /* NotificationObserver.swift */,
|
B5D808151A34947300A44484 /* NotificationObserver.swift */,
|
||||||
B595CAC71A9A161B009A397F /* WeakObject.swift */,
|
B595CAC71A9A161B009A397F /* WeakObject.swift */,
|
||||||
B5D808191A3495BD00A44484 /* NSObject+HardcoreData.swift */,
|
B5D808191A3495BD00A44484 /* AssociatedObjects.swift */,
|
||||||
B5CFF23D19FD1D1C00D6DFC4 /* NSManagedObjectContext+HardcoreData.swift */,
|
B5CFF23D19FD1D1C00D6DFC4 /* NSManagedObjectContext+HardcoreData.swift */,
|
||||||
);
|
);
|
||||||
name = Internal;
|
name = Internal;
|
||||||
@@ -524,7 +524,7 @@
|
|||||||
B5F409EF1A8B243D00A228EA /* BaseDataTransaction+Querying.swift in Sources */,
|
B5F409EF1A8B243D00A228EA /* BaseDataTransaction+Querying.swift in Sources */,
|
||||||
2F291E2719C6D3CF007AF63F /* HardcoreData.swift in Sources */,
|
2F291E2719C6D3CF007AF63F /* HardcoreData.swift in Sources */,
|
||||||
B5F409E91A8B11CE00A228EA /* HardcoreDataLogger.swift in Sources */,
|
B5F409E91A8B11CE00A228EA /* HardcoreDataLogger.swift in Sources */,
|
||||||
B5D8081A1A3495BD00A44484 /* NSObject+HardcoreData.swift in Sources */,
|
B5D8081A1A3495BD00A44484 /* AssociatedObjects.swift in Sources */,
|
||||||
B595CAC41A9A11C1009A397F /* NSManagedObjectContext+Setup.swift in Sources */,
|
B595CAC41A9A11C1009A397F /* NSManagedObjectContext+Setup.swift in Sources */,
|
||||||
B5D19BFF1AA14351001D1A99 /* SynchronousDataTransaction.swift in Sources */,
|
B5D19BFF1AA14351001D1A99 /* SynchronousDataTransaction.swift in Sources */,
|
||||||
B5D10DC21AB4590F004B4EEA /* Select.swift in Sources */,
|
B5D10DC21AB4590F004B4EEA /* Select.swift in Sources */,
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
<key>IDESourceControlProjectIdentifier</key>
|
<key>IDESourceControlProjectIdentifier</key>
|
||||||
<string>FE56D6CC-DFA6-4581-B49D-F2486374A545</string>
|
<string>FE56D6CC-DFA6-4581-B49D-F2486374A545</string>
|
||||||
<key>IDESourceControlProjectName</key>
|
<key>IDESourceControlProjectName</key>
|
||||||
<string>HardcoreData</string>
|
<string>project</string>
|
||||||
<key>IDESourceControlProjectOriginsDictionary</key>
|
<key>IDESourceControlProjectOriginsDictionary</key>
|
||||||
<dict>
|
<dict>
|
||||||
<key>4B60F1BCB491FF717C56441AE7783C74F417BE48</key>
|
<key>4B60F1BCB491FF717C56441AE7783C74F417BE48</key>
|
||||||
@@ -16,7 +16,7 @@
|
|||||||
<string>github.com:JohnEstropia/GCDKit.git</string>
|
<string>github.com:JohnEstropia/GCDKit.git</string>
|
||||||
</dict>
|
</dict>
|
||||||
<key>IDESourceControlProjectPath</key>
|
<key>IDESourceControlProjectPath</key>
|
||||||
<string>HardcoreData.xcodeproj</string>
|
<string>HardcoreData.xcodeproj/project.xcworkspace</string>
|
||||||
<key>IDESourceControlProjectRelativeInstallPathDictionary</key>
|
<key>IDESourceControlProjectRelativeInstallPathDictionary</key>
|
||||||
<dict>
|
<dict>
|
||||||
<key>4B60F1BCB491FF717C56441AE7783C74F417BE48</key>
|
<key>4B60F1BCB491FF717C56441AE7783C74F417BE48</key>
|
||||||
|
|||||||
68
HardcoreData/AssociatedObjects.swift
Normal file
68
HardcoreData/AssociatedObjects.swift
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
//
|
||||||
|
// NSObject+HardcoreData.swift
|
||||||
|
// HardcoreData
|
||||||
|
//
|
||||||
|
// Copyright (c) 2014 John Rommel Estropia
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
// of this software and associated documentation files (the "Software"), to deal
|
||||||
|
// in the Software without restriction, including without limitation the rights
|
||||||
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
// copies of the Software, and to permit persons to whom the Software is
|
||||||
|
// furnished to do so, subject to the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
|
// copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
// SOFTWARE.
|
||||||
|
//
|
||||||
|
|
||||||
|
import Foundation
|
||||||
|
|
||||||
|
internal func getAssociatedObjectForKey<T: AnyObject>(key: UnsafePointer<Void>, inObject object: AnyObject) -> T? {
|
||||||
|
|
||||||
|
switch objc_getAssociatedObject(object, key) {
|
||||||
|
|
||||||
|
case let associatedObject as T:
|
||||||
|
return associatedObject
|
||||||
|
|
||||||
|
case let associatedObject as WeakObject:
|
||||||
|
return associatedObject.object as? T
|
||||||
|
|
||||||
|
default:
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
internal func setAssociatedRetainedObject<T: AnyObject>(associatedObject: T?, forKey key: UnsafePointer<Void>, inObject object: AnyObject) {
|
||||||
|
|
||||||
|
objc_setAssociatedObject(object, key, associatedObject, UInt(OBJC_ASSOCIATION_RETAIN_NONATOMIC))
|
||||||
|
}
|
||||||
|
|
||||||
|
internal func setAssociatedCopiedObject<T: AnyObject>(associatedObject: T?, forKey key: UnsafePointer<Void>, inObject object: AnyObject) {
|
||||||
|
|
||||||
|
objc_setAssociatedObject(object, key, associatedObject, UInt(OBJC_ASSOCIATION_COPY_NONATOMIC))
|
||||||
|
}
|
||||||
|
|
||||||
|
internal func setAssociatedAssignedObject<T: AnyObject>(associatedObject: T?, forKey key: UnsafePointer<Void>, inObject object: AnyObject) {
|
||||||
|
|
||||||
|
objc_setAssociatedObject(object, key, associatedObject, UInt(OBJC_ASSOCIATION_ASSIGN))
|
||||||
|
}
|
||||||
|
|
||||||
|
internal func setAssociatedWeakObject<T: AnyObject>(associatedObject: T?, forKey key: UnsafePointer<Void>, inObject object: AnyObject) {
|
||||||
|
|
||||||
|
if let associatedObject = associatedObject {
|
||||||
|
|
||||||
|
objc_setAssociatedObject(object, key, WeakObject(associatedObject), UInt(OBJC_ASSOCIATION_RETAIN_NONATOMIC))
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
|
||||||
|
objc_setAssociatedObject(object, key, nil, UInt(OBJC_ASSOCIATION_RETAIN_NONATOMIC))
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -41,8 +41,8 @@ public final class AsynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public func commit(completion: (result: SaveResult) -> Void) {
|
public func commit(completion: (result: SaveResult) -> Void) {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to commit a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to commit a \(typeName(self)) outside its designated queue.")
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to commit a <\(self.dynamicType)> more than once.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to commit a \(typeName(self)) more than once.")
|
||||||
|
|
||||||
self.isCommitted = true
|
self.isCommitted = true
|
||||||
let semaphore = GCDSemaphore(0)
|
let semaphore = GCDSemaphore(0)
|
||||||
@@ -62,8 +62,8 @@ public final class AsynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public func commitAndWait() {
|
public func commitAndWait() {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to commit a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to commit a \(typeName(self)) outside its designated queue.")
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to commit a <\(self.dynamicType)> more than once.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to commit a \(typeName(self)) more than once.")
|
||||||
|
|
||||||
self.isCommitted = true
|
self.isCommitted = true
|
||||||
self.result = self.context.saveSynchronously()
|
self.result = self.context.saveSynchronously()
|
||||||
@@ -77,8 +77,8 @@ public final class AsynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public func beginSynchronous(closure: (transaction: SynchronousDataTransaction) -> Void) -> SaveResult? {
|
public func beginSynchronous(closure: (transaction: SynchronousDataTransaction) -> Void) -> SaveResult? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to begin a child transaction from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to begin a child transaction from a \(typeName(self)) outside its designated queue.")
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to begin a child transaction from an already committed <\(self.dynamicType)>.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to begin a child transaction from an already committed \(typeName(self)).")
|
||||||
|
|
||||||
return SynchronousDataTransaction(
|
return SynchronousDataTransaction(
|
||||||
mainContext: self.context,
|
mainContext: self.context,
|
||||||
@@ -97,7 +97,7 @@ public final class AsynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public override func create<T: NSManagedObject>(entity: T.Type) -> T {
|
public override func create<T: NSManagedObject>(entity: T.Type) -> T {
|
||||||
|
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to create an entity of type <\(entity)> from an already committed <\(self.dynamicType)>.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to create an entity of type <\(entity)> from an already committed \(typeName(self)).")
|
||||||
|
|
||||||
return super.create(entity)
|
return super.create(entity)
|
||||||
}
|
}
|
||||||
@@ -110,7 +110,7 @@ public final class AsynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public override func fetch<T: NSManagedObject>(object: T) -> T? {
|
public override func fetch<T: NSManagedObject>(object: T) -> T? {
|
||||||
|
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to update an entity of type <\(object.dynamicType)> from an already committed <\(self.dynamicType)>.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to update an entity of type \(typeName(object)) from an already committed \(typeName(self)).")
|
||||||
|
|
||||||
return super.fetch(object)
|
return super.fetch(object)
|
||||||
}
|
}
|
||||||
@@ -122,7 +122,7 @@ public final class AsynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public override func delete(object: NSManagedObject) {
|
public override func delete(object: NSManagedObject) {
|
||||||
|
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to delete an entity of type <\(object.dynamicType)> from an already committed <\(self.dynamicType)>.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to delete an entity of type \(typeName(object)) from an already committed \(typeName(self)).")
|
||||||
|
|
||||||
super.delete(object)
|
super.delete(object)
|
||||||
}
|
}
|
||||||
@@ -132,7 +132,7 @@ public final class AsynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public override func rollback() {
|
public override func rollback() {
|
||||||
|
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to rollback an already committed <\(self.dynamicType)>.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to rollback an already committed \(typeName(self)).")
|
||||||
|
|
||||||
super.rollback()
|
super.rollback()
|
||||||
}
|
}
|
||||||
@@ -154,7 +154,7 @@ public final class AsynchronousDataTransaction: BaseDataTransaction {
|
|||||||
self.closure(transaction: self)
|
self.closure(transaction: self)
|
||||||
if !self.isCommitted && self.hasChanges {
|
if !self.isCommitted && self.hasChanges {
|
||||||
|
|
||||||
HardcoreData.log(.Warning, message: "The closure for the <\(self.dynamicType)> completed without being committed. All changes made within the transaction were discarded.")
|
HardcoreData.log(.Warning, message: "The closure for the \(typeName(self)) completed without being committed. All changes made within the transaction were discarded.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -166,7 +166,7 @@ public final class AsynchronousDataTransaction: BaseDataTransaction {
|
|||||||
self.closure(transaction: self)
|
self.closure(transaction: self)
|
||||||
if !self.isCommitted && self.hasChanges {
|
if !self.isCommitted && self.hasChanges {
|
||||||
|
|
||||||
HardcoreData.log(.Warning, message: "The closure for the <\(self.dynamicType)> completed without being committed. All changes made within the transaction were discarded.")
|
HardcoreData.log(.Warning, message: "The closure for the \(typeName(self)) completed without being committed. All changes made within the transaction were discarded.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return self.result
|
return self.result
|
||||||
|
|||||||
@@ -35,112 +35,112 @@ public extension BaseDataTransaction {
|
|||||||
|
|
||||||
public func fetchOne<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> T? {
|
public func fetchOne<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> T? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.fetchOne(from, queryClauses)
|
return self.context.fetchOne(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchOne<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> T? {
|
public func fetchOne<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> T? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.fetchOne(from, queryClauses)
|
return self.context.fetchOne(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchAll<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> [T]? {
|
public func fetchAll<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> [T]? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.fetchAll(from, queryClauses)
|
return self.context.fetchAll(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchAll<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> [T]? {
|
public func fetchAll<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> [T]? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.fetchAll(from, queryClauses)
|
return self.context.fetchAll(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchCount<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> Int? {
|
public func fetchCount<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> Int? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.fetchCount(from, queryClauses)
|
return self.context.fetchCount(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchCount<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> Int? {
|
public func fetchCount<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> Int? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.fetchCount(from, queryClauses)
|
return self.context.fetchCount(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> NSManagedObjectID? {
|
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> NSManagedObjectID? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.fetchObjectID(from, queryClauses)
|
return self.context.fetchObjectID(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> NSManagedObjectID? {
|
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> NSManagedObjectID? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.fetchObjectID(from, queryClauses)
|
return self.context.fetchObjectID(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> [NSManagedObjectID]? {
|
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> [NSManagedObjectID]? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.fetchObjectIDs(from, queryClauses)
|
return self.context.fetchObjectIDs(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> [NSManagedObjectID]? {
|
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> [NSManagedObjectID]? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.fetchObjectIDs(from, queryClauses)
|
return self.context.fetchObjectIDs(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func deleteAll<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> Int? {
|
public func deleteAll<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> Int? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to delete from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to delete from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.deleteAll(from, queryClauses)
|
return self.context.deleteAll(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func deleteAll<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> Int? {
|
public func deleteAll<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> Int? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to delete from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to delete from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.deleteAll(from, queryClauses)
|
return self.context.deleteAll(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: FetchClause...) -> U? {
|
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: FetchClause...) -> U? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to query from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to query from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.queryValue(from, selectClause, queryClauses)
|
return self.context.queryValue(from, selectClause, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: [FetchClause]) -> U? {
|
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: [FetchClause]) -> U? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to query from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to query from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.queryValue(from, selectClause, queryClauses)
|
return self.context.queryValue(from, selectClause, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: QueryClause...) -> [[NSString: AnyObject]]? {
|
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: QueryClause...) -> [[NSString: AnyObject]]? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to query from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to query from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.queryAttributes(from, selectClause, queryClauses)
|
return self.context.queryAttributes(from, selectClause, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: [QueryClause]) -> [[NSString: AnyObject]]? {
|
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: [QueryClause]) -> [[NSString: AnyObject]]? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to query from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to query from a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
return self.context.queryAttributes(from, selectClause, queryClauses)
|
return self.context.queryAttributes(from, selectClause, queryClauses)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -63,7 +63,7 @@ public /*abstract*/ class BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public func fetch<T: NSManagedObject>(object: T) -> T? {
|
public func fetch<T: NSManagedObject>(object: T) -> T? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to update an entity of type <\(object.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to update an entity of type \(typeName(object)) outside its designated queue.")
|
||||||
|
|
||||||
return object.inContext(self.context)
|
return object.inContext(self.context)
|
||||||
}
|
}
|
||||||
@@ -75,7 +75,7 @@ public /*abstract*/ class BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public func delete(object: NSManagedObject) {
|
public func delete(object: NSManagedObject) {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to delete an entity of type <\(object.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to delete an entity of type \(typeName(object)) outside its designated queue.")
|
||||||
|
|
||||||
object.deleteFromContext()
|
object.deleteFromContext()
|
||||||
}
|
}
|
||||||
@@ -87,7 +87,7 @@ public /*abstract*/ class BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public func rollback() {
|
public func rollback() {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to rollback a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to rollback a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
self.context.reset()
|
self.context.reset()
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -34,14 +34,14 @@ public extension DataStack {
|
|||||||
|
|
||||||
// MARK: Public
|
// MARK: Public
|
||||||
|
|
||||||
public func observeObjectList<T: NSManagedObject>(entity: T.Type, _ queryClauses: FetchClause...) -> ManagedObjectListController<T> {
|
public func observeObjectList<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> ManagedObjectListController<T> {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
// TODO: sectionNameKeyPath and cacheResults
|
// TODO: sectionNameKeyPath and cacheResults
|
||||||
return ManagedObjectListController(
|
return ManagedObjectListController(
|
||||||
dataStack: self,
|
dataStack: self,
|
||||||
entity: entity,
|
entity: T.self,
|
||||||
sectionNameKeyPath: nil,
|
sectionNameKeyPath: nil,
|
||||||
cacheResults: false,
|
cacheResults: false,
|
||||||
queryClauses: queryClauses
|
queryClauses: queryClauses
|
||||||
|
|||||||
@@ -36,112 +36,112 @@ public extension DataStack {
|
|||||||
|
|
||||||
public func fetchOne<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> T? {
|
public func fetchOne<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> T? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.fetchOne(from, queryClauses)
|
return self.mainContext.fetchOne(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchOne<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> T? {
|
public func fetchOne<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> T? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.fetchOne(from, queryClauses)
|
return self.mainContext.fetchOne(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchAll<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> [T]? {
|
public func fetchAll<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> [T]? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.fetchAll(from, queryClauses)
|
return self.mainContext.fetchAll(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchAll<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> [T]? {
|
public func fetchAll<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> [T]? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.fetchAll(from, queryClauses)
|
return self.mainContext.fetchAll(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchCount<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> Int? {
|
public func fetchCount<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> Int? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.fetchCount(from, queryClauses)
|
return self.mainContext.fetchCount(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchCount<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> Int? {
|
public func fetchCount<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> Int? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.fetchCount(from, queryClauses)
|
return self.mainContext.fetchCount(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> NSManagedObjectID? {
|
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> NSManagedObjectID? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.fetchObjectID(from, queryClauses)
|
return self.mainContext.fetchObjectID(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> NSManagedObjectID? {
|
public func fetchObjectID<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> NSManagedObjectID? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.fetchObjectID(from, queryClauses)
|
return self.mainContext.fetchObjectID(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> [NSManagedObjectID]? {
|
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> [NSManagedObjectID]? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.fetchObjectIDs(from, queryClauses)
|
return self.mainContext.fetchObjectIDs(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> [NSManagedObjectID]? {
|
public func fetchObjectIDs<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> [NSManagedObjectID]? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to fetch from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.fetchObjectIDs(from, queryClauses)
|
return self.mainContext.fetchObjectIDs(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func deleteAll<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> Int? {
|
public func deleteAll<T: NSManagedObject>(from: From<T>, _ queryClauses: FetchClause...) -> Int? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to delete from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to delete from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.deleteAll(from, queryClauses)
|
return self.mainContext.deleteAll(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func deleteAll<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> Int? {
|
public func deleteAll<T: NSManagedObject>(from: From<T>, _ queryClauses: [FetchClause]) -> Int? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to delete from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to delete from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.deleteAll(from, queryClauses)
|
return self.mainContext.deleteAll(from, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: FetchClause...) -> U? {
|
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: FetchClause...) -> U? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to query from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to query from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.queryValue(from, selectClause, queryClauses)
|
return self.mainContext.queryValue(from, selectClause, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: [FetchClause]) -> U? {
|
public func queryValue<T: NSManagedObject, U: SelectValueResultType>(from: From<T>, _ selectClause: Select<U>, _ queryClauses: [FetchClause]) -> U? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to query from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to query from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.queryValue(from, selectClause, queryClauses)
|
return self.mainContext.queryValue(from, selectClause, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: QueryClause...) -> [[NSString: AnyObject]]? {
|
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: QueryClause...) -> [[NSString: AnyObject]]? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to query from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to query from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.queryAttributes(from, selectClause, queryClauses)
|
return self.mainContext.queryAttributes(from, selectClause, queryClauses)
|
||||||
}
|
}
|
||||||
|
|
||||||
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: [QueryClause]) -> [[NSString: AnyObject]]? {
|
public func queryAttributes<T: NSManagedObject>(from: From<T>, _ selectClause: Select<NSDictionary>, _ queryClauses: [QueryClause]) -> [[NSString: AnyObject]]? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to query from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to query from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return self.mainContext.queryAttributes(from, selectClause, queryClauses)
|
return self.mainContext.queryAttributes(from, selectClause, queryClauses)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -41,7 +41,7 @@ public extension DataStack {
|
|||||||
*/
|
*/
|
||||||
public func beginAsynchronous(closure: (transaction: AsynchronousDataTransaction) -> Void) {
|
public func beginAsynchronous(closure: (transaction: AsynchronousDataTransaction) -> Void) {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to begin a transaction from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to begin a transaction from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
AsynchronousDataTransaction(
|
AsynchronousDataTransaction(
|
||||||
mainContext: self.rootSavingContext,
|
mainContext: self.rootSavingContext,
|
||||||
@@ -57,7 +57,7 @@ public extension DataStack {
|
|||||||
*/
|
*/
|
||||||
public func beginSynchronous(closure: (transaction: SynchronousDataTransaction) -> Void) -> SaveResult? {
|
public func beginSynchronous(closure: (transaction: SynchronousDataTransaction) -> Void) -> SaveResult? {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to begin a transaction from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to begin a transaction from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return SynchronousDataTransaction(
|
return SynchronousDataTransaction(
|
||||||
mainContext: self.rootSavingContext,
|
mainContext: self.rootSavingContext,
|
||||||
@@ -72,7 +72,7 @@ public extension DataStack {
|
|||||||
*/
|
*/
|
||||||
public func beginDetached() -> DetachedDataTransaction {
|
public func beginDetached() -> DetachedDataTransaction {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to begin a transaction from a <\(self.dynamicType)> outside the main queue.")
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to begin a transaction from a \(typeName(self)) outside the main queue.")
|
||||||
|
|
||||||
return DetachedDataTransaction(
|
return DetachedDataTransaction(
|
||||||
mainContext: self.rootSavingContext,
|
mainContext: self.rootSavingContext,
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ private let applicationSupportDirectory = NSFileManager.defaultManager().URLsFor
|
|||||||
|
|
||||||
private let applicationName = ((NSBundle.mainBundle().objectForInfoDictionaryKey("CFBundleName") as? String) ?? "CoreData")
|
private let applicationName = ((NSBundle.mainBundle().objectForInfoDictionaryKey("CFBundleName") as? String) ?? "CoreData")
|
||||||
|
|
||||||
private let defaultSQLiteStoreURL = applicationSupportDirectory.URLByAppendingPathComponent(applicationName, isDirectory: true).URLByAppendingPathExtension("sqlite")
|
private let defaultSQLiteStoreURL = applicationSupportDirectory.URLByAppendingPathComponent(applicationName, isDirectory: false).URLByAppendingPathExtension("sqlite")
|
||||||
|
|
||||||
|
|
||||||
// MARK: - DataStack
|
// MARK: - DataStack
|
||||||
|
|||||||
@@ -41,7 +41,7 @@ public final class DetachedDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public func commit(completion: (result: SaveResult) -> Void) {
|
public func commit(completion: (result: SaveResult) -> Void) {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to commit a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to commit a \(typeName(self)) outside its designated queue.")
|
||||||
|
|
||||||
self.context.saveAsynchronouslyWithCompletion { (result) -> Void in
|
self.context.saveAsynchronouslyWithCompletion { (result) -> Void in
|
||||||
|
|
||||||
|
|||||||
@@ -56,7 +56,7 @@ public struct GroupBy: QueryClause {
|
|||||||
|
|
||||||
if fetchRequest.propertiesToGroupBy != nil {
|
if fetchRequest.propertiesToGroupBy != nil {
|
||||||
|
|
||||||
HardcoreData.log(.Warning, message: "An existing \"propertiesToGroupBy\" for the <\(NSFetchRequest.self)> was overwritten by <\(self.dynamicType)> query clause.")
|
HardcoreData.log(.Warning, message: "An existing \"propertiesToGroupBy\" for the <\(NSFetchRequest.self)> was overwritten by \(typeName(self)) query clause.")
|
||||||
}
|
}
|
||||||
|
|
||||||
fetchRequest.propertiesToGroupBy = self.keyPaths
|
fetchRequest.propertiesToGroupBy = self.keyPaths
|
||||||
|
|||||||
@@ -46,4 +46,12 @@ public protocol HardcoreDataLogger {
|
|||||||
func handleError(#error: NSError, message: String, fileName: StaticString, lineNumber: Int, functionName: StaticString)
|
func handleError(#error: NSError, message: String, fileName: StaticString, lineNumber: Int, functionName: StaticString)
|
||||||
|
|
||||||
func assert(@autoclosure condition: () -> Bool, message: String, fileName: StaticString, lineNumber: Int, functionName: StaticString)
|
func assert(@autoclosure condition: () -> Bool, message: String, fileName: StaticString, lineNumber: Int, functionName: StaticString)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// MARK: - Utilities
|
||||||
|
|
||||||
|
internal func typeName<T>(value: T) -> String {
|
||||||
|
|
||||||
|
return "<\(_stdlib_getDemangledTypeName(value))>"
|
||||||
|
}
|
||||||
|
|||||||
@@ -28,48 +28,260 @@ import CoreData
|
|||||||
import GCDKit
|
import GCDKit
|
||||||
|
|
||||||
|
|
||||||
|
private let ManagedObjectListControllerWillChangeListNotification = "ManagedObjectListControllerWillChangeListNotification"
|
||||||
|
private let ManagedObjectListControllerDidChangeListNotification = "ManagedObjectListControllerDidChangeListNotification"
|
||||||
|
private let ManagedObjectListControllerDidInsertObjectNotification = "ManagedObjectListControllerDidInsertObjectNotification"
|
||||||
|
private let ManagedObjectListControllerDidDeleteObjectNotification = "ManagedObjectListControllerDidDeleteObjectNotification"
|
||||||
|
private let ManagedObjectListControllerDidUpdateObjectNotification = "ManagedObjectListControllerDidUpdateObjectNotification"
|
||||||
|
private let ManagedObjectListControllerDidMoveObjectNotification = "ManagedObjectListControllerDidMoveObjectNotification"
|
||||||
|
|
||||||
|
private let UserInfoKeyObject = "UserInfoKeyObject"
|
||||||
|
private let UserInfoKeyIndexPath = "UserInfoKeyIndexPath"
|
||||||
|
private let UserInfoKeyNewIndexPath = "UserInfoKeyNewIndexPath"
|
||||||
|
|
||||||
|
private struct NotificationKey {
|
||||||
|
|
||||||
|
static var willChangeList: Void?
|
||||||
|
static var didChangeList: Void?
|
||||||
|
static var didInsertObject: Void?
|
||||||
|
static var didDeleteObject: Void?
|
||||||
|
static var didUpdateObject: Void?
|
||||||
|
static var didMoveObject: Void?
|
||||||
|
}
|
||||||
|
|
||||||
// MARK: - ManagedObjectListController
|
// MARK: - ManagedObjectListController
|
||||||
|
|
||||||
public final class ManagedObjectListController<T: NSManagedObject>: FetchedResultsControllerHandler {
|
public final class ManagedObjectListController<T: NSManagedObject>: FetchedResultsControllerHandler {
|
||||||
|
|
||||||
// MARK: Public
|
// MARK: Public
|
||||||
|
|
||||||
public typealias EntityType = T
|
public subscript(indexPath: NSIndexPath) -> T {
|
||||||
|
|
||||||
public func addObserver<U: ManagedObjectListObserver where U.EntityType == EntityType>(observer: U) {
|
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to add a <\(U.self)> outside the main queue.")
|
return self.fetchedResultsController.objectAtIndexPath(indexPath) as! T
|
||||||
|
|
||||||
self.observers.addObject(observer)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public func removeObserver<U: ManagedObjectListObserver where U.EntityType == EntityType>(observer: U) {
|
public func numberOfSections() -> Int {
|
||||||
|
|
||||||
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to remove a <\(U.self)> outside the main queue.")
|
return self.fetchedResultsController.sections?.count ?? 0
|
||||||
|
|
||||||
self.observers.removeObject(observer)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public func numberOfItemsInSection(section: Int) -> Int {
|
||||||
|
|
||||||
|
return (self.fetchedResultsController.sections?[section] as? NSFetchedResultsSectionInfo)?.numberOfObjects ?? 0
|
||||||
|
}
|
||||||
|
|
||||||
|
public func addObserver<U: ManagedObjectListObserver where U.EntityType == T>(observer: U) {
|
||||||
|
|
||||||
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to add a \(typeName(observer)) outside the main queue.")
|
||||||
|
|
||||||
|
setAssociatedRetainedObject(
|
||||||
|
NotificationObserver(
|
||||||
|
notificationName: ManagedObjectListControllerWillChangeListNotification,
|
||||||
|
object: self,
|
||||||
|
closure: { [weak self, weak observer] (note) -> Void in
|
||||||
|
|
||||||
|
if let strongSelf = self, let strongObserver = observer {
|
||||||
|
|
||||||
|
strongObserver.managedObjectListWillChange(strongSelf)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
),
|
||||||
|
forKey: &NotificationKey.willChangeList,
|
||||||
|
inObject: observer
|
||||||
|
)
|
||||||
|
setAssociatedRetainedObject(
|
||||||
|
NotificationObserver(
|
||||||
|
notificationName: ManagedObjectListControllerDidChangeListNotification,
|
||||||
|
object: self,
|
||||||
|
closure: { [weak self, weak observer] (note) -> Void in
|
||||||
|
|
||||||
|
if let strongSelf = self, let strongObserver = observer {
|
||||||
|
|
||||||
|
strongObserver.managedObjectListDidChange(strongSelf)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
),
|
||||||
|
forKey: &NotificationKey.willChangeList,
|
||||||
|
inObject: observer
|
||||||
|
)
|
||||||
|
setAssociatedRetainedObject(
|
||||||
|
NotificationObserver(
|
||||||
|
notificationName: ManagedObjectListControllerDidInsertObjectNotification,
|
||||||
|
object: self,
|
||||||
|
closure: { [weak self, weak observer] (note) -> Void in
|
||||||
|
|
||||||
|
if let strongSelf = self,
|
||||||
|
let strongObserver = observer,
|
||||||
|
let userInfo = note.userInfo,
|
||||||
|
let object = userInfo[UserInfoKeyObject] as? T,
|
||||||
|
let newIndexPath = userInfo[UserInfoKeyNewIndexPath] as? NSIndexPath {
|
||||||
|
|
||||||
|
strongObserver.managedObjectList(
|
||||||
|
strongSelf,
|
||||||
|
didInsertObject: object,
|
||||||
|
toIndexPath: newIndexPath
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
),
|
||||||
|
forKey: &NotificationKey.didInsertObject,
|
||||||
|
inObject: observer
|
||||||
|
)
|
||||||
|
setAssociatedRetainedObject(
|
||||||
|
NotificationObserver(
|
||||||
|
notificationName: ManagedObjectListControllerDidDeleteObjectNotification,
|
||||||
|
object: self,
|
||||||
|
closure: { [weak self, weak observer] (note) -> Void in
|
||||||
|
|
||||||
|
if let strongSelf = self,
|
||||||
|
let strongObserver = observer,
|
||||||
|
let userInfo = note.userInfo,
|
||||||
|
let object = userInfo[UserInfoKeyObject] as? T,
|
||||||
|
let indexPath = userInfo[UserInfoKeyIndexPath] as? NSIndexPath {
|
||||||
|
|
||||||
|
strongObserver.managedObjectList(
|
||||||
|
strongSelf,
|
||||||
|
didDeleteObject: object,
|
||||||
|
fromIndexPath: indexPath
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
),
|
||||||
|
forKey: &NotificationKey.didDeleteObject,
|
||||||
|
inObject: observer
|
||||||
|
)
|
||||||
|
setAssociatedRetainedObject(
|
||||||
|
NotificationObserver(
|
||||||
|
notificationName: ManagedObjectListControllerDidUpdateObjectNotification,
|
||||||
|
object: self,
|
||||||
|
closure: { [weak self, weak observer] (note) -> Void in
|
||||||
|
|
||||||
|
if let strongSelf = self,
|
||||||
|
let strongObserver = observer,
|
||||||
|
let userInfo = note.userInfo,
|
||||||
|
let object = userInfo[UserInfoKeyObject] as? T,
|
||||||
|
let indexPath = userInfo[UserInfoKeyIndexPath] as? NSIndexPath {
|
||||||
|
|
||||||
|
strongObserver.managedObjectList(
|
||||||
|
strongSelf,
|
||||||
|
didUpdateObject: object,
|
||||||
|
atIndexPath: indexPath
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
),
|
||||||
|
forKey: &NotificationKey.didUpdateObject,
|
||||||
|
inObject: observer
|
||||||
|
)
|
||||||
|
setAssociatedRetainedObject(
|
||||||
|
NotificationObserver(
|
||||||
|
notificationName: ManagedObjectListControllerDidMoveObjectNotification,
|
||||||
|
object: self,
|
||||||
|
closure: { [weak self, weak observer] (note) -> Void in
|
||||||
|
|
||||||
|
if let strongSelf = self,
|
||||||
|
let strongObserver = observer,
|
||||||
|
let userInfo = note.userInfo,
|
||||||
|
let object = userInfo[UserInfoKeyObject] as? T,
|
||||||
|
let indexPath = userInfo[UserInfoKeyIndexPath] as? NSIndexPath ,
|
||||||
|
let newIndexPath = userInfo[UserInfoKeyNewIndexPath] as? NSIndexPath {
|
||||||
|
|
||||||
|
strongObserver.managedObjectList(
|
||||||
|
strongSelf,
|
||||||
|
didMoveObject: object,
|
||||||
|
fromIndexPath: indexPath,
|
||||||
|
toIndexPath: newIndexPath
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
),
|
||||||
|
forKey: &NotificationKey.didMoveObject,
|
||||||
|
inObject: observer
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
public func removeObserver<U: ManagedObjectListObserver where U.EntityType == T>(observer: U) {
|
||||||
|
|
||||||
|
HardcoreData.assert(GCDQueue.Main.isCurrentExecutionContext(), "Attempted to remove a \(typeName(observer)) outside the main queue.")
|
||||||
|
|
||||||
|
setAssociatedRetainedObject(nil as AnyObject?, forKey: &NotificationKey.willChangeList, inObject: observer)
|
||||||
|
setAssociatedRetainedObject(nil as AnyObject?, forKey: &NotificationKey.didChangeList, inObject: observer)
|
||||||
|
setAssociatedRetainedObject(nil as AnyObject?, forKey: &NotificationKey.didInsertObject, inObject: observer)
|
||||||
|
setAssociatedRetainedObject(nil as AnyObject?, forKey: &NotificationKey.didDeleteObject, inObject: observer)
|
||||||
|
setAssociatedRetainedObject(nil as AnyObject?, forKey: &NotificationKey.didUpdateObject, inObject: observer)
|
||||||
|
setAssociatedRetainedObject(nil as AnyObject?, forKey: &NotificationKey.didMoveObject, inObject: observer)
|
||||||
|
}
|
||||||
|
|
||||||
// MARK: FetchedResultsControllerHandler
|
// MARK: FetchedResultsControllerHandler
|
||||||
|
|
||||||
func controller(controller: NSFetchedResultsController, didChangeObject anObject: AnyObject, atIndexPath indexPath: NSIndexPath?, forChangeType type: NSFetchedResultsChangeType, newIndexPath: NSIndexPath?) {
|
private func controller(controller: NSFetchedResultsController, didChangeObject anObject: AnyObject, atIndexPath indexPath: NSIndexPath?, forChangeType type: NSFetchedResultsChangeType, newIndexPath: NSIndexPath?) {
|
||||||
|
|
||||||
|
switch type {
|
||||||
|
|
||||||
|
case .Insert:
|
||||||
|
NSNotificationCenter.defaultCenter().postNotificationName(
|
||||||
|
ManagedObjectListControllerDidInsertObjectNotification,
|
||||||
|
object: self,
|
||||||
|
userInfo: [
|
||||||
|
UserInfoKeyObject: anObject,
|
||||||
|
UserInfoKeyNewIndexPath: newIndexPath!
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
case .Delete:
|
||||||
|
NSNotificationCenter.defaultCenter().postNotificationName(
|
||||||
|
ManagedObjectListControllerDidDeleteObjectNotification,
|
||||||
|
object: self,
|
||||||
|
userInfo: [
|
||||||
|
UserInfoKeyObject: anObject,
|
||||||
|
UserInfoKeyIndexPath: indexPath!
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
case .Update:
|
||||||
|
NSNotificationCenter.defaultCenter().postNotificationName(
|
||||||
|
ManagedObjectListControllerDidUpdateObjectNotification,
|
||||||
|
object: self,
|
||||||
|
userInfo: [
|
||||||
|
UserInfoKeyObject: anObject,
|
||||||
|
UserInfoKeyIndexPath: indexPath!
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
case .Move:
|
||||||
|
NSNotificationCenter.defaultCenter().postNotificationName(
|
||||||
|
ManagedObjectListControllerDidMoveObjectNotification,
|
||||||
|
object: self,
|
||||||
|
userInfo: [
|
||||||
|
UserInfoKeyObject: anObject,
|
||||||
|
UserInfoKeyIndexPath: indexPath!,
|
||||||
|
UserInfoKeyNewIndexPath: newIndexPath!
|
||||||
|
]
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private func controller(controller: NSFetchedResultsController, didChangeSection sectionInfo: NSFetchedResultsSectionInfo, atIndex sectionIndex: Int, forChangeType type: NSFetchedResultsChangeType) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func controller(controller: NSFetchedResultsController, didChangeSection sectionInfo: NSFetchedResultsSectionInfo, atIndex sectionIndex: Int, forChangeType type: NSFetchedResultsChangeType) {
|
private func controllerWillChangeContent(controller: NSFetchedResultsController) {
|
||||||
|
|
||||||
|
NSNotificationCenter.defaultCenter().postNotificationName(
|
||||||
|
ManagedObjectListControllerWillChangeListNotification,
|
||||||
|
object: self
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
func controllerWillChangeContent(controller: NSFetchedResultsController) {
|
private func controllerDidChangeContent(controller: NSFetchedResultsController) {
|
||||||
|
|
||||||
|
NSNotificationCenter.defaultCenter().postNotificationName(
|
||||||
|
ManagedObjectListControllerDidChangeListNotification,
|
||||||
|
object: self
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
func controllerDidChangeContent(controller: NSFetchedResultsController) {
|
private func controller(controller: NSFetchedResultsController, sectionIndexTitleForSectionName sectionName: String?) -> String? {
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
func controller(controller: NSFetchedResultsController, sectionIndexTitleForSectionName sectionName: String?) -> String? {
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@@ -96,7 +308,7 @@ public final class ManagedObjectListController<T: NSManagedObject>: FetchedResul
|
|||||||
managedObjectContext: context,
|
managedObjectContext: context,
|
||||||
sectionNameKeyPath: sectionNameKeyPath,
|
sectionNameKeyPath: sectionNameKeyPath,
|
||||||
cacheName: (cacheResults
|
cacheName: (cacheResults
|
||||||
? "\(ManagedObjectListController<T>.self).\(NSUUID())"
|
? "\(self.dynamicType).\(NSUUID())"
|
||||||
: nil)
|
: nil)
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -105,7 +317,6 @@ public final class ManagedObjectListController<T: NSManagedObject>: FetchedResul
|
|||||||
self.fetchedResultsController = fetchedResultsController
|
self.fetchedResultsController = fetchedResultsController
|
||||||
self.fetchedResultsControllerDelegate = fetchedResultsControllerDelegate
|
self.fetchedResultsControllerDelegate = fetchedResultsControllerDelegate
|
||||||
self.parentStack = dataStack
|
self.parentStack = dataStack
|
||||||
self.observers = NSHashTable.weakObjectsHashTable()
|
|
||||||
|
|
||||||
fetchedResultsControllerDelegate.handler = self
|
fetchedResultsControllerDelegate.handler = self
|
||||||
fetchedResultsControllerDelegate.fetchedResultsController = fetchedResultsController
|
fetchedResultsControllerDelegate.fetchedResultsController = fetchedResultsController
|
||||||
@@ -125,7 +336,6 @@ public final class ManagedObjectListController<T: NSManagedObject>: FetchedResul
|
|||||||
private let fetchedResultsController: NSFetchedResultsController
|
private let fetchedResultsController: NSFetchedResultsController
|
||||||
private let fetchedResultsControllerDelegate: FetchedResultsControllerDelegate
|
private let fetchedResultsControllerDelegate: FetchedResultsControllerDelegate
|
||||||
private weak var parentStack: DataStack?
|
private weak var parentStack: DataStack?
|
||||||
private let observers: NSHashTable
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -45,33 +45,17 @@ public protocol ManagedObjectListObserver: class {
|
|||||||
// func managedObjectList(listController: ManagedObjectListController<EntityType>, didChangeSection sectionInfo: NSFetchedResultsSectionInfo, atSectionIndex sectionIndex: Int)
|
// func managedObjectList(listController: ManagedObjectListController<EntityType>, didChangeSection sectionInfo: NSFetchedResultsSectionInfo, atSectionIndex sectionIndex: Int)
|
||||||
|
|
||||||
|
|
||||||
func managedObjectList(listController: ManagedObjectListController<EntityType>, didInsertObject object: EntityType, toItemIndex itemIndex: Int)
|
func managedObjectList(listController: ManagedObjectListController<EntityType>, didInsertObject object: EntityType, toIndexPath indexPath: NSIndexPath)
|
||||||
|
|
||||||
func managedObjectList(listController: ManagedObjectListController<EntityType>, didDeleteObject object: EntityType, fromItemIndex itemIndex: Int)
|
func managedObjectList(listController: ManagedObjectListController<EntityType>, didDeleteObject object: EntityType, fromIndexPath indexPath: NSIndexPath)
|
||||||
|
|
||||||
func managedObjectList(listController: ManagedObjectListController<EntityType>, didUpdateObject object: EntityType, atItemIndex itemIndex: Int)
|
func managedObjectList(listController: ManagedObjectListController<EntityType>, didUpdateObject object: EntityType, atIndexPath indexPath: NSIndexPath)
|
||||||
|
|
||||||
func managedObjectList(listController: ManagedObjectListController<EntityType>, didMoveObject object: EntityType, fromItemIndex: Int, toItemIndex: Int)
|
func managedObjectList(listController: ManagedObjectListController<EntityType>, didMoveObject object: EntityType, fromIndexPath: NSIndexPath, toIndexPath: NSIndexPath)
|
||||||
|
|
||||||
|
|
||||||
func managedObjectListDidChange(listController: ManagedObjectListController<EntityType>)
|
func managedObjectListDidChange(listController: ManagedObjectListController<EntityType>)
|
||||||
|
|
||||||
|
|
||||||
// private func controller(controller: NSFetchedResultsController, didChangeObject anObject: AnyObject, atIndexPath indexPath: NSIndexPath?, forChangeType type: NSFetchedResultsChangeType, newIndexPath: NSIndexPath?) {
|
|
||||||
//
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// private func controller(controller: NSFetchedResultsController, didChangeSection sectionInfo: NSFetchedResultsSectionInfo, atIndex sectionIndex: Int, forChangeType type: NSFetchedResultsChangeType) {
|
|
||||||
//
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// private func controllerWillChangeContent(controller: NSFetchedResultsController) {
|
|
||||||
//
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// private func controllerDidChangeContent(controller: NSFetchedResultsController) {
|
|
||||||
//
|
|
||||||
// }
|
|
||||||
//
|
//
|
||||||
// private func controller(controller: NSFetchedResultsController, sectionIndexTitleForSectionName sectionName: String?) -> String? {
|
// private func controller(controller: NSFetchedResultsController, sectionIndexTitleForSectionName sectionName: String?) -> String? {
|
||||||
//
|
//
|
||||||
|
|||||||
@@ -38,14 +38,19 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
get {
|
get {
|
||||||
|
|
||||||
let number: NSNumber? = self.getAssociatedObjectForKey(&PropertyKeys.shouldCascadeSavesToParent)
|
let number: NSNumber? = getAssociatedObjectForKey(
|
||||||
|
&PropertyKeys.shouldCascadeSavesToParent,
|
||||||
|
inObject: self
|
||||||
|
)
|
||||||
return number?.boolValue ?? false
|
return number?.boolValue ?? false
|
||||||
}
|
}
|
||||||
set {
|
set {
|
||||||
|
|
||||||
self.setAssociatedCopiedObject(
|
setAssociatedCopiedObject(
|
||||||
NSNumber(bool: newValue),
|
NSNumber(bool: newValue),
|
||||||
forKey: &PropertyKeys.shouldCascadeSavesToParent)
|
forKey: &PropertyKeys.shouldCascadeSavesToParent,
|
||||||
|
inObject: self
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -106,13 +111,18 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
get {
|
get {
|
||||||
|
|
||||||
return self.getAssociatedObjectForKey(&PropertyKeys.observerForWillSaveNotification)
|
return getAssociatedObjectForKey(
|
||||||
|
&PropertyKeys.observerForWillSaveNotification,
|
||||||
|
inObject: self
|
||||||
|
)
|
||||||
}
|
}
|
||||||
set {
|
set {
|
||||||
|
|
||||||
self.setAssociatedRetainedObject(
|
setAssociatedRetainedObject(
|
||||||
newValue,
|
newValue,
|
||||||
forKey: &PropertyKeys.observerForWillSaveNotification)
|
forKey: &PropertyKeys.observerForWillSaveNotification,
|
||||||
|
inObject: self
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -42,7 +42,7 @@ internal extension NSManagedObjectContext {
|
|||||||
return parentContext.parentStack
|
return parentContext.parentStack
|
||||||
}
|
}
|
||||||
|
|
||||||
return self.getAssociatedObjectForKey(&PropertyKeys.parentStack)
|
return getAssociatedObjectForKey(&PropertyKeys.parentStack, inObject: self)
|
||||||
}
|
}
|
||||||
set {
|
set {
|
||||||
|
|
||||||
@@ -51,9 +51,11 @@ internal extension NSManagedObjectContext {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
self.setAssociatedWeakObject(
|
setAssociatedWeakObject(
|
||||||
newValue,
|
newValue,
|
||||||
forKey: &PropertyKeys.parentStack)
|
forKey: &PropertyKeys.parentStack,
|
||||||
|
inObject: self
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -72,9 +74,9 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
let context = NSManagedObjectContext(concurrencyType: .MainQueueConcurrencyType)
|
let context = NSManagedObjectContext(concurrencyType: .MainQueueConcurrencyType)
|
||||||
context.parentContext = rootContext
|
context.parentContext = rootContext
|
||||||
context.setupForHardcoreDataWithContextName("com.hardcoredata.maincontext")
|
|
||||||
context.shouldCascadeSavesToParent = true
|
context.shouldCascadeSavesToParent = true
|
||||||
context.undoManager = nil
|
context.undoManager = nil
|
||||||
|
context.setupForHardcoreDataWithContextName("com.hardcoredata.maincontext")
|
||||||
context.observerForDidSaveNotification = NotificationObserver(
|
context.observerForDidSaveNotification = NotificationObserver(
|
||||||
notificationName: NSManagedObjectContextDidSaveNotification,
|
notificationName: NSManagedObjectContextDidSaveNotification,
|
||||||
object: rootContext,
|
object: rootContext,
|
||||||
@@ -104,13 +106,18 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
get {
|
get {
|
||||||
|
|
||||||
return self.getAssociatedObjectForKey(&PropertyKeys.observerForDidSaveNotification)
|
return getAssociatedObjectForKey(
|
||||||
|
&PropertyKeys.observerForDidSaveNotification,
|
||||||
|
inObject: self
|
||||||
|
)
|
||||||
}
|
}
|
||||||
set {
|
set {
|
||||||
|
|
||||||
self.setAssociatedRetainedObject(
|
setAssociatedRetainedObject(
|
||||||
newValue,
|
newValue,
|
||||||
forKey: &PropertyKeys.observerForDidSaveNotification)
|
forKey: &PropertyKeys.observerForDidSaveNotification,
|
||||||
|
inObject: self
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -38,13 +38,18 @@ internal extension NSManagedObjectContext {
|
|||||||
|
|
||||||
get {
|
get {
|
||||||
|
|
||||||
return self.getAssociatedObjectForKey(&PropertyKeys.parentTransaction)
|
return getAssociatedObjectForKey(
|
||||||
|
&PropertyKeys.parentTransaction,
|
||||||
|
inObject: self
|
||||||
|
)
|
||||||
}
|
}
|
||||||
set {
|
set {
|
||||||
|
|
||||||
self.setAssociatedWeakObject(
|
setAssociatedWeakObject(
|
||||||
newValue,
|
newValue,
|
||||||
forKey: &PropertyKeys.parentTransaction)
|
forKey: &PropertyKeys.parentTransaction,
|
||||||
|
inObject: self
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,76 +0,0 @@
|
|||||||
//
|
|
||||||
// NSObject+HardcoreData.swift
|
|
||||||
// HardcoreData
|
|
||||||
//
|
|
||||||
// Copyright (c) 2014 John Rommel Estropia
|
|
||||||
//
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
// of this software and associated documentation files (the "Software"), to deal
|
|
||||||
// in the Software without restriction, including without limitation the rights
|
|
||||||
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
// copies of the Software, and to permit persons to whom the Software is
|
|
||||||
// furnished to do so, subject to the following conditions:
|
|
||||||
//
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
|
||||||
// copies or substantial portions of the Software.
|
|
||||||
//
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
||||||
// SOFTWARE.
|
|
||||||
//
|
|
||||||
|
|
||||||
import Foundation
|
|
||||||
|
|
||||||
|
|
||||||
// MARK: - NSObject
|
|
||||||
|
|
||||||
internal extension NSObject {
|
|
||||||
|
|
||||||
// MARK: Internal
|
|
||||||
|
|
||||||
internal func getAssociatedObjectForKey<T: AnyObject>(key: UnsafePointer<Void>) -> T? {
|
|
||||||
|
|
||||||
switch objc_getAssociatedObject(self, key) {
|
|
||||||
|
|
||||||
case let object as T:
|
|
||||||
return object
|
|
||||||
|
|
||||||
case let object as WeakObject:
|
|
||||||
return object.object as? T
|
|
||||||
|
|
||||||
default:
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
internal func setAssociatedRetainedObject<T: AnyObject>(object: T?, forKey key: UnsafePointer<Void>) {
|
|
||||||
|
|
||||||
objc_setAssociatedObject(self, key, object, UInt(OBJC_ASSOCIATION_RETAIN_NONATOMIC))
|
|
||||||
}
|
|
||||||
|
|
||||||
internal func setAssociatedCopiedObject<T: AnyObject>(object: T?, forKey key: UnsafePointer<Void>) {
|
|
||||||
|
|
||||||
objc_setAssociatedObject(self, key, object, UInt(OBJC_ASSOCIATION_COPY_NONATOMIC))
|
|
||||||
}
|
|
||||||
|
|
||||||
internal func setAssociatedAssignedObject<T: AnyObject>(object: T?, forKey key: UnsafePointer<Void>) {
|
|
||||||
|
|
||||||
objc_setAssociatedObject(self, key, object, UInt(OBJC_ASSOCIATION_ASSIGN))
|
|
||||||
}
|
|
||||||
|
|
||||||
internal func setAssociatedWeakObject<T: AnyObject>(object: T?, forKey key: UnsafePointer<Void>) {
|
|
||||||
|
|
||||||
if let object = object {
|
|
||||||
|
|
||||||
objc_setAssociatedObject(self, key, WeakObject(object), UInt(OBJC_ASSOCIATION_RETAIN_NONATOMIC))
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
|
|
||||||
objc_setAssociatedObject(self, key, nil, UInt(OBJC_ASSOCIATION_RETAIN_NONATOMIC))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -44,7 +44,8 @@ internal final class NotificationObserver {
|
|||||||
notificationName,
|
notificationName,
|
||||||
object: object,
|
object: object,
|
||||||
queue: nil,
|
queue: nil,
|
||||||
usingBlock: closure)
|
usingBlock: closure
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
deinit {
|
deinit {
|
||||||
@@ -52,6 +53,7 @@ internal final class NotificationObserver {
|
|||||||
NSNotificationCenter.defaultCenter().removeObserver(
|
NSNotificationCenter.defaultCenter().removeObserver(
|
||||||
self.observer,
|
self.observer,
|
||||||
name: self.notificationName,
|
name: self.notificationName,
|
||||||
object: self.object)
|
object: self.object
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -155,7 +155,7 @@ public struct Select<T: SelectResultType> {
|
|||||||
|
|
||||||
if fetchRequest.propertiesToFetch != nil {
|
if fetchRequest.propertiesToFetch != nil {
|
||||||
|
|
||||||
HardcoreData.log(.Warning, message: "An existing \"propertiesToFetch\" for the <\(NSFetchRequest.self)> was overwritten by <\(self.dynamicType)> query clause.")
|
HardcoreData.log(.Warning, message: "An existing \"propertiesToFetch\" for the <\(NSFetchRequest.self)> was overwritten by \(typeName(self)) query clause.")
|
||||||
}
|
}
|
||||||
|
|
||||||
fetchRequest.includesPendingChanges = false
|
fetchRequest.includesPendingChanges = false
|
||||||
@@ -177,7 +177,7 @@ public struct Select<T: SelectResultType> {
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
||||||
HardcoreData.log(.Warning, message: "The property \"\(keyPath)\" does not exist in entity <\(entityDescription.managedObjectClassName)> and will be ignored by <\(self.dynamicType)> query clause.")
|
HardcoreData.log(.Warning, message: "The property \"\(keyPath)\" does not exist in entity <\(entityDescription.managedObjectClassName)> and will be ignored by \(typeName(self)) query clause.")
|
||||||
}
|
}
|
||||||
|
|
||||||
case .Aggregate(let function, let keyPath, let alias):
|
case .Aggregate(let function, let keyPath, let alias):
|
||||||
@@ -195,7 +195,7 @@ public struct Select<T: SelectResultType> {
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
||||||
HardcoreData.log(.Warning, message: "The attribute \"\(keyPath)\" does not exist in entity <\(entityDescription.managedObjectClassName)> and will be ignored by <\(self.dynamicType)> query clause.")
|
HardcoreData.log(.Warning, message: "The attribute \"\(keyPath)\" does not exist in entity <\(entityDescription.managedObjectClassName)> and will be ignored by \(typeName(self)) query clause.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -98,7 +98,7 @@ public struct SortedBy: FetchClause {
|
|||||||
|
|
||||||
if fetchRequest.sortDescriptors != nil {
|
if fetchRequest.sortDescriptors != nil {
|
||||||
|
|
||||||
HardcoreData.log(.Warning, message: "Existing sortDescriptors for the <\(NSFetchRequest.self)> was overwritten by <\(self.dynamicType)> query clause.")
|
HardcoreData.log(.Warning, message: "Existing sortDescriptors for the <\(NSFetchRequest.self)> was overwritten by \(typeName(self)) query clause.")
|
||||||
}
|
}
|
||||||
|
|
||||||
fetchRequest.sortDescriptors = self.sortDescriptors
|
fetchRequest.sortDescriptors = self.sortDescriptors
|
||||||
|
|||||||
@@ -20,8 +20,8 @@ public final class SynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public func commitAndWait() {
|
public func commitAndWait() {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to commit a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to commit a \(typeName(self)) outside its designated queue.")
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to commit a <\(self.dynamicType)> more than once.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to commit a \(typeName(self)) more than once.")
|
||||||
|
|
||||||
self.isCommitted = true
|
self.isCommitted = true
|
||||||
self.result = self.context.saveSynchronously()
|
self.result = self.context.saveSynchronously()
|
||||||
@@ -35,8 +35,8 @@ public final class SynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public func beginSynchronous(closure: (transaction: SynchronousDataTransaction) -> Void) -> SaveResult? {
|
public func beginSynchronous(closure: (transaction: SynchronousDataTransaction) -> Void) -> SaveResult? {
|
||||||
|
|
||||||
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to begin a child transaction from a <\(self.dynamicType)> outside its designated queue.")
|
HardcoreData.assert(self.transactionQueue.isCurrentExecutionContext(), "Attempted to begin a child transaction from a \(typeName(self)) outside its designated queue.")
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to begin a child transaction from an already committed <\(self.dynamicType)>.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to begin a child transaction from an already committed \(typeName(self)).")
|
||||||
|
|
||||||
return SynchronousDataTransaction(
|
return SynchronousDataTransaction(
|
||||||
mainContext: self.context,
|
mainContext: self.context,
|
||||||
@@ -55,7 +55,7 @@ public final class SynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public override func create<T: NSManagedObject>(entity: T.Type) -> T {
|
public override func create<T: NSManagedObject>(entity: T.Type) -> T {
|
||||||
|
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to create an entity of type <\(entity)> from an already committed <\(self.dynamicType)>.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to create an entity of type <\(entity)> from an already committed \(typeName(self)).")
|
||||||
|
|
||||||
return super.create(entity)
|
return super.create(entity)
|
||||||
}
|
}
|
||||||
@@ -68,7 +68,7 @@ public final class SynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public override func fetch<T: NSManagedObject>(object: T) -> T? {
|
public override func fetch<T: NSManagedObject>(object: T) -> T? {
|
||||||
|
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to update an entity of type <\(object.dynamicType)> from an already committed <\(self.dynamicType)>.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to update an entity of type \(typeName(object)) from an already committed \(typeName(self)).")
|
||||||
|
|
||||||
return super.fetch(object)
|
return super.fetch(object)
|
||||||
}
|
}
|
||||||
@@ -80,7 +80,7 @@ public final class SynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public override func delete(object: NSManagedObject) {
|
public override func delete(object: NSManagedObject) {
|
||||||
|
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to delete an entity of type <\(object.dynamicType)> from an already committed <\(self.dynamicType)>.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to delete an entity of type \(typeName(object)) from an already committed \(typeName(self)).")
|
||||||
|
|
||||||
super.delete(object)
|
super.delete(object)
|
||||||
}
|
}
|
||||||
@@ -90,7 +90,7 @@ public final class SynchronousDataTransaction: BaseDataTransaction {
|
|||||||
*/
|
*/
|
||||||
public override func rollback() {
|
public override func rollback() {
|
||||||
|
|
||||||
HardcoreData.assert(!self.isCommitted, "Attempted to rollback an already committed <\(self.dynamicType)>.")
|
HardcoreData.assert(!self.isCommitted, "Attempted to rollback an already committed \(typeName(self)).")
|
||||||
|
|
||||||
super.rollback()
|
super.rollback()
|
||||||
}
|
}
|
||||||
@@ -105,7 +105,7 @@ public final class SynchronousDataTransaction: BaseDataTransaction {
|
|||||||
self.closure(transaction: self)
|
self.closure(transaction: self)
|
||||||
if !self.isCommitted && self.hasChanges {
|
if !self.isCommitted && self.hasChanges {
|
||||||
|
|
||||||
HardcoreData.log(.Warning, message: "The closure for the <\(self.dynamicType)> completed without being committed. All changes made within the transaction were discarded.")
|
HardcoreData.log(.Warning, message: "The closure for the \(typeName(self)) completed without being committed. All changes made within the transaction were discarded.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return self.result
|
return self.result
|
||||||
|
|||||||
@@ -89,7 +89,7 @@ public struct Where: FetchClause {
|
|||||||
|
|
||||||
if fetchRequest.predicate != nil {
|
if fetchRequest.predicate != nil {
|
||||||
|
|
||||||
HardcoreData.log(.Warning, message: "An existing predicate for the <\(NSFetchRequest.self)> was overwritten by <\(self.dynamicType)> query clause.")
|
HardcoreData.log(.Warning, message: "An existing predicate for the <\(NSFetchRequest.self)> was overwritten by \(typeName(self)) query clause.")
|
||||||
}
|
}
|
||||||
|
|
||||||
fetchRequest.predicate = self.predicate
|
fetchRequest.predicate = self.predicate
|
||||||
|
|||||||
553
HardcoreDataDemo/HardcoreDataDemo.xcodeproj/project.pbxproj
Normal file
553
HardcoreDataDemo/HardcoreDataDemo.xcodeproj/project.pbxproj
Normal file
@@ -0,0 +1,553 @@
|
|||||||
|
// !$*UTF8*$!
|
||||||
|
{
|
||||||
|
archiveVersion = 1;
|
||||||
|
classes = {
|
||||||
|
};
|
||||||
|
objectVersion = 46;
|
||||||
|
objects = {
|
||||||
|
|
||||||
|
/* Begin PBXBuildFile section */
|
||||||
|
B54AAD4F1AF4D26E00848AE0 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = B54AAD4E1AF4D26E00848AE0 /* AppDelegate.swift */; };
|
||||||
|
B54AAD521AF4D26E00848AE0 /* HardcoreDataDemo.xcdatamodeld in Sources */ = {isa = PBXBuildFile; fileRef = B54AAD501AF4D26E00848AE0 /* HardcoreDataDemo.xcdatamodeld */; };
|
||||||
|
B54AAD541AF4D26E00848AE0 /* MasterViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = B54AAD531AF4D26E00848AE0 /* MasterViewController.swift */; };
|
||||||
|
B54AAD561AF4D26E00848AE0 /* DetailViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = B54AAD551AF4D26E00848AE0 /* DetailViewController.swift */; };
|
||||||
|
B54AAD591AF4D26E00848AE0 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = B54AAD571AF4D26E00848AE0 /* Main.storyboard */; };
|
||||||
|
B54AAD5B1AF4D26E00848AE0 /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = B54AAD5A1AF4D26E00848AE0 /* Images.xcassets */; };
|
||||||
|
B54AAD5E1AF4D26E00848AE0 /* LaunchScreen.xib in Resources */ = {isa = PBXBuildFile; fileRef = B54AAD5C1AF4D26E00848AE0 /* LaunchScreen.xib */; };
|
||||||
|
B54AAD6A1AF4D26E00848AE0 /* HardcoreDataDemoTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = B54AAD691AF4D26E00848AE0 /* HardcoreDataDemoTests.swift */; };
|
||||||
|
B583A9201AF5F542001F76AF /* HardcoreData.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = B583A91B1AF5F4F4001F76AF /* HardcoreData.framework */; };
|
||||||
|
B583A9211AF5F542001F76AF /* HardcoreData.framework in Embed Frameworks */ = {isa = PBXBuildFile; fileRef = B583A91B1AF5F4F4001F76AF /* HardcoreData.framework */; settings = {ATTRIBUTES = (CodeSignOnCopy, RemoveHeadersOnCopy, ); }; };
|
||||||
|
B583A92B1AF5FCE6001F76AF /* Event.swift in Sources */ = {isa = PBXBuildFile; fileRef = B583A92A1AF5FCE6001F76AF /* Event.swift */; };
|
||||||
|
/* End PBXBuildFile section */
|
||||||
|
|
||||||
|
/* Begin PBXContainerItemProxy section */
|
||||||
|
B54AAD641AF4D26E00848AE0 /* PBXContainerItemProxy */ = {
|
||||||
|
isa = PBXContainerItemProxy;
|
||||||
|
containerPortal = B54AAD411AF4D26E00848AE0 /* Project object */;
|
||||||
|
proxyType = 1;
|
||||||
|
remoteGlobalIDString = B54AAD481AF4D26E00848AE0;
|
||||||
|
remoteInfo = HardcoreDataDemo;
|
||||||
|
};
|
||||||
|
B583A91A1AF5F4F4001F76AF /* PBXContainerItemProxy */ = {
|
||||||
|
isa = PBXContainerItemProxy;
|
||||||
|
containerPortal = B583A9141AF5F4F3001F76AF /* HardcoreData.xcodeproj */;
|
||||||
|
proxyType = 2;
|
||||||
|
remoteGlobalIDString = 2F03A53019C5C6DA005002A5;
|
||||||
|
remoteInfo = HardcoreData;
|
||||||
|
};
|
||||||
|
B583A91C1AF5F4F4001F76AF /* PBXContainerItemProxy */ = {
|
||||||
|
isa = PBXContainerItemProxy;
|
||||||
|
containerPortal = B583A9141AF5F4F3001F76AF /* HardcoreData.xcodeproj */;
|
||||||
|
proxyType = 2;
|
||||||
|
remoteGlobalIDString = 2F03A53B19C5C6DA005002A5;
|
||||||
|
remoteInfo = HardcoreDataTests;
|
||||||
|
};
|
||||||
|
B583A91E1AF5F512001F76AF /* PBXContainerItemProxy */ = {
|
||||||
|
isa = PBXContainerItemProxy;
|
||||||
|
containerPortal = B583A9141AF5F4F3001F76AF /* HardcoreData.xcodeproj */;
|
||||||
|
proxyType = 1;
|
||||||
|
remoteGlobalIDString = 2F03A52F19C5C6DA005002A5;
|
||||||
|
remoteInfo = HardcoreData;
|
||||||
|
};
|
||||||
|
B583A9221AF5F542001F76AF /* PBXContainerItemProxy */ = {
|
||||||
|
isa = PBXContainerItemProxy;
|
||||||
|
containerPortal = B583A9141AF5F4F3001F76AF /* HardcoreData.xcodeproj */;
|
||||||
|
proxyType = 1;
|
||||||
|
remoteGlobalIDString = 2F03A52F19C5C6DA005002A5;
|
||||||
|
remoteInfo = HardcoreData;
|
||||||
|
};
|
||||||
|
/* End PBXContainerItemProxy section */
|
||||||
|
|
||||||
|
/* Begin PBXCopyFilesBuildPhase section */
|
||||||
|
B583A9241AF5F542001F76AF /* Embed Frameworks */ = {
|
||||||
|
isa = PBXCopyFilesBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
dstPath = "";
|
||||||
|
dstSubfolderSpec = 10;
|
||||||
|
files = (
|
||||||
|
B583A9211AF5F542001F76AF /* HardcoreData.framework in Embed Frameworks */,
|
||||||
|
);
|
||||||
|
name = "Embed Frameworks";
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
/* End PBXCopyFilesBuildPhase section */
|
||||||
|
|
||||||
|
/* Begin PBXFileReference section */
|
||||||
|
B54AAD491AF4D26E00848AE0 /* HardcoreDataDemo.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = HardcoreDataDemo.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
|
B54AAD4D1AF4D26E00848AE0 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
||||||
|
B54AAD4E1AF4D26E00848AE0 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
|
||||||
|
B54AAD511AF4D26E00848AE0 /* HardcoreDataDemo.xcdatamodel */ = {isa = PBXFileReference; lastKnownFileType = wrapper.xcdatamodel; path = HardcoreDataDemo.xcdatamodel; sourceTree = "<group>"; };
|
||||||
|
B54AAD531AF4D26E00848AE0 /* MasterViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = MasterViewController.swift; sourceTree = "<group>"; };
|
||||||
|
B54AAD551AF4D26E00848AE0 /* DetailViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = DetailViewController.swift; sourceTree = "<group>"; };
|
||||||
|
B54AAD581AF4D26E00848AE0 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = "<group>"; };
|
||||||
|
B54AAD5A1AF4D26E00848AE0 /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Images.xcassets; sourceTree = "<group>"; };
|
||||||
|
B54AAD5D1AF4D26E00848AE0 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = Base; path = Base.lproj/LaunchScreen.xib; sourceTree = "<group>"; };
|
||||||
|
B54AAD631AF4D26E00848AE0 /* HardcoreDataDemoTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = HardcoreDataDemoTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
|
B54AAD681AF4D26E00848AE0 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
||||||
|
B54AAD691AF4D26E00848AE0 /* HardcoreDataDemoTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HardcoreDataDemoTests.swift; sourceTree = "<group>"; };
|
||||||
|
B583A9141AF5F4F3001F76AF /* HardcoreData.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = HardcoreData.xcodeproj; path = ../HardcoreData.xcodeproj; sourceTree = "<group>"; };
|
||||||
|
B583A9251AF5F547001F76AF /* GCDKit.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; name = GCDKit.framework; path = "/Users/johnestropia/Library/Developer/Xcode/DerivedData/HardcoreDataDemo-ftknhsqfpsthfogvisxisgpbbhsj/Build/Products/Debug-iphoneos/GCDKit.framework"; sourceTree = "<absolute>"; };
|
||||||
|
B583A92A1AF5FCE6001F76AF /* Event.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Event.swift; sourceTree = "<group>"; };
|
||||||
|
/* End PBXFileReference section */
|
||||||
|
|
||||||
|
/* Begin PBXFrameworksBuildPhase section */
|
||||||
|
B54AAD461AF4D26E00848AE0 /* Frameworks */ = {
|
||||||
|
isa = PBXFrameworksBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
B583A9201AF5F542001F76AF /* HardcoreData.framework in Frameworks */,
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
B54AAD601AF4D26E00848AE0 /* Frameworks */ = {
|
||||||
|
isa = PBXFrameworksBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
/* End PBXFrameworksBuildPhase section */
|
||||||
|
|
||||||
|
/* Begin PBXGroup section */
|
||||||
|
B54AAD401AF4D26E00848AE0 = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
B583A9251AF5F547001F76AF /* GCDKit.framework */,
|
||||||
|
B583A9141AF5F4F3001F76AF /* HardcoreData.xcodeproj */,
|
||||||
|
B54AAD4B1AF4D26E00848AE0 /* HardcoreDataDemo */,
|
||||||
|
B54AAD661AF4D26E00848AE0 /* HardcoreDataDemoTests */,
|
||||||
|
B54AAD4A1AF4D26E00848AE0 /* Products */,
|
||||||
|
);
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
B54AAD4A1AF4D26E00848AE0 /* Products */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
B54AAD491AF4D26E00848AE0 /* HardcoreDataDemo.app */,
|
||||||
|
B54AAD631AF4D26E00848AE0 /* HardcoreDataDemoTests.xctest */,
|
||||||
|
);
|
||||||
|
name = Products;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
B54AAD4B1AF4D26E00848AE0 /* HardcoreDataDemo */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
B54AAD4E1AF4D26E00848AE0 /* AppDelegate.swift */,
|
||||||
|
B54AAD531AF4D26E00848AE0 /* MasterViewController.swift */,
|
||||||
|
B54AAD551AF4D26E00848AE0 /* DetailViewController.swift */,
|
||||||
|
B54AAD571AF4D26E00848AE0 /* Main.storyboard */,
|
||||||
|
B54AAD5A1AF4D26E00848AE0 /* Images.xcassets */,
|
||||||
|
B54AAD5C1AF4D26E00848AE0 /* LaunchScreen.xib */,
|
||||||
|
B583A92A1AF5FCE6001F76AF /* Event.swift */,
|
||||||
|
B54AAD501AF4D26E00848AE0 /* HardcoreDataDemo.xcdatamodeld */,
|
||||||
|
B54AAD4C1AF4D26E00848AE0 /* Supporting Files */,
|
||||||
|
);
|
||||||
|
path = HardcoreDataDemo;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
B54AAD4C1AF4D26E00848AE0 /* Supporting Files */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
B54AAD4D1AF4D26E00848AE0 /* Info.plist */,
|
||||||
|
);
|
||||||
|
name = "Supporting Files";
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
B54AAD661AF4D26E00848AE0 /* HardcoreDataDemoTests */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
B54AAD691AF4D26E00848AE0 /* HardcoreDataDemoTests.swift */,
|
||||||
|
B54AAD671AF4D26E00848AE0 /* Supporting Files */,
|
||||||
|
);
|
||||||
|
path = HardcoreDataDemoTests;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
B54AAD671AF4D26E00848AE0 /* Supporting Files */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
B54AAD681AF4D26E00848AE0 /* Info.plist */,
|
||||||
|
);
|
||||||
|
name = "Supporting Files";
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
B583A9151AF5F4F3001F76AF /* Products */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
B583A91B1AF5F4F4001F76AF /* HardcoreData.framework */,
|
||||||
|
B583A91D1AF5F4F4001F76AF /* HardcoreDataTests.xctest */,
|
||||||
|
);
|
||||||
|
name = Products;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
/* End PBXGroup section */
|
||||||
|
|
||||||
|
/* Begin PBXNativeTarget section */
|
||||||
|
B54AAD481AF4D26E00848AE0 /* HardcoreDataDemo */ = {
|
||||||
|
isa = PBXNativeTarget;
|
||||||
|
buildConfigurationList = B54AAD6D1AF4D26E00848AE0 /* Build configuration list for PBXNativeTarget "HardcoreDataDemo" */;
|
||||||
|
buildPhases = (
|
||||||
|
B54AAD451AF4D26E00848AE0 /* Sources */,
|
||||||
|
B54AAD461AF4D26E00848AE0 /* Frameworks */,
|
||||||
|
B54AAD471AF4D26E00848AE0 /* Resources */,
|
||||||
|
B583A9241AF5F542001F76AF /* Embed Frameworks */,
|
||||||
|
);
|
||||||
|
buildRules = (
|
||||||
|
);
|
||||||
|
dependencies = (
|
||||||
|
B583A91F1AF5F512001F76AF /* PBXTargetDependency */,
|
||||||
|
B583A9231AF5F542001F76AF /* PBXTargetDependency */,
|
||||||
|
);
|
||||||
|
name = HardcoreDataDemo;
|
||||||
|
productName = HardcoreDataDemo;
|
||||||
|
productReference = B54AAD491AF4D26E00848AE0 /* HardcoreDataDemo.app */;
|
||||||
|
productType = "com.apple.product-type.application";
|
||||||
|
};
|
||||||
|
B54AAD621AF4D26E00848AE0 /* HardcoreDataDemoTests */ = {
|
||||||
|
isa = PBXNativeTarget;
|
||||||
|
buildConfigurationList = B54AAD701AF4D26E00848AE0 /* Build configuration list for PBXNativeTarget "HardcoreDataDemoTests" */;
|
||||||
|
buildPhases = (
|
||||||
|
B54AAD5F1AF4D26E00848AE0 /* Sources */,
|
||||||
|
B54AAD601AF4D26E00848AE0 /* Frameworks */,
|
||||||
|
B54AAD611AF4D26E00848AE0 /* Resources */,
|
||||||
|
);
|
||||||
|
buildRules = (
|
||||||
|
);
|
||||||
|
dependencies = (
|
||||||
|
B54AAD651AF4D26E00848AE0 /* PBXTargetDependency */,
|
||||||
|
);
|
||||||
|
name = HardcoreDataDemoTests;
|
||||||
|
productName = HardcoreDataDemoTests;
|
||||||
|
productReference = B54AAD631AF4D26E00848AE0 /* HardcoreDataDemoTests.xctest */;
|
||||||
|
productType = "com.apple.product-type.bundle.unit-test";
|
||||||
|
};
|
||||||
|
/* End PBXNativeTarget section */
|
||||||
|
|
||||||
|
/* Begin PBXProject section */
|
||||||
|
B54AAD411AF4D26E00848AE0 /* Project object */ = {
|
||||||
|
isa = PBXProject;
|
||||||
|
attributes = {
|
||||||
|
LastUpgradeCheck = 0630;
|
||||||
|
ORGANIZATIONNAME = "John Rommel Estropia";
|
||||||
|
TargetAttributes = {
|
||||||
|
B54AAD481AF4D26E00848AE0 = {
|
||||||
|
CreatedOnToolsVersion = 6.3;
|
||||||
|
};
|
||||||
|
B54AAD621AF4D26E00848AE0 = {
|
||||||
|
CreatedOnToolsVersion = 6.3;
|
||||||
|
TestTargetID = B54AAD481AF4D26E00848AE0;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
buildConfigurationList = B54AAD441AF4D26E00848AE0 /* Build configuration list for PBXProject "HardcoreDataDemo" */;
|
||||||
|
compatibilityVersion = "Xcode 3.2";
|
||||||
|
developmentRegion = English;
|
||||||
|
hasScannedForEncodings = 0;
|
||||||
|
knownRegions = (
|
||||||
|
en,
|
||||||
|
Base,
|
||||||
|
);
|
||||||
|
mainGroup = B54AAD401AF4D26E00848AE0;
|
||||||
|
productRefGroup = B54AAD4A1AF4D26E00848AE0 /* Products */;
|
||||||
|
projectDirPath = "";
|
||||||
|
projectReferences = (
|
||||||
|
{
|
||||||
|
ProductGroup = B583A9151AF5F4F3001F76AF /* Products */;
|
||||||
|
ProjectRef = B583A9141AF5F4F3001F76AF /* HardcoreData.xcodeproj */;
|
||||||
|
},
|
||||||
|
);
|
||||||
|
projectRoot = "";
|
||||||
|
targets = (
|
||||||
|
B54AAD481AF4D26E00848AE0 /* HardcoreDataDemo */,
|
||||||
|
B54AAD621AF4D26E00848AE0 /* HardcoreDataDemoTests */,
|
||||||
|
);
|
||||||
|
};
|
||||||
|
/* End PBXProject section */
|
||||||
|
|
||||||
|
/* Begin PBXReferenceProxy section */
|
||||||
|
B583A91B1AF5F4F4001F76AF /* HardcoreData.framework */ = {
|
||||||
|
isa = PBXReferenceProxy;
|
||||||
|
fileType = wrapper.framework;
|
||||||
|
path = HardcoreData.framework;
|
||||||
|
remoteRef = B583A91A1AF5F4F4001F76AF /* PBXContainerItemProxy */;
|
||||||
|
sourceTree = BUILT_PRODUCTS_DIR;
|
||||||
|
};
|
||||||
|
B583A91D1AF5F4F4001F76AF /* HardcoreDataTests.xctest */ = {
|
||||||
|
isa = PBXReferenceProxy;
|
||||||
|
fileType = wrapper.cfbundle;
|
||||||
|
path = HardcoreDataTests.xctest;
|
||||||
|
remoteRef = B583A91C1AF5F4F4001F76AF /* PBXContainerItemProxy */;
|
||||||
|
sourceTree = BUILT_PRODUCTS_DIR;
|
||||||
|
};
|
||||||
|
/* End PBXReferenceProxy section */
|
||||||
|
|
||||||
|
/* Begin PBXResourcesBuildPhase section */
|
||||||
|
B54AAD471AF4D26E00848AE0 /* Resources */ = {
|
||||||
|
isa = PBXResourcesBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
B54AAD591AF4D26E00848AE0 /* Main.storyboard in Resources */,
|
||||||
|
B54AAD5E1AF4D26E00848AE0 /* LaunchScreen.xib in Resources */,
|
||||||
|
B54AAD5B1AF4D26E00848AE0 /* Images.xcassets in Resources */,
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
B54AAD611AF4D26E00848AE0 /* Resources */ = {
|
||||||
|
isa = PBXResourcesBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
/* End PBXResourcesBuildPhase section */
|
||||||
|
|
||||||
|
/* Begin PBXSourcesBuildPhase section */
|
||||||
|
B54AAD451AF4D26E00848AE0 /* Sources */ = {
|
||||||
|
isa = PBXSourcesBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
B54AAD521AF4D26E00848AE0 /* HardcoreDataDemo.xcdatamodeld in Sources */,
|
||||||
|
B54AAD4F1AF4D26E00848AE0 /* AppDelegate.swift in Sources */,
|
||||||
|
B54AAD541AF4D26E00848AE0 /* MasterViewController.swift in Sources */,
|
||||||
|
B54AAD561AF4D26E00848AE0 /* DetailViewController.swift in Sources */,
|
||||||
|
B583A92B1AF5FCE6001F76AF /* Event.swift in Sources */,
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
B54AAD5F1AF4D26E00848AE0 /* Sources */ = {
|
||||||
|
isa = PBXSourcesBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
B54AAD6A1AF4D26E00848AE0 /* HardcoreDataDemoTests.swift in Sources */,
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
|
/* End PBXSourcesBuildPhase section */
|
||||||
|
|
||||||
|
/* Begin PBXTargetDependency section */
|
||||||
|
B54AAD651AF4D26E00848AE0 /* PBXTargetDependency */ = {
|
||||||
|
isa = PBXTargetDependency;
|
||||||
|
target = B54AAD481AF4D26E00848AE0 /* HardcoreDataDemo */;
|
||||||
|
targetProxy = B54AAD641AF4D26E00848AE0 /* PBXContainerItemProxy */;
|
||||||
|
};
|
||||||
|
B583A91F1AF5F512001F76AF /* PBXTargetDependency */ = {
|
||||||
|
isa = PBXTargetDependency;
|
||||||
|
name = HardcoreData;
|
||||||
|
targetProxy = B583A91E1AF5F512001F76AF /* PBXContainerItemProxy */;
|
||||||
|
};
|
||||||
|
B583A9231AF5F542001F76AF /* PBXTargetDependency */ = {
|
||||||
|
isa = PBXTargetDependency;
|
||||||
|
name = HardcoreData;
|
||||||
|
targetProxy = B583A9221AF5F542001F76AF /* PBXContainerItemProxy */;
|
||||||
|
};
|
||||||
|
/* End PBXTargetDependency section */
|
||||||
|
|
||||||
|
/* Begin PBXVariantGroup section */
|
||||||
|
B54AAD571AF4D26E00848AE0 /* Main.storyboard */ = {
|
||||||
|
isa = PBXVariantGroup;
|
||||||
|
children = (
|
||||||
|
B54AAD581AF4D26E00848AE0 /* Base */,
|
||||||
|
);
|
||||||
|
name = Main.storyboard;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
B54AAD5C1AF4D26E00848AE0 /* LaunchScreen.xib */ = {
|
||||||
|
isa = PBXVariantGroup;
|
||||||
|
children = (
|
||||||
|
B54AAD5D1AF4D26E00848AE0 /* Base */,
|
||||||
|
);
|
||||||
|
name = LaunchScreen.xib;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
|
/* End PBXVariantGroup section */
|
||||||
|
|
||||||
|
/* Begin XCBuildConfiguration section */
|
||||||
|
B54AAD6B1AF4D26E00848AE0 /* Debug */ = {
|
||||||
|
isa = XCBuildConfiguration;
|
||||||
|
buildSettings = {
|
||||||
|
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||||
|
CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
|
||||||
|
CLANG_CXX_LIBRARY = "libc++";
|
||||||
|
CLANG_ENABLE_MODULES = YES;
|
||||||
|
CLANG_ENABLE_OBJC_ARC = YES;
|
||||||
|
CLANG_WARN_BOOL_CONVERSION = YES;
|
||||||
|
CLANG_WARN_CONSTANT_CONVERSION = YES;
|
||||||
|
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
|
||||||
|
CLANG_WARN_EMPTY_BODY = YES;
|
||||||
|
CLANG_WARN_ENUM_CONVERSION = YES;
|
||||||
|
CLANG_WARN_INT_CONVERSION = YES;
|
||||||
|
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
||||||
|
CLANG_WARN_UNREACHABLE_CODE = YES;
|
||||||
|
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
|
||||||
|
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
|
||||||
|
COPY_PHASE_STRIP = NO;
|
||||||
|
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
|
||||||
|
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
||||||
|
GCC_C_LANGUAGE_STANDARD = gnu99;
|
||||||
|
GCC_DYNAMIC_NO_PIC = NO;
|
||||||
|
GCC_NO_COMMON_BLOCKS = YES;
|
||||||
|
GCC_OPTIMIZATION_LEVEL = 0;
|
||||||
|
GCC_PREPROCESSOR_DEFINITIONS = (
|
||||||
|
"DEBUG=1",
|
||||||
|
"$(inherited)",
|
||||||
|
);
|
||||||
|
GCC_SYMBOLS_PRIVATE_EXTERN = NO;
|
||||||
|
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
|
||||||
|
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
|
||||||
|
GCC_WARN_UNDECLARED_SELECTOR = YES;
|
||||||
|
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
||||||
|
GCC_WARN_UNUSED_FUNCTION = YES;
|
||||||
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
|
IPHONEOS_DEPLOYMENT_TARGET = 8.3;
|
||||||
|
MTL_ENABLE_DEBUG_INFO = YES;
|
||||||
|
ONLY_ACTIVE_ARCH = YES;
|
||||||
|
SDKROOT = iphoneos;
|
||||||
|
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
|
||||||
|
};
|
||||||
|
name = Debug;
|
||||||
|
};
|
||||||
|
B54AAD6C1AF4D26E00848AE0 /* Release */ = {
|
||||||
|
isa = XCBuildConfiguration;
|
||||||
|
buildSettings = {
|
||||||
|
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||||
|
CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
|
||||||
|
CLANG_CXX_LIBRARY = "libc++";
|
||||||
|
CLANG_ENABLE_MODULES = YES;
|
||||||
|
CLANG_ENABLE_OBJC_ARC = YES;
|
||||||
|
CLANG_WARN_BOOL_CONVERSION = YES;
|
||||||
|
CLANG_WARN_CONSTANT_CONVERSION = YES;
|
||||||
|
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
|
||||||
|
CLANG_WARN_EMPTY_BODY = YES;
|
||||||
|
CLANG_WARN_ENUM_CONVERSION = YES;
|
||||||
|
CLANG_WARN_INT_CONVERSION = YES;
|
||||||
|
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
|
||||||
|
CLANG_WARN_UNREACHABLE_CODE = YES;
|
||||||
|
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
|
||||||
|
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
|
||||||
|
COPY_PHASE_STRIP = NO;
|
||||||
|
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
|
||||||
|
ENABLE_NS_ASSERTIONS = NO;
|
||||||
|
ENABLE_STRICT_OBJC_MSGSEND = YES;
|
||||||
|
GCC_C_LANGUAGE_STANDARD = gnu99;
|
||||||
|
GCC_NO_COMMON_BLOCKS = YES;
|
||||||
|
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
|
||||||
|
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
|
||||||
|
GCC_WARN_UNDECLARED_SELECTOR = YES;
|
||||||
|
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
|
||||||
|
GCC_WARN_UNUSED_FUNCTION = YES;
|
||||||
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
|
IPHONEOS_DEPLOYMENT_TARGET = 8.3;
|
||||||
|
MTL_ENABLE_DEBUG_INFO = NO;
|
||||||
|
SDKROOT = iphoneos;
|
||||||
|
VALIDATE_PRODUCT = YES;
|
||||||
|
};
|
||||||
|
name = Release;
|
||||||
|
};
|
||||||
|
B54AAD6E1AF4D26E00848AE0 /* Debug */ = {
|
||||||
|
isa = XCBuildConfiguration;
|
||||||
|
buildSettings = {
|
||||||
|
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
||||||
|
FRAMEWORK_SEARCH_PATHS = (
|
||||||
|
"$(inherited)",
|
||||||
|
"$(USER_LIBRARY_DIR)/Developer/Xcode/DerivedData/HardcoreDataDemo-ftknhsqfpsthfogvisxisgpbbhsj/Build/Products/Debug-iphoneos",
|
||||||
|
);
|
||||||
|
INFOPLIST_FILE = HardcoreDataDemo/Info.plist;
|
||||||
|
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
|
||||||
|
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||||
|
};
|
||||||
|
name = Debug;
|
||||||
|
};
|
||||||
|
B54AAD6F1AF4D26E00848AE0 /* Release */ = {
|
||||||
|
isa = XCBuildConfiguration;
|
||||||
|
buildSettings = {
|
||||||
|
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
|
||||||
|
FRAMEWORK_SEARCH_PATHS = (
|
||||||
|
"$(inherited)",
|
||||||
|
"$(USER_LIBRARY_DIR)/Developer/Xcode/DerivedData/HardcoreDataDemo-ftknhsqfpsthfogvisxisgpbbhsj/Build/Products/Debug-iphoneos",
|
||||||
|
);
|
||||||
|
INFOPLIST_FILE = HardcoreDataDemo/Info.plist;
|
||||||
|
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
|
||||||
|
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||||
|
};
|
||||||
|
name = Release;
|
||||||
|
};
|
||||||
|
B54AAD711AF4D26E00848AE0 /* Debug */ = {
|
||||||
|
isa = XCBuildConfiguration;
|
||||||
|
buildSettings = {
|
||||||
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
|
FRAMEWORK_SEARCH_PATHS = (
|
||||||
|
"$(SDKROOT)/Developer/Library/Frameworks",
|
||||||
|
"$(inherited)",
|
||||||
|
);
|
||||||
|
GCC_PREPROCESSOR_DEFINITIONS = (
|
||||||
|
"DEBUG=1",
|
||||||
|
"$(inherited)",
|
||||||
|
);
|
||||||
|
INFOPLIST_FILE = HardcoreDataDemoTests/Info.plist;
|
||||||
|
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
|
||||||
|
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||||
|
TEST_HOST = "$(BUILT_PRODUCTS_DIR)/HardcoreDataDemo.app/HardcoreDataDemo";
|
||||||
|
};
|
||||||
|
name = Debug;
|
||||||
|
};
|
||||||
|
B54AAD721AF4D26E00848AE0 /* Release */ = {
|
||||||
|
isa = XCBuildConfiguration;
|
||||||
|
buildSettings = {
|
||||||
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
|
FRAMEWORK_SEARCH_PATHS = (
|
||||||
|
"$(SDKROOT)/Developer/Library/Frameworks",
|
||||||
|
"$(inherited)",
|
||||||
|
);
|
||||||
|
INFOPLIST_FILE = HardcoreDataDemoTests/Info.plist;
|
||||||
|
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
|
||||||
|
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||||
|
TEST_HOST = "$(BUILT_PRODUCTS_DIR)/HardcoreDataDemo.app/HardcoreDataDemo";
|
||||||
|
};
|
||||||
|
name = Release;
|
||||||
|
};
|
||||||
|
/* End XCBuildConfiguration section */
|
||||||
|
|
||||||
|
/* Begin XCConfigurationList section */
|
||||||
|
B54AAD441AF4D26E00848AE0 /* Build configuration list for PBXProject "HardcoreDataDemo" */ = {
|
||||||
|
isa = XCConfigurationList;
|
||||||
|
buildConfigurations = (
|
||||||
|
B54AAD6B1AF4D26E00848AE0 /* Debug */,
|
||||||
|
B54AAD6C1AF4D26E00848AE0 /* Release */,
|
||||||
|
);
|
||||||
|
defaultConfigurationIsVisible = 0;
|
||||||
|
defaultConfigurationName = Release;
|
||||||
|
};
|
||||||
|
B54AAD6D1AF4D26E00848AE0 /* Build configuration list for PBXNativeTarget "HardcoreDataDemo" */ = {
|
||||||
|
isa = XCConfigurationList;
|
||||||
|
buildConfigurations = (
|
||||||
|
B54AAD6E1AF4D26E00848AE0 /* Debug */,
|
||||||
|
B54AAD6F1AF4D26E00848AE0 /* Release */,
|
||||||
|
);
|
||||||
|
defaultConfigurationIsVisible = 0;
|
||||||
|
defaultConfigurationName = Release;
|
||||||
|
};
|
||||||
|
B54AAD701AF4D26E00848AE0 /* Build configuration list for PBXNativeTarget "HardcoreDataDemoTests" */ = {
|
||||||
|
isa = XCConfigurationList;
|
||||||
|
buildConfigurations = (
|
||||||
|
B54AAD711AF4D26E00848AE0 /* Debug */,
|
||||||
|
B54AAD721AF4D26E00848AE0 /* Release */,
|
||||||
|
);
|
||||||
|
defaultConfigurationIsVisible = 0;
|
||||||
|
defaultConfigurationName = Release;
|
||||||
|
};
|
||||||
|
/* End XCConfigurationList section */
|
||||||
|
|
||||||
|
/* Begin XCVersionGroup section */
|
||||||
|
B54AAD501AF4D26E00848AE0 /* HardcoreDataDemo.xcdatamodeld */ = {
|
||||||
|
isa = XCVersionGroup;
|
||||||
|
children = (
|
||||||
|
B54AAD511AF4D26E00848AE0 /* HardcoreDataDemo.xcdatamodel */,
|
||||||
|
);
|
||||||
|
currentVersion = B54AAD511AF4D26E00848AE0 /* HardcoreDataDemo.xcdatamodel */;
|
||||||
|
path = HardcoreDataDemo.xcdatamodeld;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
versionGroupType = wrapper.xcdatamodel;
|
||||||
|
};
|
||||||
|
/* End XCVersionGroup section */
|
||||||
|
};
|
||||||
|
rootObject = B54AAD411AF4D26E00848AE0 /* Project object */;
|
||||||
|
}
|
||||||
7
HardcoreDataDemo/HardcoreDataDemo.xcodeproj/project.xcworkspace/contents.xcworkspacedata
generated
Normal file
7
HardcoreDataDemo/HardcoreDataDemo.xcodeproj/project.xcworkspace/contents.xcworkspacedata
generated
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<Workspace
|
||||||
|
version = "1.0">
|
||||||
|
<FileRef
|
||||||
|
location = "self:HardcoreDataDemo.xcodeproj">
|
||||||
|
</FileRef>
|
||||||
|
</Workspace>
|
||||||
@@ -0,0 +1,53 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>IDESourceControlProjectFavoriteDictionaryKey</key>
|
||||||
|
<false/>
|
||||||
|
<key>IDESourceControlProjectIdentifier</key>
|
||||||
|
<string>7C5E31AC-5DD0-43DA-A5C6-AF73B4532D86</string>
|
||||||
|
<key>IDESourceControlProjectName</key>
|
||||||
|
<string>project</string>
|
||||||
|
<key>IDESourceControlProjectOriginsDictionary</key>
|
||||||
|
<dict>
|
||||||
|
<key>4B60F1BCB491FF717C56441AE7783C74F417BE48</key>
|
||||||
|
<string>github.com:JohnEstropia/HardcoreData.git</string>
|
||||||
|
<key>8B2E522D57154DFA93A06982C36315ECBEA4FA97</key>
|
||||||
|
<string>github.com:JohnEstropia/GCDKit.git</string>
|
||||||
|
</dict>
|
||||||
|
<key>IDESourceControlProjectPath</key>
|
||||||
|
<string>HardcoreDataDemo/HardcoreDataDemo.xcodeproj/project.xcworkspace</string>
|
||||||
|
<key>IDESourceControlProjectRelativeInstallPathDictionary</key>
|
||||||
|
<dict>
|
||||||
|
<key>4B60F1BCB491FF717C56441AE7783C74F417BE48</key>
|
||||||
|
<string>../../..</string>
|
||||||
|
<key>8B2E522D57154DFA93A06982C36315ECBEA4FA97</key>
|
||||||
|
<string>../../../Libraries/GCDKit</string>
|
||||||
|
</dict>
|
||||||
|
<key>IDESourceControlProjectURL</key>
|
||||||
|
<string>github.com:JohnEstropia/HardcoreData.git</string>
|
||||||
|
<key>IDESourceControlProjectVersion</key>
|
||||||
|
<integer>111</integer>
|
||||||
|
<key>IDESourceControlProjectWCCIdentifier</key>
|
||||||
|
<string>4B60F1BCB491FF717C56441AE7783C74F417BE48</string>
|
||||||
|
<key>IDESourceControlProjectWCConfigurations</key>
|
||||||
|
<array>
|
||||||
|
<dict>
|
||||||
|
<key>IDESourceControlRepositoryExtensionIdentifierKey</key>
|
||||||
|
<string>public.vcs.git</string>
|
||||||
|
<key>IDESourceControlWCCIdentifierKey</key>
|
||||||
|
<string>8B2E522D57154DFA93A06982C36315ECBEA4FA97</string>
|
||||||
|
<key>IDESourceControlWCCName</key>
|
||||||
|
<string>GCDKit</string>
|
||||||
|
</dict>
|
||||||
|
<dict>
|
||||||
|
<key>IDESourceControlRepositoryExtensionIdentifierKey</key>
|
||||||
|
<string>public.vcs.git</string>
|
||||||
|
<key>IDESourceControlWCCIdentifierKey</key>
|
||||||
|
<string>4B60F1BCB491FF717C56441AE7783C74F417BE48</string>
|
||||||
|
<key>IDESourceControlWCCName</key>
|
||||||
|
<string>HardcoreData</string>
|
||||||
|
</dict>
|
||||||
|
</array>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
||||||
27
HardcoreDataDemo/HardcoreDataDemo/AppDelegate.swift
Normal file
27
HardcoreDataDemo/HardcoreDataDemo/AppDelegate.swift
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
//
|
||||||
|
// AppDelegate.swift
|
||||||
|
// HardcoreDataDemo
|
||||||
|
//
|
||||||
|
// Created by John Rommel Estropia on 2015/05/02.
|
||||||
|
// Copyright (c) 2015 John Rommel Estropia. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
import UIKit
|
||||||
|
import HardcoreData
|
||||||
|
|
||||||
|
|
||||||
|
// MARK: - AppDelegate
|
||||||
|
|
||||||
|
@UIApplicationMain
|
||||||
|
class AppDelegate: UIResponder, UIApplicationDelegate {
|
||||||
|
|
||||||
|
// MARK: UIApplicationDelegate
|
||||||
|
|
||||||
|
var window: UIWindow?
|
||||||
|
|
||||||
|
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
|
||||||
|
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -0,0 +1,41 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<document type="com.apple.InterfaceBuilder3.CocoaTouch.XIB" version="3.0" toolsVersion="6214" systemVersion="14A314h" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES">
|
||||||
|
<dependencies>
|
||||||
|
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="6207"/>
|
||||||
|
<capability name="Constraints with non-1.0 multipliers" minToolsVersion="5.1"/>
|
||||||
|
</dependencies>
|
||||||
|
<objects>
|
||||||
|
<placeholder placeholderIdentifier="IBFilesOwner" id="-1" userLabel="File's Owner"/>
|
||||||
|
<placeholder placeholderIdentifier="IBFirstResponder" id="-2" customClass="UIResponder"/>
|
||||||
|
<view contentMode="scaleToFill" id="iN0-l3-epB">
|
||||||
|
<rect key="frame" x="0.0" y="0.0" width="480" height="480"/>
|
||||||
|
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
|
||||||
|
<subviews>
|
||||||
|
<label opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text=" Copyright (c) 2015 John Rommel Estropia. All rights reserved." textAlignment="center" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" minimumFontSize="9" translatesAutoresizingMaskIntoConstraints="NO" id="8ie-xW-0ye">
|
||||||
|
<rect key="frame" x="20" y="439" width="441" height="21"/>
|
||||||
|
<fontDescription key="fontDescription" type="system" pointSize="17"/>
|
||||||
|
<color key="textColor" cocoaTouchSystemColor="darkTextColor"/>
|
||||||
|
<nil key="highlightedColor"/>
|
||||||
|
</label>
|
||||||
|
<label opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="HardcoreDataDemo" textAlignment="center" lineBreakMode="middleTruncation" baselineAdjustment="alignBaselines" minimumFontSize="18" translatesAutoresizingMaskIntoConstraints="NO" id="kId-c2-rCX">
|
||||||
|
<rect key="frame" x="20" y="140" width="441" height="43"/>
|
||||||
|
<fontDescription key="fontDescription" type="boldSystem" pointSize="36"/>
|
||||||
|
<color key="textColor" cocoaTouchSystemColor="darkTextColor"/>
|
||||||
|
<nil key="highlightedColor"/>
|
||||||
|
</label>
|
||||||
|
</subviews>
|
||||||
|
<color key="backgroundColor" white="1" alpha="1" colorSpace="custom" customColorSpace="calibratedWhite"/>
|
||||||
|
<constraints>
|
||||||
|
<constraint firstItem="kId-c2-rCX" firstAttribute="centerY" secondItem="iN0-l3-epB" secondAttribute="bottom" multiplier="1/3" constant="1" id="5cJ-9S-tgC"/>
|
||||||
|
<constraint firstAttribute="centerX" secondItem="kId-c2-rCX" secondAttribute="centerX" id="Koa-jz-hwk"/>
|
||||||
|
<constraint firstAttribute="bottom" secondItem="8ie-xW-0ye" secondAttribute="bottom" constant="20" id="Kzo-t9-V3l"/>
|
||||||
|
<constraint firstItem="8ie-xW-0ye" firstAttribute="leading" secondItem="iN0-l3-epB" secondAttribute="leading" constant="20" symbolic="YES" id="MfP-vx-nX0"/>
|
||||||
|
<constraint firstAttribute="centerX" secondItem="8ie-xW-0ye" secondAttribute="centerX" id="ZEH-qu-HZ9"/>
|
||||||
|
<constraint firstItem="kId-c2-rCX" firstAttribute="leading" secondItem="iN0-l3-epB" secondAttribute="leading" constant="20" symbolic="YES" id="fvb-Df-36g"/>
|
||||||
|
</constraints>
|
||||||
|
<nil key="simulatedStatusBarMetrics"/>
|
||||||
|
<freeformSimulatedSizeMetrics key="simulatedDestinationMetrics"/>
|
||||||
|
<point key="canvasLocation" x="548" y="455"/>
|
||||||
|
</view>
|
||||||
|
</objects>
|
||||||
|
</document>
|
||||||
102
HardcoreDataDemo/HardcoreDataDemo/Base.lproj/Main.storyboard
Normal file
102
HardcoreDataDemo/HardcoreDataDemo/Base.lproj/Main.storyboard
Normal file
@@ -0,0 +1,102 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="7702" systemVersion="14D136" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES" initialViewController="rS3-R9-Ivy">
|
||||||
|
<dependencies>
|
||||||
|
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="7701"/>
|
||||||
|
</dependencies>
|
||||||
|
<scenes>
|
||||||
|
<!--Master-->
|
||||||
|
<scene sceneID="cUi-kZ-frf">
|
||||||
|
<objects>
|
||||||
|
<navigationController title="Master" id="rS3-R9-Ivy" sceneMemberID="viewController">
|
||||||
|
<navigationBar key="navigationBar" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="scaleToFill" id="yXu-0R-QUA">
|
||||||
|
<autoresizingMask key="autoresizingMask"/>
|
||||||
|
</navigationBar>
|
||||||
|
<connections>
|
||||||
|
<segue destination="pGg-6v-bdr" kind="relationship" relationship="rootViewController" id="RxB-wf-QIq"/>
|
||||||
|
</connections>
|
||||||
|
</navigationController>
|
||||||
|
<placeholder placeholderIdentifier="IBFirstResponder" id="eq9-QA-ai8" sceneMemberID="firstResponder"/>
|
||||||
|
</objects>
|
||||||
|
<point key="canvasLocation" x="-148" y="64"/>
|
||||||
|
</scene>
|
||||||
|
<!--Master-->
|
||||||
|
<scene sceneID="VgW-fR-Quf">
|
||||||
|
<objects>
|
||||||
|
<tableViewController title="Master" id="pGg-6v-bdr" customClass="MasterViewController" customModule="HardcoreDataDemo" customModuleProvider="target" sceneMemberID="viewController">
|
||||||
|
<tableView key="view" opaque="NO" clipsSubviews="YES" clearsContextBeforeDrawing="NO" contentMode="scaleToFill" alwaysBounceVertical="YES" dataMode="prototypes" style="plain" separatorStyle="default" rowHeight="44" sectionHeaderHeight="22" sectionFooterHeight="22" id="mLL-gJ-YKr">
|
||||||
|
<rect key="frame" x="0.0" y="0.0" width="600" height="600"/>
|
||||||
|
<autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
|
||||||
|
<color key="backgroundColor" white="1" alpha="1" colorSpace="calibratedWhite"/>
|
||||||
|
<prototypes>
|
||||||
|
<tableViewCell contentMode="scaleToFill" selectionStyle="blue" accessoryType="disclosureIndicator" hidesAccessoryWhenEditing="NO" indentationLevel="1" indentationWidth="0.0" reuseIdentifier="UITableViewCell" textLabel="2pz-XF-uhl" style="IBUITableViewCellStyleDefault" id="m0d-ak-lc9">
|
||||||
|
<rect key="frame" x="0.0" y="86" width="320" height="44"/>
|
||||||
|
<autoresizingMask key="autoresizingMask"/>
|
||||||
|
<tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" tableViewCell="m0d-ak-lc9" id="d3P-M7-ByW">
|
||||||
|
<rect key="frame" x="0.0" y="0.0" width="287" height="43"/>
|
||||||
|
<autoresizingMask key="autoresizingMask"/>
|
||||||
|
<subviews>
|
||||||
|
<label opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" text="Title" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" id="2pz-XF-uhl">
|
||||||
|
<rect key="frame" x="15" y="0.0" width="270" height="43"/>
|
||||||
|
<autoresizingMask key="autoresizingMask"/>
|
||||||
|
<fontDescription key="fontDescription" type="boldSystem" pointSize="20"/>
|
||||||
|
<color key="textColor" cocoaTouchSystemColor="darkTextColor"/>
|
||||||
|
<color key="highlightedColor" red="1" green="1" blue="1" alpha="1" colorSpace="calibratedRGB"/>
|
||||||
|
</label>
|
||||||
|
</subviews>
|
||||||
|
</tableViewCellContentView>
|
||||||
|
<color key="backgroundColor" white="1" alpha="1" colorSpace="calibratedWhite"/>
|
||||||
|
<connections>
|
||||||
|
<segue destination="Ah7-4n-0Wa" kind="show" identifier="showDetail" id="jUr-3t-vfg"/>
|
||||||
|
</connections>
|
||||||
|
</tableViewCell>
|
||||||
|
</prototypes>
|
||||||
|
<sections/>
|
||||||
|
<connections>
|
||||||
|
<outlet property="dataSource" destination="pGg-6v-bdr" id="P41-gY-KXY"/>
|
||||||
|
<outlet property="delegate" destination="pGg-6v-bdr" id="Y6K-Cp-Qkv"/>
|
||||||
|
</connections>
|
||||||
|
</tableView>
|
||||||
|
<navigationItem key="navigationItem" title="Master" id="tQt-TN-PWz"/>
|
||||||
|
</tableViewController>
|
||||||
|
<placeholder placeholderIdentifier="IBFirstResponder" id="6Cn-md-YlS" sceneMemberID="firstResponder"/>
|
||||||
|
</objects>
|
||||||
|
<point key="canvasLocation" x="605" y="64"/>
|
||||||
|
</scene>
|
||||||
|
<!--Detail-->
|
||||||
|
<scene sceneID="Cn3-H9-jdl">
|
||||||
|
<objects>
|
||||||
|
<viewController title="Detail" id="Ah7-4n-0Wa" customClass="DetailViewController" customModule="HardcoreDataDemo" customModuleProvider="target" sceneMemberID="viewController">
|
||||||
|
<layoutGuides>
|
||||||
|
<viewControllerLayoutGuide type="top" id="cIm-e0-J51"/>
|
||||||
|
<viewControllerLayoutGuide type="bottom" id="a0L-h9-sNL"/>
|
||||||
|
</layoutGuides>
|
||||||
|
<view key="view" contentMode="scaleToFill" id="MMQ-IT-qOo">
|
||||||
|
<rect key="frame" x="0.0" y="0.0" width="600" height="600"/>
|
||||||
|
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
|
||||||
|
<subviews>
|
||||||
|
<label clipsSubviews="YES" userInteractionEnabled="NO" contentMode="scaleToFill" text="Detail view content goes here" textAlignment="center" lineBreakMode="tailTruncation" minimumFontSize="10" translatesAutoresizingMaskIntoConstraints="NO" id="Lei-5M-9Gs">
|
||||||
|
<rect key="frame" x="20" y="292" width="560" height="17"/>
|
||||||
|
<color key="backgroundColor" white="1" alpha="1" colorSpace="calibratedWhite"/>
|
||||||
|
<fontDescription key="fontDescription" type="system" size="system"/>
|
||||||
|
<color key="textColor" cocoaTouchSystemColor="darkTextColor"/>
|
||||||
|
<nil key="highlightedColor"/>
|
||||||
|
</label>
|
||||||
|
</subviews>
|
||||||
|
<color key="backgroundColor" white="1" alpha="1" colorSpace="custom" customColorSpace="calibratedWhite"/>
|
||||||
|
<constraints>
|
||||||
|
<constraint firstItem="Lei-5M-9Gs" firstAttribute="leading" secondItem="MMQ-IT-qOo" secondAttribute="leading" constant="20" symbolic="YES" id="62x-JV-TTJ"/>
|
||||||
|
<constraint firstItem="Lei-5M-9Gs" firstAttribute="centerY" secondItem="MMQ-IT-qOo" secondAttribute="centerY" id="JzS-HC-Rnl"/>
|
||||||
|
<constraint firstAttribute="trailing" secondItem="Lei-5M-9Gs" secondAttribute="trailing" constant="20" symbolic="YES" id="pXB-RP-Zz6"/>
|
||||||
|
</constraints>
|
||||||
|
</view>
|
||||||
|
<navigationItem key="navigationItem" title="Detail" id="cra-N8-TIN"/>
|
||||||
|
<connections>
|
||||||
|
<outlet property="detailDescriptionLabel" destination="Lei-5M-9Gs" id="sCT-F7-F6f"/>
|
||||||
|
</connections>
|
||||||
|
</viewController>
|
||||||
|
<placeholder placeholderIdentifier="IBFirstResponder" id="lrm-kH-fPn" sceneMemberID="firstResponder"/>
|
||||||
|
</objects>
|
||||||
|
<point key="canvasLocation" x="1343" y="64"/>
|
||||||
|
</scene>
|
||||||
|
</scenes>
|
||||||
|
</document>
|
||||||
45
HardcoreDataDemo/HardcoreDataDemo/DetailViewController.swift
Normal file
45
HardcoreDataDemo/HardcoreDataDemo/DetailViewController.swift
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
//
|
||||||
|
// DetailViewController.swift
|
||||||
|
// HardcoreDataDemo
|
||||||
|
//
|
||||||
|
// Created by John Rommel Estropia on 2015/05/02.
|
||||||
|
// Copyright (c) 2015 John Rommel Estropia. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
import UIKit
|
||||||
|
|
||||||
|
class DetailViewController: UIViewController {
|
||||||
|
|
||||||
|
@IBOutlet weak var detailDescriptionLabel: UILabel!
|
||||||
|
|
||||||
|
|
||||||
|
var detailItem: AnyObject? {
|
||||||
|
didSet {
|
||||||
|
// Update the view.
|
||||||
|
self.configureView()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func configureView() {
|
||||||
|
// Update the user interface for the detail item.
|
||||||
|
if let detail: AnyObject = self.detailItem {
|
||||||
|
if let label = self.detailDescriptionLabel {
|
||||||
|
label.text = detail.valueForKey("timeStamp")!.description
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
override func viewDidLoad() {
|
||||||
|
super.viewDidLoad()
|
||||||
|
// Do any additional setup after loading the view, typically from a nib.
|
||||||
|
self.configureView()
|
||||||
|
}
|
||||||
|
|
||||||
|
override func didReceiveMemoryWarning() {
|
||||||
|
super.didReceiveMemoryWarning()
|
||||||
|
// Dispose of any resources that can be recreated.
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
16
HardcoreDataDemo/HardcoreDataDemo/Event.swift
Normal file
16
HardcoreDataDemo/HardcoreDataDemo/Event.swift
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
//
|
||||||
|
// Event.swift
|
||||||
|
// HardcoreDataDemo
|
||||||
|
//
|
||||||
|
// Created by John Rommel Estropia on 2015/05/03.
|
||||||
|
// Copyright (c) 2015 John Rommel Estropia. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
import Foundation
|
||||||
|
import CoreData
|
||||||
|
|
||||||
|
class Event: NSManagedObject {
|
||||||
|
|
||||||
|
@NSManaged var timeStamp: NSDate
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>_XCCurrentVersionName</key>
|
||||||
|
<string>HardcoreDataDemo.xcdatamodel</string>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
||||||
@@ -0,0 +1,12 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
||||||
|
<model userDefinedModelVersionIdentifier="" type="com.apple.IDECoreDataModeler.DataModel" documentVersion="1.0" lastSavedToolsVersion="7549" systemVersion="14D136" minimumToolsVersion="Automatic" macOSVersion="Automatic" iOSVersion="Automatic">
|
||||||
|
<entity name="Event" representedClassName="HardcoreDataDemo.Event">
|
||||||
|
<attribute name="timeStamp" optional="YES" attributeType="Date">
|
||||||
|
<userInfo/>
|
||||||
|
</attribute>
|
||||||
|
<userInfo/>
|
||||||
|
</entity>
|
||||||
|
<elements>
|
||||||
|
<element name="Event" positionX="261" positionY="189" width="128" height="60"/>
|
||||||
|
</elements>
|
||||||
|
</model>
|
||||||
@@ -0,0 +1,38 @@
|
|||||||
|
{
|
||||||
|
"images" : [
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "29x29",
|
||||||
|
"scale" : "2x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "29x29",
|
||||||
|
"scale" : "3x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "40x40",
|
||||||
|
"scale" : "2x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "40x40",
|
||||||
|
"scale" : "3x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "60x60",
|
||||||
|
"scale" : "2x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "iphone",
|
||||||
|
"size" : "60x60",
|
||||||
|
"scale" : "3x"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"info" : {
|
||||||
|
"version" : 1,
|
||||||
|
"author" : "xcode"
|
||||||
|
}
|
||||||
|
}
|
||||||
50
HardcoreDataDemo/HardcoreDataDemo/Info.plist
Normal file
50
HardcoreDataDemo/HardcoreDataDemo/Info.plist
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>CFBundleDevelopmentRegion</key>
|
||||||
|
<string>en</string>
|
||||||
|
<key>CFBundleExecutable</key>
|
||||||
|
<string>$(EXECUTABLE_NAME)</string>
|
||||||
|
<key>CFBundleIdentifier</key>
|
||||||
|
<string>com.johnestropia.HardcoreDataDemo</string>
|
||||||
|
<key>CFBundleInfoDictionaryVersion</key>
|
||||||
|
<string>6.0</string>
|
||||||
|
<key>CFBundleName</key>
|
||||||
|
<string>$(PRODUCT_NAME)</string>
|
||||||
|
<key>CFBundlePackageType</key>
|
||||||
|
<string>APPL</string>
|
||||||
|
<key>CFBundleShortVersionString</key>
|
||||||
|
<string>1.0</string>
|
||||||
|
<key>CFBundleSignature</key>
|
||||||
|
<string>????</string>
|
||||||
|
<key>CFBundleVersion</key>
|
||||||
|
<string>1</string>
|
||||||
|
<key>LSRequiresIPhoneOS</key>
|
||||||
|
<true/>
|
||||||
|
<key>UILaunchStoryboardName</key>
|
||||||
|
<string>LaunchScreen</string>
|
||||||
|
<key>UIMainStoryboardFile</key>
|
||||||
|
<string>Main</string>
|
||||||
|
<key>UIRequiredDeviceCapabilities</key>
|
||||||
|
<array>
|
||||||
|
<string>armv7</string>
|
||||||
|
</array>
|
||||||
|
<key>UIStatusBarTintParameters</key>
|
||||||
|
<dict>
|
||||||
|
<key>UINavigationBar</key>
|
||||||
|
<dict>
|
||||||
|
<key>Style</key>
|
||||||
|
<string>UIBarStyleDefault</string>
|
||||||
|
<key>Translucent</key>
|
||||||
|
<false/>
|
||||||
|
</dict>
|
||||||
|
</dict>
|
||||||
|
<key>UISupportedInterfaceOrientations</key>
|
||||||
|
<array>
|
||||||
|
<string>UIInterfaceOrientationPortrait</string>
|
||||||
|
<string>UIInterfaceOrientationLandscapeLeft</string>
|
||||||
|
<string>UIInterfaceOrientationLandscapeRight</string>
|
||||||
|
</array>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
||||||
137
HardcoreDataDemo/HardcoreDataDemo/MasterViewController.swift
Normal file
137
HardcoreDataDemo/HardcoreDataDemo/MasterViewController.swift
Normal file
@@ -0,0 +1,137 @@
|
|||||||
|
//
|
||||||
|
// MasterViewController.swift
|
||||||
|
// HardcoreDataDemo
|
||||||
|
//
|
||||||
|
// Created by John Rommel Estropia on 2015/05/02.
|
||||||
|
// Copyright (c) 2015 John Rommel Estropia. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
import UIKit
|
||||||
|
import HardcoreData
|
||||||
|
|
||||||
|
|
||||||
|
// MARK: - MasterViewController
|
||||||
|
|
||||||
|
class MasterViewController: UITableViewController, ManagedObjectListObserver {
|
||||||
|
|
||||||
|
// MARK: UIViewController
|
||||||
|
|
||||||
|
override func viewDidLoad() {
|
||||||
|
|
||||||
|
super.viewDidLoad()
|
||||||
|
|
||||||
|
self.navigationItem.leftBarButtonItem = self.editButtonItem()
|
||||||
|
self.navigationItem.rightBarButtonItem = UIBarButtonItem(barButtonSystemItem: .Add, target: self, action: "addBarButtonItemTouched:")
|
||||||
|
|
||||||
|
self.list.addObserver(self)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// MARK: UITableViewController
|
||||||
|
|
||||||
|
required init!(coder aDecoder: NSCoder!) {
|
||||||
|
|
||||||
|
HardcoreData.defaultStack.addSQLiteStore()
|
||||||
|
self.list = HardcoreData.defaultStack.observeObjectList(
|
||||||
|
From(Event),
|
||||||
|
SortedBy(.Ascending("timeStamp"))
|
||||||
|
)
|
||||||
|
super.init(coder: aDecoder)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// MARK: UITableViewDataSource
|
||||||
|
|
||||||
|
override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
|
||||||
|
|
||||||
|
return self.list.numberOfSections()
|
||||||
|
}
|
||||||
|
|
||||||
|
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
|
||||||
|
|
||||||
|
return self.list.numberOfItemsInSection(section)
|
||||||
|
}
|
||||||
|
|
||||||
|
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
|
||||||
|
|
||||||
|
let cell = tableView.dequeueReusableCellWithIdentifier("UITableViewCell") as! UITableViewCell
|
||||||
|
cell.textLabel?.text = "\(self.list[indexPath].timeStamp)"
|
||||||
|
return cell
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// MARK: UITableViewDelegate
|
||||||
|
|
||||||
|
// override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
|
||||||
|
//
|
||||||
|
// super.tableView(tableView, didSelectRowAtIndexPath: indexPath)
|
||||||
|
// }
|
||||||
|
|
||||||
|
override func tableView(tableView: UITableView, commitEditingStyle editingStyle: UITableViewCellEditingStyle, forRowAtIndexPath indexPath: NSIndexPath) {
|
||||||
|
|
||||||
|
switch editingStyle {
|
||||||
|
|
||||||
|
case .Delete:
|
||||||
|
let event = self.list[indexPath]
|
||||||
|
HardcoreData.beginAsynchronous{ (transaction) -> Void in
|
||||||
|
|
||||||
|
transaction.delete(transaction.fetch(event)!)
|
||||||
|
transaction.commit { (result) -> Void in }
|
||||||
|
}
|
||||||
|
|
||||||
|
default:
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// optional func tableView(tableView: UITableView, moveRowAtIndexPath sourceIndexPath: NSIndexPath, toIndexPath destinationIndexPath: NSIndexPath)
|
||||||
|
|
||||||
|
|
||||||
|
// MARK: ManagedObjectListObserver
|
||||||
|
|
||||||
|
func managedObjectListWillChange(listController: ManagedObjectListController<Event>) {
|
||||||
|
|
||||||
|
self.tableView.beginUpdates()
|
||||||
|
}
|
||||||
|
|
||||||
|
func managedObjectList(listController: ManagedObjectListController<Event>, didInsertObject object: Event, toIndexPath indexPath: NSIndexPath) {
|
||||||
|
|
||||||
|
self.tableView.insertRowsAtIndexPaths([indexPath], withRowAnimation: .Automatic)
|
||||||
|
}
|
||||||
|
|
||||||
|
func managedObjectList(listController: ManagedObjectListController<Event>, didDeleteObject object: Event, fromIndexPath indexPath: NSIndexPath) {
|
||||||
|
|
||||||
|
self.tableView.deleteRowsAtIndexPaths([indexPath], withRowAnimation: .Automatic)
|
||||||
|
}
|
||||||
|
|
||||||
|
func managedObjectList(listController: ManagedObjectListController<Event>, didUpdateObject object: Event, atIndexPath indexPath: NSIndexPath) {
|
||||||
|
|
||||||
|
self.tableView.reloadRowsAtIndexPaths([indexPath], withRowAnimation: .Automatic)
|
||||||
|
}
|
||||||
|
|
||||||
|
func managedObjectList(listController: ManagedObjectListController<Event>, didMoveObject object: Event, fromIndexPath: NSIndexPath, toIndexPath: NSIndexPath) {
|
||||||
|
|
||||||
|
self.tableView.moveRowAtIndexPath(fromIndexPath, toIndexPath: toIndexPath)
|
||||||
|
}
|
||||||
|
|
||||||
|
func managedObjectListDidChange(listController: ManagedObjectListController<Event>) {
|
||||||
|
|
||||||
|
self.tableView.endUpdates()
|
||||||
|
}
|
||||||
|
|
||||||
|
// MARK: Private
|
||||||
|
|
||||||
|
let list: ManagedObjectListController<Event>
|
||||||
|
|
||||||
|
@objc dynamic func addBarButtonItemTouched(sender: AnyObject!) {
|
||||||
|
|
||||||
|
HardcoreData.beginAsynchronous { (transaction) -> Void in
|
||||||
|
|
||||||
|
let event = transaction.create(Event)
|
||||||
|
event.timeStamp = NSDate()
|
||||||
|
|
||||||
|
transaction.commit { (result) -> Void in }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@@ -0,0 +1,36 @@
|
|||||||
|
//
|
||||||
|
// HardcoreDataDemoTests.swift
|
||||||
|
// HardcoreDataDemoTests
|
||||||
|
//
|
||||||
|
// Created by John Rommel Estropia on 2015/05/02.
|
||||||
|
// Copyright (c) 2015 John Rommel Estropia. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
import UIKit
|
||||||
|
import XCTest
|
||||||
|
|
||||||
|
class HardcoreDataDemoTests: XCTestCase {
|
||||||
|
|
||||||
|
override func setUp() {
|
||||||
|
super.setUp()
|
||||||
|
// Put setup code here. This method is called before the invocation of each test method in the class.
|
||||||
|
}
|
||||||
|
|
||||||
|
override func tearDown() {
|
||||||
|
// Put teardown code here. This method is called after the invocation of each test method in the class.
|
||||||
|
super.tearDown()
|
||||||
|
}
|
||||||
|
|
||||||
|
func testExample() {
|
||||||
|
// This is an example of a functional test case.
|
||||||
|
XCTAssert(true, "Pass")
|
||||||
|
}
|
||||||
|
|
||||||
|
func testPerformanceExample() {
|
||||||
|
// This is an example of a performance test case.
|
||||||
|
self.measureBlock() {
|
||||||
|
// Put the code you want to measure the time of here.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
24
HardcoreDataDemo/HardcoreDataDemoTests/Info.plist
Normal file
24
HardcoreDataDemo/HardcoreDataDemoTests/Info.plist
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0">
|
||||||
|
<dict>
|
||||||
|
<key>CFBundleDevelopmentRegion</key>
|
||||||
|
<string>en</string>
|
||||||
|
<key>CFBundleExecutable</key>
|
||||||
|
<string>$(EXECUTABLE_NAME)</string>
|
||||||
|
<key>CFBundleIdentifier</key>
|
||||||
|
<string>com.johnestropia.$(PRODUCT_NAME:rfc1034identifier)</string>
|
||||||
|
<key>CFBundleInfoDictionaryVersion</key>
|
||||||
|
<string>6.0</string>
|
||||||
|
<key>CFBundleName</key>
|
||||||
|
<string>$(PRODUCT_NAME)</string>
|
||||||
|
<key>CFBundlePackageType</key>
|
||||||
|
<string>BNDL</string>
|
||||||
|
<key>CFBundleShortVersionString</key>
|
||||||
|
<string>1.0</string>
|
||||||
|
<key>CFBundleSignature</key>
|
||||||
|
<string>????</string>
|
||||||
|
<key>CFBundleVersion</key>
|
||||||
|
<string>1</string>
|
||||||
|
</dict>
|
||||||
|
</plist>
|
||||||
@@ -47,7 +47,7 @@ class HardcoreDataTests: XCTestCase {
|
|||||||
HardcoreData.defaultStack = stack
|
HardcoreData.defaultStack = stack
|
||||||
XCTAssert(HardcoreData.defaultStack === stack, "HardcoreData.defaultStack === stack")
|
XCTAssert(HardcoreData.defaultStack === stack, "HardcoreData.defaultStack === stack")
|
||||||
|
|
||||||
switch stack.addSQLiteStore("Config1Store.sqlite", configuration: "Config1", resetStoreOnMigrationFailure: true){
|
switch stack.addSQLiteStore("ConfigStore1.sqlite", configuration: "Config1", resetStoreOnMigrationFailure: true){
|
||||||
|
|
||||||
case .Failure(let error):
|
case .Failure(let error):
|
||||||
XCTFail(error.description)
|
XCTFail(error.description)
|
||||||
@@ -56,7 +56,7 @@ class HardcoreDataTests: XCTestCase {
|
|||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
|
||||||
switch stack.addSQLiteStore("Config2Store.sqlite", configuration: "Config2", resetStoreOnMigrationFailure: true){
|
switch stack.addSQLiteStore("ConfigStore2.sqlite", configuration: "Config2", resetStoreOnMigrationFailure: true){
|
||||||
|
|
||||||
case .Failure(let error):
|
case .Failure(let error):
|
||||||
XCTFail(error.description)
|
XCTFail(error.description)
|
||||||
|
|||||||
Reference in New Issue
Block a user