Zomp.SyncMethodGenerator
1.1.2
See the version list below for details.
dotnet add package Zomp.SyncMethodGenerator --version 1.1.2
NuGet\Install-Package Zomp.SyncMethodGenerator -Version 1.1.2
<PackageReference Include="Zomp.SyncMethodGenerator" Version="1.1.2" />
paket add Zomp.SyncMethodGenerator --version 1.1.2
#r "nuget: Zomp.SyncMethodGenerator, 1.1.2"
// Install Zomp.SyncMethodGenerator as a Cake Addin #addin nuget:?package=Zomp.SyncMethodGenerator&version=1.1.2 // Install Zomp.SyncMethodGenerator as a Cake Tool #tool nuget:?package=Zomp.SyncMethodGenerator&version=1.1.2
Sync Method Generator
This .NET source generator produces a sync method from an async one.
Use cases
- A library which exposes both sync and async version of a method
- An application has to process two kinds of data in the same way:
- Large data from I/O which cannot be stored in memory before processing: Original async method
- Small sample of data in memory, usually a sample of the larger data: Generated sync method
How it works
CreateSyncVersionAttribute
Add CreateSyncVersionAttribute
to your async method in your partial
class
[Zomp.SyncMethodGenerator.CreateSyncVersion]
static async Task WriteAsync(ReadOnlyMemory<byte> buffer, Stream stream,
CancellationToken ct)
=> await stream.WriteAsync(buffer, ct).ConfigureAwait(true);
And it will generate a sync version of the method:
static void Write(ReadOnlySpan<byte> buffer, Stream stream)
=> stream.Write(buffer);
A list of changes applied to the new synchronized method:
Remove async modifier
Remove await from methods as well as
foreach
statementChange types
From To Task or ValueTask void Task<T> or ValueTask<T> T IAsyncEnumerable<T> IEnumerable<T> IAsyncEnumerator<T> IEnumerator<T> Memory<T> Span<T> ReadOnlyMemory<T> ReadOnlySpan<T> Remove parameters
Invocation changes
- Remove ConfigureAwait
- Remove WithCancellation
- Rewrite asynchronous invocations with
Async
suffix to call synchronous version (e.g. MoveNextAsync() becomes MoveNext()) - Remove asynchronous invocations without the
Async
suffix - Remove CancellationToken parameter
- Remove IProgress<T>.Report(T) call
- Remove Memory<T>.Span property
Remove
CreateSyncVersionAttribute
Update XML documentation
SYNC_ONLY symbol
In case there is logic which should only be executed in the synchronized version of the method, wrap it in SYNC_ONLY
#if directive.
SYNC_ONLY
must not be defined anywhere. The source generator will scan #if directives for this symbol.
Code inside SYNC_ONLY
block will be copied as is. Unless global namespaces are used in the project, this code should contain fully qualified namespaces.
The following syntax:
[Zomp.SyncMethodGenerator.CreateSyncVersion]
public async Task WithSyncOnlyDirectiveAsync(CancellationToken ct)
{
#if SYNC_ONLY
System.Console.Write("Sync");
#endif
await Task.CompletedTask;
}
will output:
public void WithSyncOnlyDirective()
{
System.Console.Write("Sync");
}
If you only want to execute in the original async version, flip the flag like this: #if !SYNC_ONLY
.
Note: SYNC_ONLY
cannot be mixed with other symbols in a conditional expression and cannot have #elif
directive.
Installation
To add the library use:
dotnet add package Zomp.SyncMethodGenerator
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (2)
Showing the top 2 popular GitHub repositories that depend on Zomp.SyncMethodGenerator:
Repository | Stars |
---|---|
Zeugma440/atldotnet
Fully managed, portable and easy-to-use C# library to read and edit audio data and metadata (tags) from various audio formats, playlists and CUE sheets
|
|
SineVector241/VoiceCraft-MCBE_Proximity_Chat
VoiceCraft software to implement proximity VC for Minecraft Bedrock Edition
|
Version | Downloads | Last updated |
---|---|---|
1.4.15 | 429 | 11/17/2024 |
1.4.14 | 880 | 8/7/2024 |
1.4.13 | 744 | 7/21/2024 |
1.4.11 | 699 | 7/15/2024 |
1.4.10 | 617 | 7/13/2024 |
1.4.8 | 273 | 7/8/2024 |
1.4.3 | 238 | 6/27/2024 |
1.4.1 | 262 | 5/21/2024 |
1.3.44 | 207 | 5/14/2024 |
1.3.43 | 282 | 4/26/2024 |
1.3.40 | 491 | 4/11/2024 |
1.3.39 | 239 | 4/9/2024 |
1.3.38 | 372 | 3/23/2024 |
1.3.36 | 207 | 3/20/2024 |
1.3.35 | 86 | 3/19/2024 |
1.3.33 | 163 | 3/18/2024 |
1.3.28 | 160 | 3/18/2024 |
1.3.27 | 187 | 3/17/2024 |
1.3.24 | 376 | 3/12/2024 |
1.3.23 | 230 | 3/12/2024 |
1.3.21 | 189 | 3/11/2024 |
1.3.20 | 220 | 3/11/2024 |
1.3.18 | 189 | 3/10/2024 |
1.3.17 | 266 | 2/26/2024 |
1.3.16 | 303 | 2/26/2024 |
1.3.13 | 215 | 2/25/2024 |
1.3.8-beta | 238 | 2/12/2024 |
1.3.6 | 284 | 1/26/2024 |
1.3.5 | 202 | 1/21/2024 |
1.3.1 | 301 | 1/17/2024 |
1.2.24 | 213 | 1/14/2024 |
1.2.18 | 181 | 1/5/2024 |
1.2.16 | 212 | 1/5/2024 |
1.2.13 | 185 | 1/4/2024 |
1.2.12 | 182 | 1/4/2024 |
1.2.8 | 181 | 1/3/2024 |
1.2.3 | 431 | 11/20/2023 |
1.2.1 | 196 | 11/13/2023 |
1.1.2 | 1,408 | 8/8/2023 |
1.0.14 | 271 | 8/4/2023 |
1.0.12 | 30,658 | 8/3/2023 |
1.0.11 | 242 | 8/2/2023 |
1.0.5 | 164 | 7/31/2023 |
1.0.3 | 154 | 7/29/2023 |
1.0.2 | 169 | 7/29/2023 |
1.0.1 | 233 | 7/27/2023 |
0.1.39-alpha | 512 | 1/25/2023 |
0.1.38-alpha | 241 | 1/19/2023 |
0.1.37-alpha | 235 | 1/19/2023 |
0.1.34-alpha | 226 | 1/18/2023 |
0.1.33-alpha | 205 | 1/15/2023 |
0.1.30-alpha | 266 | 11/21/2022 |
0.1.22-alpha | 226 | 11/19/2022 |
0.1.21-alpha | 224 | 11/19/2022 |
0.1.19-alpha | 200 | 11/19/2022 |
0.1.18-alpha | 235 | 11/18/2022 |
0.1.17-alpha | 305 | 11/14/2022 |
0.1.13-alpha | 211 | 11/13/2022 |
0.1.12-alpha | 254 | 10/31/2022 |
0.1.10-alpha | 203 | 10/28/2022 |
0.1.9-alpha | 249 | 10/27/2022 |
0.1.8-alpha | 275 | 10/27/2022 |
0.1.5-alpha | 225 | 10/27/2022 |
0.1.4-alpha | 251 | 10/27/2022 |
0.1.3-alpha | 272 | 10/26/2022 |
0.1.2-alpha | 272 | 10/25/2022 |
0.1.1-alpha | 297 | 10/25/2022 |