Ladybug 0.3.1

dotnet add package Ladybug --version 0.3.1
                    
NuGet\Install-Package Ladybug -Version 0.3.1
                    
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="Ladybug" Version="0.3.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Ladybug" Version="0.3.1" />
                    
Directory.Packages.props
<PackageReference Include="Ladybug" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Ladybug --version 0.3.1
                    
#r "nuget: Ladybug, 0.3.1"
                    
#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.
#:package Ladybug@0.3.1
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Ladybug&version=0.3.1
                    
Install as a Cake Addin
#tool nuget:?package=Ladybug&version=0.3.1
                    
Install as a Cake Tool

ladybug-csharp

A .NET binding for Kuzu graph database APIs with strict feature and performance parity goals.

Package NuGet
Ladybug NuGet
Ladybug.Native NuGet
Ladybug.Extensions NuGet

Installation

dotnet add package Ladybug
dotnet add package Ladybug.Extensions

Ladybug.Native is pulled in automatically as a dependency of Ladybug.

Quick Start

using Ladybug;
using Ladybug.Extensions;

await using var client = new LadybugClient(nativeLibrary);

var result = await client.ExecuteAsync(
    "MATCH (p:Person) RETURN p.name, p.age");

// LINQ mapping with typed row accessor
var people = result.Select(r => new
{
    Name = r.Get<string>("p.name"),
    Age  = r.Get<int>("p.age")
});

foreach (var p in people)
    Console.WriteLine($"{p.Name} is {p.Age} years old");

For a full runnable example with fraud detection, recommendations, JSON/CSV export, true-streaming fallback behavior, DI, health checks, and resilience, see the Example project.

Packages

Package Description
Ladybug Managed API surface, LadybugClient, ILadybugExecutor, and differential smoke runner.
Ladybug.Native Native abstraction layer modelling the Kuzu C API contract (INativeLibrary).
Ladybug.Extensions LINQ mapping, JSON/CSV export, DataTable, streaming, DI, Options, health checks, and resilience policies.

Extensions API

LINQ / Row Mapping

// Project rows into dictionaries
IEnumerable<IReadOnlyDictionary<string, object?>> dicts = result.ToDictionaries();

// Map rows with a typed IRowAccessor
IEnumerable<T> items = result.Select(r => new MyDto(r.Get<string>("name"), r.Get<int>("age")));

// Materialize into a list
List<T> list = result.ToList(r => new MyDto(r.Get<string>("name"), r.Get<int>("age")));

// Extract a single scalar value
string name = result.Scalar<string>("name");
int value = result.Scalar<int>(0);

IRowAccessor

Typed access to row values by column name (case-insensitive) or index:

T value          = accessor.Get<T>("columnName");
T value          = accessor.Get<T>(0);
T? valueOrNull   = accessor.GetOrDefault<T>("columnName");
T? valueOrFallback = accessor.GetOrDefault<T>(0, fallback);

JSON Export

// Full result with metadata (columns, rows, sourceLibrary, durationMs)
string json = result.ToJson();

// Array of row objects keyed by column names
string jsonArray = result.ToJsonArray();

DataTable Conversion

DataTable dt = result.ToDataTable();

CSV Export

string csv = result.ToCsv();               // comma-separated
string tsv = result.ToCsv(separator: "\t"); // tab-separated

IAsyncEnumerable Streaming

// Stream rows one by one as IRowAccessor
await foreach (var row in executor.StreamAsync("MATCH (n) RETURN n.id"))
{
    Console.WriteLine(row.Get<string>(0));
}

// Stream with a mapper
await foreach (var id in executor.StreamAsync("MATCH (n) RETURN n.id", r => r.Get<string>(0)))
{
    Console.WriteLine(id);
}

When the underlying native adapter implements INativeStreamingLibrary, Ladybug uses row-by-row streaming without full result materialization. Otherwise it falls back to buffered execution.

Dependency Injection

// Basic registration
services.AddLadybugClient<MyNativeLibrary>();

// With options
services.AddLadybugClient<MyNativeLibrary>(opts =>
{
    opts.DatabasePath = "./mydb";
    opts.ReadOnly = true;
    opts.MaxThreads = 4;
    opts.BufferPoolSize = 256 * 1024 * 1024;
});

// Health check
services.AddHealthChecks().AddLadybugCheck();

// Optional resilience wrapper for enterprise workloads
services.AddResilientLadybugExecutor(opts =>
{
    opts.Timeout = TimeSpan.FromSeconds(5);
    opts.MaxRetryAttempts = 1;
    opts.RetryDelay = TimeSpan.FromMilliseconds(50);
    opts.CircuitBreakerFailureThreshold = 3;
    opts.CircuitBreakerBreakDuration = TimeSpan.FromSeconds(5);
});

Registers INativeLibrary, LadybugClient, and ILadybugExecutor as singletons.

Observability

LadybugClient emits OpenTelemetry-compatible diagnostics:

  • Activity source: Ladybug
  • Meter: Ladybug
  • Counter: ladybug.query.count
  • Counter: ladybug.query.errors
  • Counter: ladybug.query.cancellations
  • Histogram: ladybug.query.duration.ms

These signals can be exported through standard OpenTelemetry pipelines for dashboards and alerts.

Supported Frameworks

  • .NET 10 (net10.0)
  • .NET 8 (net8.0)

Build

dotnet restore
dotnet build ladybug-csharp.sln -c Release

Test

dotnet test ladybug-csharp.sln -c Release

Benchmark

dotnet run -c Release --project benchmarks/Ladybug.Benchmarks/Ladybug.Benchmarks.csproj

Deterministic CI gate mode:

LADYBUG_BENCH_RATIO_MAX=1.10 dotnet run -c Release --project benchmarks/Ladybug.Benchmarks/Ladybug.Benchmarks.csproj -- --ci-gate

Differential Smoke Strategy

See:

  • docs/differential-smoke-spec.md
  • docs/parity-matrix.md

License

MIT. See LICENSE.

Product Compatible and additional computed target framework versions.
.NET 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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 is compatible.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Ladybug:

Package Downloads
Ladybug.Extensions

LINQ extensions, DI integration, health checks, JSON/CSV export, and streaming helpers for the Ladybug .NET binding.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
0.3.1 55 3/25/2026
0.3.0 50 3/25/2026
0.2.0 56 3/25/2026