From c15288a90f6b891cd5eb8999344eae77c9f4ed68 Mon Sep 17 00:00:00 2001 From: Zach Date: Wed, 2 Oct 2024 17:20:50 -0600 Subject: [PATCH] Update FileState MainActor usage (#108) --- Sources/AppState/PropertyWrappers/State/FileState.swift | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/Sources/AppState/PropertyWrappers/State/FileState.swift b/Sources/AppState/PropertyWrappers/State/FileState.swift index d2e6e03..29db6cb 100644 --- a/Sources/AppState/PropertyWrappers/State/FileState.swift +++ b/Sources/AppState/PropertyWrappers/State/FileState.swift @@ -5,7 +5,6 @@ import SwiftUI #endif /// `FileState` is a property wrapper allowing SwiftUI views to subscribe to Application's state changes in a reactive way. State is stored using `FileManager`. Works similar to `State` and `Published`. -@MainActor @propertyWrapper public struct FileState { #if !os(Linux) && !os(Windows) /// Holds the singleton instance of `Application`. @@ -25,6 +24,7 @@ import SwiftUI private let column: Int /// Represents the current value of the `FileState`. + @MainActor public var wrappedValue: Value { get { Application.fileState( @@ -51,6 +51,7 @@ import SwiftUI #if !os(Linux) && !os(Windows) /// A binding to the `State`'s value, which can be used with SwiftUI views. + @MainActor public var projectedValue: Binding { Binding( get: { wrappedValue }, @@ -64,6 +65,7 @@ import SwiftUI - Parameter keyPath: The `KeyPath` for accessing `FileState` in Application. */ + @MainActor public init( _ keyPath: KeyPath>, _ fileID: StaticString = #fileID, @@ -80,6 +82,7 @@ import SwiftUI #if !os(Linux) && !os(Windows) /// A property wrapper's synthetic storage property. This is just for SwiftUI to mutate the `wrappedValue` and send event through `objectWillChange` publisher when the `wrappedValue` changes + @MainActor public static subscript( _enclosingInstance observed: OuterSelf, wrapped wrappedKeyPath: ReferenceWritableKeyPath,