-
Notifications
You must be signed in to change notification settings - Fork 278
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Write configs asynchronously, first part of async API rewrite #1510
base: master
Are you sure you want to change the base?
Conversation
To prevent double writes, any queued io operations should have a cancellation token before committing and care must be taken before creating a new write task to make sure that only one queued write exists at the same time. An example of that would be an older write operation overwriting a newer one if its thread had to be stalled for any reason |
#pragma warning disable CS0618 // Type or member is obsolete | ||
await this.configs.SaveAsync(currentConfig, this.plugin.InternalName, this.plugin.Manifest.WorkingPluginId); | ||
#pragma warning restore CS0618 // Type or member is obsolete |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
These pragmas are unnecessary, SaveAsync
is not obsolete.
@@ -508,7 +514,8 @@ private void Save() | |||
{ | |||
ThreadSafety.AssertMainThread(); | |||
|
|||
Service<ReliableFileStorage>.Get().WriteAllText( | |||
this.writeTask?.Wait(); | |||
this.writeTask = Service<ReliableFileStorage>.Get().WriteAllTextAsync( | |||
this.configPath, JsonConvert.SerializeObject(this, SerializerSettings)); | |||
this.DalamudConfigurationSaved?.Invoke(this); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We'll be invoking DalamudConfigurationSaved
before the save actually completes. This seems fine, given that the only use I can see is updating DalamudPluginInterface#GeneralChatType
, but it does feel like a behavioral change that should at least be noted.
Are you referring to something specific, or are you saying that the system should handle this? I'm waiting for these tasks in the two spots I'm using this now before kicking off another, so this shouldn't be an issue, error handling isn't great but I wanted to get this in for the patch. I'll go over it again when this is going to be a public API. |
Should fix some microstuttering complaints we have been getting. Reads aren't async yet, they definitely should be, but they should take the same code path as before the VFS in 99.9% of cases so it doesn't matter at the moment.