diff Simoleon/Helpers/Persistence.swift @ 171:70f0625bfcf1

Merge pull request #17 from denniscm190/development open source project committer: GitHub <noreply@github.com>
author Dennis C. M. <dennis@denniscm.com>
date Tue, 12 Oct 2021 16:17:35 +0200
parents Simoleon/Persistence.swift@ecc58b9cd89d Simoleon/Persistence.swift@1940db1ef321
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Simoleon/Helpers/Persistence.swift	Tue Oct 12 16:17:35 2021 +0200
@@ -0,0 +1,66 @@
+//
+//  Persistence.swift
+//  Simoleon
+//
+//  Created by Dennis Concepción Martín on 08/07/2021.
+//
+
+import CoreData
+
+struct PersistenceController {
+    static let shared = PersistenceController()
+    
+    static var preview: PersistenceController = {
+        let result = PersistenceController(inMemory: true)
+        let viewContext = result.container.viewContext
+        
+        for _ in 0..<10 {
+            let favoritePair = FavoritePair(context: viewContext)
+            favoritePair.baseSymbol = "USD"
+            favoritePair.quoteSymbol = "EUR"
+        }
+        
+        do {
+            try viewContext.save()
+        } catch {
+            /*
+             Replace this implementation with code to handle the error appropriately.
+             fatalError() causes the application to generate a crash log and terminate.
+             You should not use this function in a shipping application, although it may be useful during development.
+             */
+            let nsError = error as NSError
+            fatalError("Unresolved error \(nsError), \(nsError.userInfo)")
+        }
+        return result
+    }()
+    
+    let container: NSPersistentCloudKitContainer
+    
+    init(inMemory: Bool = false) {
+        container = NSPersistentCloudKitContainer(name: "Simoleon")
+        container.viewContext.automaticallyMergesChangesFromParent = true
+        container.viewContext.mergePolicy = NSMergeByPropertyStoreTrumpMergePolicy
+        if inMemory {
+            container.persistentStoreDescriptions.first!.url = URL(fileURLWithPath: "/dev/null")
+        }
+        container.loadPersistentStores(completionHandler: { (storeDescription, error) in
+            if let error = error as NSError? {
+                /*
+                 Replace this implementation with code to handle the error appropriately.
+                 fatalError() causes the application to generate a crash log and terminate.
+                 You should not use this function in a shipping application, although it may be useful during development.
+                 */
+                
+                /*
+                 Typical reasons for an error here include:
+                 * The parent directory does not exist, cannot be created, or disallows writing.
+                 * The persistent store is not accessible, due to permissions or data protection when the device is locked.
+                 * The device is out of space.
+                 * The store could not be migrated to the current model version.
+                 Check the error message to determine what the actual problem was.
+                 */
+                fatalError("Unresolved error \(error), \(error.userInfo)")
+            }
+        })
+    }
+}