domportera.NetJsonAOT 0.1.3-alpha

Prefix Reserved
This is a prerelease version of domportera.NetJsonAOT.
dotnet add package domportera.NetJsonAOT --version 0.1.3-alpha                
NuGet\Install-Package domportera.NetJsonAOT -Version 0.1.3-alpha                
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="domportera.NetJsonAOT" Version="0.1.3-alpha" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add domportera.NetJsonAOT --version 0.1.3-alpha                
#r "nuget: domportera.NetJsonAOT, 0.1.3-alpha"                
#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 domportera.NetJsonAOT as a Cake Addin
#addin nuget:?package=domportera.NetJsonAOT&version=0.1.3-alpha&prerelease

// Install domportera.NetJsonAOT as a Cake Tool
#tool nuget:?package=domportera.NetJsonAOT&version=0.1.3-alpha&prerelease                

.NET JSON AOT

This project is a source generator that allows you to easily use System.Text.JSON in your AOT projects.

This is in very early stages, but is working. Currently, the incremental generator does not work due to the evil things going on in here to make the native JSON source generators run before this one, however build-time source generation does work.

In order to reference this in your project, find it on nuget and add the following tags to your csproj's package reference:

<ItemGroup>
    <PackageReference Include="domportera.NetJsonAOT" OutputItemType="Analyzer" ReferenceOutputAssembly="false" />
</ItemGroup>

In order to serialize an AOT class, decorate it with a System.Serializable attribute, like this:

[Serializable]
internal class MyClass
{
    public float MyGuy;
}

The source generator will seek out types tagged as Serializable to generate the proper classes.

This also creates a static NetJsonAOT class for your convenience.

using NetJsonAOT; // this is actually a reference to a namespace generated within your project - every project has its own internal NetJsonAot class

void SomeMethod()
{
    // this is a dictionary of your type (key) to the generated JsonSerializerContext types
    var typeDictionary = RuntimeJson.JsonContextTypes;

    // this is a dictionary of your type (key) to actual instances of their respective JsonSerializerContext types
    var contexts = RuntimeJson.JsonContexts;


    // this is a dictionary of your type (key) to instances of JsonSerializerOptions, ready to be used in actual serialization & deserialization
    var options = RuntimeJson.JsonSerializerOptions;
}

// example deserialization - serialization should be very similar
bool Deserialize<T>(string json, [NotNullWhen(true)] out T? result, [NotNullWhen(false)] out string? reason)
{

    var gotOption = RuntimeJson.JsonSerializerOptions.TryGetValue(type, out var options);

    if(!gotOptions)
    {
        Console.WriteLine("Woah there, this might not work with aot....");
        // return false;
    }

    try
    {
        value = JsonSerializer.Deserialize(s, type, options);

        if (value == null)
        {
            reason = $"Could not convert {s} to {type.Name}";
            return false;
        }

        reason = null;
        return true;
    }
    catch (JsonException e)
    {
        value = default!;
        reason = $"Could not convert json to {type.Name} - exception thrown: {e.Message}.\n'{s}'";
        return false;
    }
    catch (Exception e)
    {
        value = default!;
        reason = $"Unexpected exception thrown: {e.Message}.\n'{s}'";
        return false;
    }
}
There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.1.3-alpha 50 10/30/2024