Zomp.SyncMethodGenerator 1.1.2

There is a newer version of this package available.
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                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Zomp.SyncMethodGenerator" Version="1.1.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Zomp.SyncMethodGenerator --version 1.1.2                
#r "nuget: Zomp.SyncMethodGenerator, 1.1.2"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// 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

Build Support .NET Standard 2.0 Nuget codecov

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:

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
There are no supported framework assets in this package.

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