domportera.NetJsonAOT
0.1.3-alpha
Prefix Reserved
dotnet add package domportera.NetJsonAOT --version 0.1.3-alpha
NuGet\Install-Package domportera.NetJsonAOT -Version 0.1.3-alpha
<PackageReference Include="domportera.NetJsonAOT" Version="0.1.3-alpha" />
paket add domportera.NetJsonAOT --version 0.1.3-alpha
#r "nuget: domportera.NetJsonAOT, 0.1.3-alpha"
// 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;
}
}
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.1
- Microsoft.CodeAnalysis.CSharp (>= 4.10.0)
- System.Text.Json (>= 8.0.5)
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 | 59 | 10/30/2024 |