Skip to content

Code Quality: Convert into await using statement or declaration #15092

@gumbarros

Description

@gumbarros

Description

using (var stream = File.OpenRead(_item.ItemPath))

to

await using (var stream = File.OpenRead(_item.ItemPath))					

In .NET, classes that own unmanaged resources usually implement the IDisposable interface to provide a mechanism for releasing unmanaged resources synchronously. However, in some cases they need to provide an asynchronous mechanism for releasing unmanaged resources in addition to (or instead of) the synchronous one. Providing such a mechanism enables the consumer to perform resource-intensive dispose operations without blocking the main thread of a GUI application for a long time.

The IAsyncDisposable.DisposeAsync method of this interface returns a ValueTask that represents the asynchronous dispose operation. Classes that own unmanaged resources implement this method, and the consumer of these classes calls this method on an object when it is no longer needed.

Source: https://stackoverflow.com/questions/58610350/what-is-the-difference-between-using-and-await-using-and-how-can-i-decide-which

Concerned code

Generated using Jetbrains Rider:

<platforms><Files.App>\Utils\Storage\StorageItems\VirtualStorageItem.cs (1 issue)
<platforms><Files.App>\Utils\Storage\StorageBaseItems\BaseStorageFile.cs (1 issue)
<platforms><Files.App>\Utils\Shell\LaunchHelper.cs (2 issues)
<platforms><Files.App>\Utils\Storage\StorageItems\ZipStorageFile.cs (7 issues)
<platforms><Files.App>\Utils\Storage\StorageItems\VirtualStorageFile.cs (4 issues)
<platforms><Files.App>\Utils\Storage\Operations\ShellFilesystemOperations.cs (4 issues)
<platforms><Files.App>\Utils\Storage\StorageItems\ZipStorageFolder.cs (9 issues)
<platforms><Files.App>\Utils\Storage\StorageItems\NativeStorageFile.cs (4 issues)
<platforms><Files.App>\Utils\Storage\StorageItems\SystemStorageFile.cs (9 issues)
<platforms><Files.App>\ViewModels\Properties\HashesViewModel.cs (1 issue)
<platforms><Files.App>\Utils\Storage\StorageItems\FtpStorageFile.cs (3 issues)
<platforms><Files.App>\Utils\Cloud\Detector\SynologyDriveCloudDetector.cs (3 issues)
<platforms><Files.App>\Utils\Cloud\Detector\GoogleDriveCloudDetector.cs (3 issues)
<platforms><Files.App>\Services\SideloadUpdateService.cs (2 issues)
<platforms><Files.App>\Services\UpdateService.cs (2 issues)
<platforms><Files.App>\Extensions\ImageSourceExtensions.cs (1 issue)

Gains

  • UI will not freeze while disposing a resource

Requirements

  • Convert all asynchronous using to async using

Comments

image

It's possible to make a single PR using this button :)

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Projects

    Status

    ✅ Done

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions