Skip to content

almmiko/btree.c-zig

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

btree.c-zig

A wrapper around btree.c lib.

Installation

This package uses Zig package manager.

To add btree.c-zig in the build.zig.zon file run:

zig fetch --save https://github.com/almmiko/btree.c-zig/archive/<git-ref>.tar.gz

Or manually

.{
    .name = "project-zig",
    .version = "0.0.0",
    .dependencies = .{
        .@"btree-zig" = .{
            .url = "https://github.com/almmiko/btree.c-zig/archive/<git-ref>.tar.gz",
            .hash = "1220450bb9feb21c29018e21a8af457859eb2a4607a6017748bb618907b4cf18c67b",
        },
    },
    .paths = .{
        "",
    },
}

Add dependency in your build.zig

const btree_zig = b.dependency("btree-zig", .{
    .target = target,
    .optimize = optimize,
});

const btree_zig_module = btree_zig.module("btree_c_zig");

exe.root_module.addImport("btree-zig", btree_zig_module);
exe.linkLibrary(btree_zig.artifact("btree-zig"));

Usage

Most of the APIs from btree.c are available, see btree.h for references.

Example

  const cString = @cImport({
        @cInclude("string.h");
    });

    const User = struct {
        name: []const u8,
    };

    const cb = struct {
        pub fn compare(a: *User, b: *User, ctx: ?*void) c_int {
            return cString.strncmp(a.name.ptr, b.name.ptr, a.name.len);
        }
    };

    var btree = Btree(User, void).init(0, cb.compare, null);
    defer btree.deinit();

    const user1 = User{ .name = "user1" };
    const user2 = User{ .name = "user2" };

    _ = btree.set(&user1);
    _ = btree.set(&user2);

    _ = btree.get(&user1).?.*;

See btree.zig for more examples.

Tests

To test, run:

zig build test

Credits

btree.c - B-tree implementation in C

About

btree.c wrapper for Zig

Topics

Resources

Stars

Watchers

Forks

Languages