The NSPersistent Document class is a subclass of NSDocument that is designed to easily integrate into the Core Data framework. It provides methods to access a document-wide NSManaged Object Context object, and provides default implementations of methods to read and write files using the persistence framework. In a persistent document, the undo manager.

< How to read the Digital Crown on watchOS using digitalCrownRotation()How to configure Core Data to work with SwiftUI >
Core

Paul Hudson@twostraws

Fully updated for Xcode 11.4

As two massive pieces of Apple’s software platform, it won’t surprise you to learn that Core Data and SwiftUI have been written to work well together: we get property wrappers, environment support, and more, all to make sure we can integrate Core Data into our SwiftUI apps with the least hassle.

Before SwiftUI it was common to find a range of ways you might find Core Data being used from an architectural perspective – Apple strongly encouraged us to create containers at the AppDelegate level then reach back up as needed, others preferred using manager classes, and some preferred abstracting Core Data away entirely so they had the freedom to move to Realm or other options at a later date.

However, SwiftUI’s integration with Core Data is different because it points very strongly in one direction: create the Core Data container once when the app starts, inject its managed object context into the environment, then perform fetch requests directly on there.

This isn’t me guessing – Apple literally designed it in a highly specific way, and if you want to take advantage of all the features of SwiftUI’s Core Data integration then you ought to follow the path Apple is laying down for us.

Here are the four specific features that will help you see what I mean:

  1. NSManagedObject conforms to the ObservableObject protocol, which means we can bind any object to part of our user interface.
  2. There’s a managedObjectContext key in the environment designed to store our active Core Data managed object context.
  3. Xcode’s template then injects that context into the initial content view inside the scene delegate.
  4. There’s a @FetchRequest property wrapper that uses the environment’s managed object context to perform fetch requests.

So, we create a managed object context when the app launches, attach it to the environment for our views, then use @FetchRequest to load data for the app to use.

SPONSOREDBuild better iOS apps, faster. Looking for a great mobile CI/CD solution that has tons of iOS-specific tools, smooth code signing, and even real device testing? Learn more about Bitrise’s iOS-specific solutions.

Explore games for macOS tagged Dungeon Crawler on itch.io Find games for macOS tagged Dungeon Crawler like Tension, Pixel Dungeon, Lost Perspective, Red Rogue, Heavens Below on itch.io, the indie game hosting marketplace. Free dungeon crawler games for mac. Browse the newest, top selling and discounted Dungeon Crawler products on Steam. New and Trending. Results exclude some products based on your preferences. Dungeon Crawlers for Mac. A classic genre, dungeon crawlers spawned directly from tabletop role playing games such as Dungeon & Dragons, with early games in the genre often requiring just as much imagination to fully immerse yourself into the worlds they conveyed. Many a franchise got its start in this genre, including The Elder Scrolls. The best 50 Dungeon-crawler games for Mac OS daily generated by our specialised A.I. Comparing over 40 000 video games across all platforms. This list includes 7 Mages, Legend of Grimrock, The Enchanted Cave 2, Crawl and 46 more for Mac OS.

Similar solutions…

< How to read the Digital Crown on watchOS using digitalCrownRotation()How to configure Core Data to work with SwiftUI >
Following the steps in 'Create a Custom Class' section, I added the Employee class, changed the Model Key Path, in the binding of contentValues of the manager pop-up menu, to fullNameAndID.
However, when built & go, the code snippet given above will cause a warning as described in the comment. The built is successful, with the compication that the pop-up menu doesn't update the fullNameAndID accordingly. I figured it could have something to do with the formatting string. So referenced relevant document, then found that '%@' could be used with any object. This led me to thought that maybe it's because that employeeID is defined as an integer 32 in the data model. Then I tried to change the last %@ to '%d', but the warning still showed up.
After all that, I'm stuck. So, could anyone help me out with this?!
Thank you very much!
--- Sherlock Asimov

12' Powerbook G4 M9691, Mac OS X (10.5)

Posted on