Sharpify.Data 2.4.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Sharpify.Data --version 2.4.0                
NuGet\Install-Package Sharpify.Data -Version 2.4.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="Sharpify.Data" Version="2.4.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Sharpify.Data --version 2.4.0                
#r "nuget: Sharpify.Data, 2.4.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 Sharpify.Data as a Cake Addin
#addin nuget:?package=Sharpify.Data&version=2.4.0

// Install Sharpify.Data as a Cake Tool
#tool nuget:?package=Sharpify.Data&version=2.4.0                

CHANGELOG

v2.4.0

  • Added an overload for Remove which takes in a Func<string, bool> keySelector, this function is more optimized then using if you were to iterate yourself and call the old Remove as this one will execute serialization only once at the end, and only if removals actually happened (selector actually matched at least one key).
    • The new Remove method also has an overload that accepts a string? preFilter as well, which can be used to only check keys that start with preFilter (the keySelector doesn't need to account for it, it will applied to a slice if the preFilter is matched), if left null it will be ignored.
    • This addition was also propagated to both implementations of the IDatabaseFilter<T>, i.e MemoryPackDatabaseFilter<T> and FlexibleDatabaseFilter<T>, both of which modify the incoming delegate to the use the filtered key, enabling simple delegate matches without relying on implementation details, they don't have the option to use a preFilter as they themselves use the statically generated type filters they create.
  • To accommodate the Remove methods, MemoryPackDatabaseFilter<T> and FlexibleDatabaseFilter<T> now create a public static readonly string KeyFilter property, which is the prefix they append to the keys, this is used internally for Remove but perhaps the could help if you need to inherit from these classes and override the Remove method.
    • Both of them also use KeyFilter internally to generate the filtered keys in a slightly more efficient way to before.
    • The static readonly field that contained the generic type name was also removed as it was integrated into KeyFilter at with no additional cost.

Reminder: Workaround for broken NativeAot support from MemoryPack

As of writing this, MemoryPack's NativeAot support is broken, for any type that isn't already in their cached types, the MemoryPackFormatterProvider uses reflection to get the formatter, which fails in NativeAot. As a workaround, we need to add the formatters ourselves, to do this, take any 1 static entry point, that activates before the database is loaded, and add this:

// for every T type that relies on MemoryPack for serialization, and their inheritance hierarchy
// This includes types that implement IMemoryPackable (i.e types that are decorated with MemoryPackable)
MemoryPackFormatterProvider.Register<T>();
// If the type is a collection or dictionary use the other corresponding overloads:
MemoryPackFormatterProvider.RegisterCollection<TCollection, TElement>();
// or
MemoryPackFormatterProvider.RegisterDictionary<TDictionary, TKey, TValue>();
// and so on...
// for all overloads check peek the definition of MemoryPackFormatterProvider, or their Github Repo

Note: Make sure you don't create a new static constructor in those types, MemoryPack already creates those, you will need to find a different entry point.

With this the serializer should be able to bypass the part using reflection, and thus work even on NativeAot.

P.S. The base type of the Database is already registered the same way on its own static constructor.

Product Compatible and additional computed target framework versions.
.NET net7.0 is compatible.  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. 
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
2.6.0 83 11/13/2024
2.5.0 85 7/30/2024
2.4.1 86 6/3/2024
2.4.0 84 5/30/2024
2.3.0 127 4/17/2024
2.2.0 134 3/2/2024
2.1.3 116 1/25/2024
2.1.2 105 1/25/2024
2.1.1 109 1/25/2024
2.1.0 129 1/25/2024
2.0.2 105 1/23/2024
2.0.1 106 1/22/2024
2.0.0 101 1/20/2024
1.1.0 118 1/15/2024
1.0.3 127 1/8/2024
1.0.2 132 1/5/2024
1.0.1 126 1/4/2024
1.0.0 122 1/4/2024