summaryrefslogtreecommitdiff
path: root/src/duckdb/Result.zig
diff options
context:
space:
mode:
authorEkaitz Zarraga <ekaitz@elenq.tech>2024-08-01 15:46:56 +0200
committerEkaitz Zarraga <ekaitz@elenq.tech>2024-08-01 15:46:56 +0200
commitb5316c4dc3ba84a4257b996f9d1505f95fe95ab4 (patch)
tree4b30760788b20d5860f4764479fd96e731fcc60b /src/duckdb/Result.zig
parent9a2ed3ddf6ebbcc46d0aea394ca92b76f65e16e7 (diff)
Separate database Result and start generics
Diffstat (limited to 'src/duckdb/Result.zig')
-rw-r--r--src/duckdb/Result.zig71
1 files changed, 71 insertions, 0 deletions
diff --git a/src/duckdb/Result.zig b/src/duckdb/Result.zig
new file mode 100644
index 0000000..b49f704
--- /dev/null
+++ b/src/duckdb/Result.zig
@@ -0,0 +1,71 @@
+const std = @import("std");
+const c = @cImport({
+ @cInclude("duckdb.h");
+});
+
+
+pub fn Result(comptime T: type) type{
+
+ return struct {
+ _res: c.duckdb_result,
+ _chunk: c.duckdb_data_chunk,
+
+ const Self = @This();
+
+ pub fn init(conn : c.duckdb_connection, query: [:0]const u8) !Self {
+ var self : Self = .{
+ ._res = undefined,
+ ._chunk = null
+ };
+ const state = c.duckdb_query(conn, query, &self._res);
+ if ( state == c.DuckDBError){
+ return error.DuckDBError;
+ }
+ self.fetchDataChunk();
+ return self;
+ }
+ pub fn deinit(self: *Self) void {
+ c.duckdb_destroy_result(&self._res);
+ c.duckdb_destroy_data_chunk(&self._chunk);
+ }
+
+ /// There's not way to know how many total elements we have, but we can
+ /// know how many we have in the current chunk.
+ fn getCurrentChunkSize(self: Self) usize {
+ if (self._chunk != null) {
+ return 0;
+ }
+ return c.duckdb_data_chunk_get_size(self._chunk);
+ }
+
+ pub fn getColumnCount(self: Self) usize {
+ return c.duckdb_data_chunk_get_column_count(self._chunk);
+ }
+
+ /// This needs to be called repeatedly to obtain the next blocks of
+ /// data. There's no way to know how many elements we'll obtain from
+ /// it.
+ fn fetchDataChunk(self: *Self) void{
+ if (self._chunk != null){
+ c.duckdb_destroy_data_chunk(&self._chunk);
+ }
+ self._chunk = c.duckdb_fetch_chunk(self._res);
+ }
+
+ pub fn exausted(self: Self) bool{
+ return self._chunk != null;
+ }
+
+ /// We need some comptime magic to create the output structures from
+ /// the T.
+ pub fn next(self: *Self) T{
+ _ = self;
+ const result: T = undefined;
+ switch (@typeInfo(T)) {
+ .Struct => std.debug.print("GOOOD: ", .{}),
+ else => null,
+ }
+ return result;
+ }
+ };
+}