From a86a078a9707bdc3b0bd7ce9c8d72a89c8c942b4 Mon Sep 17 00:00:00 2001 From: Ekaitz Zarraga Date: Thu, 1 Aug 2024 16:41:07 +0200 Subject: Start generic type matching --- src/duckdb/Result.zig | 21 ++++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) (limited to 'src/duckdb/Result.zig') diff --git a/src/duckdb/Result.zig b/src/duckdb/Result.zig index b49f704..2b5b992 100644 --- a/src/duckdb/Result.zig +++ b/src/duckdb/Result.zig @@ -22,6 +22,21 @@ pub fn Result(comptime T: type) type{ return error.DuckDBError; } self.fetchDataChunk(); + + // Get column vectors + switch (@typeInfo(T)) { + .Struct => |v| { + const column_count = v.fields.len; + var columns : [column_count]c.duckdb_vector = undefined; + for (columns, 0..) |_, i| { + columns[i] = c.duckdb_data_chunk_get_vector(self._chunk, i); + } + std.debug.print("{any}", .{columns}); + }, + .Void => {}, + else => @compileError("Expecting struct or void in query result type"), + } + return self; } pub fn deinit(self: *Self) void { @@ -59,12 +74,8 @@ pub fn Result(comptime T: type) type{ /// 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, - } + _ = self; return result; } }; -- cgit v1.2.3