Coplt.Arches 0.5.0

dotnet add package Coplt.Arches --version 0.5.0                
NuGet\Install-Package Coplt.Arches -Version 0.5.0                
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="Coplt.Arches" Version="0.5.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Coplt.Arches --version 0.5.0                
#r "nuget: Coplt.Arches, 0.5.0"                
#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 Coplt.Arches as a Cake Addin
#addin nuget:?package=Coplt.Arches&version=0.5.0

// Install Coplt.Arches as a Cake Tool
#tool nuget:?package=Coplt.Arches&version=0.5.0                

Coplt.Arches

Nuget

Archetype is a dynamic structure
This library includes dynamic archetype emit and access method emit
This is not ECS, but you can use it to implement an archetype based ECS

Example

struct Foo
{
    public int a;
    public int b;
}

struct Tag;


ArcheTypeMeta arch = ArcheTypes.EmitArcheType(
[
    typeof(int), 
    typeof(float), 
    typeof(object), // You can use any type, including managed types
    typeof(Foo), 
    typeof(Vector128<float>),
    // All 1 byte size empty structures are considered tags 
    // And do not actually occupy space
    typeof(Tag), 
    typeof(bool), 
    typeof(byte),
], new ArcheTypeOptions());

// AArcheType contains some dynamically generated utility methods, 
// such as create chunk instance、 generating access bindings

AArcheType at = arch.ArcheType;

object chunk = at.Create();


record struct Acc
{
    public int a;
    public RwRef<Vector128<float>> v;
    public RoRef<Foo> foo;
}

// Automatically generate access bindings
// The access structure can be on the heap, which means it can be passed in linq

at.UnsafeAccess(chunk, index: 3, out Acc acc);
Console.WriteLine(acc);


ref struct RefAcc
{
    public int v;
    public ref int a;
    public Span<int> b;
    public ReadOnlySpan<int> c;
    public RoRef<int> d;
    public RwRef<int> e;
}
ArcheAccess ref_acc = at.DynamicAccess(typeof(Acc));
RefAcc r = default;
ref_acc(chunk, offset: 0, index: 3, &r);
r.a++;

// Access structures also support ref structures
// Span, ReadOnlySpan will only have a length of 1


// Also supports delegate access (net8+)

delegate void AccCb(
    int a, float b, ref int a1, in int a2, out int a3,
    Span<int> c, ReadOnlySpan<int> d, RoRef<int> e, RwRef<int> f
);

at.UnsafeDelegateAccess<AccCb>(obj, index: 3,
    (
        int a, float b, ref int a1, in int a2, out int a3,
        Span<int> c, ReadOnlySpan<int> d, RoRef<int> e, RwRef<int> f
    ) =>
    {
        Console.WriteLine($"{a}, {b}");
        a3 = a2;
    }
);

// Support range delegate access, call delegates in reverse order

at.UnsafeDelegateRangeAccess<AccCb>(obj, start: 3, length: 3,
    (
        int a, float b, ref int a1, in int a2, out int a3,
        Span<int> c, ReadOnlySpan<int> d, RoRef<int> e, RwRef<int> f
    ) =>
    {
        // Calling order:
        // index 5
        // index 4
        // index 3
        Console.WriteLine($"{a}, {b}");
        a3 = a2;
    }
);


// Support method access. 
// Need to provide an interface containing only one method to specify the method. 
// This access can support inlining.

interface IAcc
{
    public void A(
        int a, float b, ref int a1, in int a2, out int a3,
        Span<int> c, ReadOnlySpan<int> d,
        RoRef<int> e, RwRef<int> f
    );
}

struct SAcc : IAcc
{
    public int a;

    [MethodImpl(MethodImplOptions.AggressiveInlining)]
    public void A(int a, float b, ref int a1, in int a2, out int a3, Span<int> c, ReadOnlySpan<int> d, RoRef<int> e,
        RwRef<int> f)
    {
        Console.WriteLine($"{a}, {b}");
        a3 = a2;
        this.a += a;
    }
}

var s_acc = new SAcc();
at.UnsafeMethodAccess<IAcc, SAcc>(obj, 3, ref s_acc);
Console.WriteLine(s_acc.a);

var s_acc_2 = new SAcc();
at.UnsafeMethodRangeAccess<IAcc, SAcc>(obj, 3, 3, ref s_acc_2);
Console.WriteLine(s_acc_2.a);
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in 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.5.0 120 8/16/2024
0.4.0 117 8/15/2024
0.3.1 122 8/9/2024
0.2.0 88 8/2/2024
0.1.0 93 8/1/2024