Post

Replies

Boosts

Views

Activity

Reply to [SwiftData] How to get the first 7 elements by using @Query?
If you create the query property using a FetchDescriptor then you can set a limit for the number of rows being fetched. The drawback of this solution is that it's not a one liner so you need to do it in the init @Query private var records:[Record] init() { var fetchDescriptor = FetchDescriptor<Record>(sortBy: [SortDescriptor(\Record.date, order: .reverse)]) fetchDescriptor.fetchLimit = 7 _categories = Query(fetchDescriptor) } If you for some reason don't want to do it in the init you could declare the fetch descriptor as a static variable and then pass it to the @Query declaration
Nov ’24
Reply to SwiftData error "Thread 1: Fatal error: Composite Coder only supports Keyed Container"
If you create a Color.Resolved value in a playground and encodes it you see you get an array of doubles rather than a structure with RGB properties and the error clearly states that an array (keyless container) is not supported. So I guess the conclusion is that Color.Resolved isn't supported by SwiftData. My playground test code and output let color = Color.red var resolvedColor: Color.Resolved resolvedColor = color.resolve(in: EnvironmentValues()) let data = try! JSONEncoder().encode(resolvedColor) print(String(data: data, encoding: .utf8)!) [1,0.23137254,0.18823528,1]
Topic: UI Frameworks SubTopic: SwiftUI Tags:
Nov ’24
Reply to SwiftData: Failed to decode a composite attribute
A migration is probably the best solution but if you don't want to do that you could use a custom decoding for the enum extension Kind { init(from decoder: any Decoder) throws { let container = try decoder.singleValueContainer() let rawValue = try container.decode(String.self) if let kind = Kind(rawValue: rawValue) { self = kind } else { let oldValue = rawValue.capitalized // <-- You might need to adjust this depending on how the rest of the enum looks. guard let kind = Kind(rawValue: oldValue) else { throw DecodingError.dataCorrupted(DecodingError.Context(codingPath: [], debugDescription: "Unknow kind: \(oldValue)")) } self = kind } } } Note that this will fix the value when read from storage but to actually store the new value, "Credit", each objects will need to be saved until it's persisted.
Nov ’24
Reply to SwiftData Predicates crashes when using Generic
There's a lot I don't understand about your question like what Reporter really is, how the ModelActor comes into play and what you mean with the last paragraph about the fetchAll method (did you write a "not" to much?) but one issue I see in your code is that you are passing PersistentModel objects from the detached Task to the UI which means you are passing them across actor boundaries and that is something you should not do since they are not conforming to Sendable. (Which swift version are you using and do you have any concurrency checking set?) This makes the whole solution look flawed and I would suggest that you instead fetch your objects on the MainActor using a @Query instead.
Dec ’24
Reply to SwiftData - Problems with Predicates and Relations
where does the content of filterHashtags come from?
Replies
Boosts
Views
Activity
Oct ’24
Reply to SwiftData thread-safety: passing models between threads
You should pass the id (persistentModelID), as you do in your code above, across actor boundaries and never the object itself.
Replies
Boosts
Views
Activity
Oct ’24
Reply to SwiftData - Problems with Predicates and Relations
But Hashtag and HashtagFilter are two different models so why should their persistentModelID values be equal? Your variable naming confused me.
Replies
Boosts
Views
Activity
Oct ’24
Reply to Type Eraser for Container
I am not sure exactly what you are asking but as far as the ModelContainer yo must supply all your model types, directly or indirectly, when you create the container object
Topic: UI Frameworks SubTopic: SwiftUI Tags:
Replies
Boosts
Views
Activity
Oct ’24
Reply to SwifttData Record Update
ModelContext has a property autosaveEnabled that you can set to false and then handle validation and save logic in a button action or something
Topic: UI Frameworks SubTopic: SwiftUI Tags:
Replies
Boosts
Views
Activity
Nov ’24
Reply to [SwiftData] How to get the first 7 elements by using @Query?
If you create the query property using a FetchDescriptor then you can set a limit for the number of rows being fetched. The drawback of this solution is that it's not a one liner so you need to do it in the init @Query private var records:[Record] init() { var fetchDescriptor = FetchDescriptor<Record>(sortBy: [SortDescriptor(\Record.date, order: .reverse)]) fetchDescriptor.fetchLimit = 7 _categories = Query(fetchDescriptor) } If you for some reason don't want to do it in the init you could declare the fetch descriptor as a static variable and then pass it to the @Query declaration
Replies
Boosts
Views
Activity
Nov ’24
Reply to SwiftData error "Thread 1: Fatal error: Composite Coder only supports Keyed Container"
If you create a Color.Resolved value in a playground and encodes it you see you get an array of doubles rather than a structure with RGB properties and the error clearly states that an array (keyless container) is not supported. So I guess the conclusion is that Color.Resolved isn't supported by SwiftData. My playground test code and output let color = Color.red var resolvedColor: Color.Resolved resolvedColor = color.resolve(in: EnvironmentValues()) let data = try! JSONEncoder().encode(resolvedColor) print(String(data: data, encoding: .utf8)!) [1,0.23137254,0.18823528,1]
Topic: UI Frameworks SubTopic: SwiftUI Tags:
Replies
Boosts
Views
Activity
Nov ’24
Reply to SwiftData: Failed to decode a composite attribute
A migration is probably the best solution but if you don't want to do that you could use a custom decoding for the enum extension Kind { init(from decoder: any Decoder) throws { let container = try decoder.singleValueContainer() let rawValue = try container.decode(String.self) if let kind = Kind(rawValue: rawValue) { self = kind } else { let oldValue = rawValue.capitalized // <-- You might need to adjust this depending on how the rest of the enum looks. guard let kind = Kind(rawValue: oldValue) else { throw DecodingError.dataCorrupted(DecodingError.Context(codingPath: [], debugDescription: "Unknow kind: \(oldValue)")) } self = kind } } } Note that this will fix the value when read from storage but to actually store the new value, "Credit", each objects will need to be saved until it's persisted.
Replies
Boosts
Views
Activity
Nov ’24
Reply to How to completely reset SwiftData?
Is this for a released app or only local in Xcode?
Replies
Boosts
Views
Activity
Nov ’24
Reply to SwiftData Crash: Incorrect actor executor assumption.
Why don't you use the @ModelActor macro instead? @ModelActor actor ConcurrentDatabase { private func save() { if self.modelContext.hasChanges { do { try self.modelContext.save() } catch { ... } } } }
Replies
Boosts
Views
Activity
Dec ’24
Reply to SwiftData Predicates crashes when using Generic
There's a lot I don't understand about your question like what Reporter really is, how the ModelActor comes into play and what you mean with the last paragraph about the fetchAll method (did you write a "not" to much?) but one issue I see in your code is that you are passing PersistentModel objects from the detached Task to the UI which means you are passing them across actor boundaries and that is something you should not do since they are not conforming to Sendable. (Which swift version are you using and do you have any concurrency checking set?) This makes the whole solution look flawed and I would suggest that you instead fetch your objects on the MainActor using a @Query instead.
Replies
Boosts
Views
Activity
Dec ’24
Reply to SwiftData Query filter().first crashed in iOS18.2
It would help if you provided a more complete code sample. For instance what is in that where condition?
Topic: Programming Languages SubTopic: Swift Tags:
Replies
Boosts
Views
Activity
Dec ’24
Reply to Model instance invalidated, backing data could no longer be found in the store
It could be an issue with how you handle ModelContainer in your code or possibly how you handle your ModelContext object(s)
Topic: Programming Languages SubTopic: Swift Tags:
Replies
Boosts
Views
Activity
Dec ’24
Reply to Can't batch delete with one-to-many to self relationship
This seems like expected behavior to me and not a bug.
Replies
Boosts
Views
Activity
Jan ’25
Reply to SwiftData Query and optional relationships
It makes no sense to sort against handlers.first (or at all against a to-many relationship) so I would remove this requirement
Topic: UI Frameworks SubTopic: SwiftUI Tags:
Replies
Boosts
Views
Activity
Jan ’25