Coplt.Arches
0.5.0
.NET 6.0
This package targets .NET 6.0. The package is compatible with this framework or higher.
.NET Standard 2.1
This package targets .NET Standard 2.1. The package is compatible with this framework or higher.
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
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#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
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Coplt.Arches
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 | Versions 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.
-
.NETStandard 2.1
- System.Collections.Immutable (>= 8.0.0)
- System.Text.Json (>= 8.0.4)
-
net6.0
- System.Collections.Immutable (>= 8.0.0)
-
net8.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.