aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGabriel A. Giovanini <mail@gabrielgio.me>2025-02-24 20:10:20 +0100
committerGabriel A. Giovanini <mail@gabrielgio.me>2025-02-24 20:10:20 +0100
commit10bdf5aea299a638f3763afcc7660a3d88cadcab (patch)
tree211a800e7b69a9d56183b63053d10ac31bdc59da /src
downloadcerrado-10bdf5aea299a638f3763afcc7660a3d88cadcab.tar.gz
cerrado-10bdf5aea299a638f3763afcc7660a3d88cadcab.tar.bz2
cerrado-10bdf5aea299a638f3763afcc7660a3d88cadcab.zip
feat: Add zig code
This is playground to test zig and libgit2.
Diffstat (limited to 'src')
-rw-r--r--src/main.zig24
-rw-r--r--src/root.zig65
2 files changed, 89 insertions, 0 deletions
diff --git a/src/main.zig b/src/main.zig
new file mode 100644
index 0000000..c8a3f67
--- /dev/null
+++ b/src/main.zig
@@ -0,0 +1,24 @@
+const std = @import("std");
+
+pub fn main() !void {
+ // Prints to stderr (it's a shortcut based on `std.io.getStdErr()`)
+ std.debug.print("All your {s} are belong to us.\n", .{"codebase"});
+
+ // stdout is for the actual output of your application, for example if you
+ // are implementing gzip, then only the compressed bytes should be sent to
+ // stdout, not any debugging messages.
+ const stdout_file = std.io.getStdOut().writer();
+ var bw = std.io.bufferedWriter(stdout_file);
+ const stdout = bw.writer();
+
+ try stdout.print("Run `zig build test` to run the tests.\n", .{});
+
+ try bw.flush(); // don't forget to flush!
+}
+
+test "simple test" {
+ var list = std.ArrayList(i32).init(std.testing.allocator);
+ defer list.deinit(); // try commenting this out and see if zig detects the memory leak!
+ try list.append(42);
+ try std.testing.expectEqual(@as(i32, 42), list.pop());
+}
diff --git a/src/root.zig b/src/root.zig
new file mode 100644
index 0000000..73222be
--- /dev/null
+++ b/src/root.zig
@@ -0,0 +1,65 @@
+const std = @import("std");
+const testing = std.testing;
+const Allocator = std.mem.Allocator;
+
+const git = @cImport({
+ @cInclude("git2.h");
+});
+
+const GitError = error{
+ InitError,
+ DeinitError,
+ OpenError,
+};
+
+pub fn initGit() GitError!void {
+ const code = git.git_libgit2_init();
+ if (code < 0) {
+ return GitError.InitError;
+ }
+}
+
+pub fn deInitGit() !void {
+ const code = git.git_libgit2_shutdown();
+ if (code < 0) {
+ return GitError.DeinitError;
+ }
+}
+
+pub const Repository = struct {
+ allocator: Allocator = undefined,
+ repository: ?*git.git_repository = null,
+
+ pub fn init(alloc: Allocator) !Repository {
+ return Repository{
+ .allocator = alloc,
+ };
+ }
+
+ pub fn open(self: Repository, path: []const u8) GitError!void {
+ const code = git.git_repository_open(@constCast(&self.repository), path.ptr);
+ if (code < 0) {
+ return GitError.OpenError;
+ }
+ }
+
+ pub fn deinit(self: Repository) !void {
+ if (self.repository) |repo| {
+ git.git_repository_free(repo);
+ }
+ }
+};
+
+test "init deinit" {
+ try initGit();
+ try deInitGit();
+}
+
+test "open repository" {
+ try initGit();
+
+ var repository = try Repository.init(std.testing.allocator);
+ try repository.open(".");
+
+ try deInitGit();
+}