diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/db.zig | 23 |
1 files changed, 20 insertions, 3 deletions
@@ -1,4 +1,5 @@ const std = @import("std"); +const assert = std.debug.assert; const c = @cImport({ @cInclude("duckdb.h"); }); @@ -8,12 +9,23 @@ const Result = struct { _res: c.duckdb_result, _chunk: c.duckdb_data_chunk, + pub fn init() Result { + return .{ + ._res = undefined, + ._chunk = null + }; + } pub fn deinit(self: *Result) void { c.duckdb_destroy_result(&self._res); c.duckdb_destroy_data_chunk(&self._chunk); } - pub fn getRowCount(self: Result) usize { + /// 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: Result) usize { + if (self._chunk != null) { + return 0; + } return c.duckdb_data_chunk_get_size(self._chunk); } @@ -21,7 +33,13 @@ const Result = struct { 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. pub fn fetchDataChunk(self: *Result) void{ + if (self._chunk != null){ + c.duckdb_destroy_data_chunk(&self._chunk); + } self._chunk = c.duckdb_fetch_chunk(self._res); } @@ -47,7 +65,7 @@ const Connection = struct { } pub fn query(self: *Connection, q: [*c]const u8) !Result{ - var result: Result = undefined; + var result = Result.init(); const state = c.duckdb_query(self._conn, q, &result._res); if ( state == c.DuckDBError){ return error.DuckDBError; @@ -96,6 +114,5 @@ test "Query size" { var result = try connection.query("SELECT * FROM integers;"); defer result.deinit(); - try std.testing.expect(3 == result.getRowCount()); try std.testing.expect(2 == result.getColumnCount()); } |