CacheThis 0.9.0
dotnet add package CacheThis --version 0.9.0
NuGet\Install-Package CacheThis -Version 0.9.0
<PackageReference Include="CacheThis" Version="0.9.0" />
paket add CacheThis --version 0.9.0
#r "nuget: CacheThis, 0.9.0"
// Install CacheThis as a Cake Addin #addin nuget:?package=CacheThis&version=0.9.0 // Install CacheThis as a Cake Tool #tool nuget:?package=CacheThis&version=0.9.0
CacheThis
Overview
CacheThis is a library designed to facilitate method caching within classes. It operates through a source generator that detects the presence of the [CacheThis]
attribute.
Simply annotate the methods you wish to cache with the [CacheThis]
attribute. Subsequently, the source generator will generate code to produce a derived class named <ClassThatContainsTheMethod>_Cached
.
This generated class retains the original functionality of the defined class while incorporating caching capabilities.
Example
public class Minus
{
[CacheThis(AbsoluteExpirationRelativeToNow=0.3, SlidingExpirationInSeconds =0.1)]
public virtual long Compute(int a, int b)
{
return (long)a - b;
}
}
class Program
{
static void Main(string[] args)
{
Console.WriteLine("Start.");
var minus = new Minus();
var minusCached = new Minus_Cached(minus);
var result = minusCached.Compute(2, 1);
Console.WriteLine($"Computed Result: {result}");
result = minusCached.Compute(2, 1);
Console.WriteLine($"Computed Result: {result}"); // Outputs the result with caching
testc(minusCached); // shows the Minus_Cached object can be used a Minus object
}
static void testc(Minus minusObj)
{
Console.WriteLine(minusObj.Compute(2,1));
}
}
The CacheThis attribute
Adding the CacheThis attribute will signal to the source generator that the method should be cached.
CacheThis attribute Parameters
The following parameters are supported currently
- AbsoluteExpirationRelativeToNow
- SlidingExpirationInSeconds
- To be added: Priority
- To be added: Size
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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 was computed. 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 | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Microsoft.CodeAnalysis.CSharp (>= 4.9.2)
- Microsoft.CodeAnalysis.Workspaces.Common (>= 4.9.2)
- Microsoft.Extensions.Caching.Memory (>= 8.0.0)
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.9.0 | 91 | 5/6/2024 |
First Upload. Some Attribute Options are still Experimental.