diff options
author | Lorenzo Torres <torres@sideros.org> | 2025-03-22 22:55:31 +0100 |
---|---|---|
committer | Lorenzo Torres <torres@sideros.org> | 2025-03-22 22:55:31 +0100 |
commit | 00d695e5f08ddff7ba66f2dd1aea4cdaf14f45e7 (patch) | |
tree | f907ee775c5d2bf3a1296d8bcee175c2aaabc582 | |
parent | 191e1485356ed6a1c0f8e608b4dd775e0939ac77 (diff) |
cleaned up ecs interface
-rw-r--r-- | src/ecs/entities.zig | 44 | ||||
-rw-r--r-- | src/main.zig | 24 |
2 files changed, 52 insertions, 16 deletions
diff --git a/src/ecs/entities.zig b/src/ecs/entities.zig index beeb919..149c9ff 100644 --- a/src/ecs/entities.zig +++ b/src/ecs/entities.zig @@ -42,6 +42,50 @@ pub const Pool = struct { return pool; } + pub fn getQuery(self: *@This(), comptime T: type) []T { + const set = switch (T) { + components.Speed => &self.speed, + components.Position => &self.position, + else => unreachable, + }; + + return set.components.items; + } + + pub fn getEntity(self: *@This(), component: usize, comptime T: type) usize { + const set = switch (T) { + components.Speed => &self.speed, + components.Position => &self.position, + else => unreachable, + }; + + return set.dense.items[component]; + } + + pub fn getComponent(self: *@This(), entity: usize, comptime T: type) ?T { + const set = switch (T) { + components.Speed => &self.speed, + components.Position => &self.position, + else => unreachable, + }; + + if (self.hasComponent(entity, T)) { + return set.components.items[set.sparse.items[entity]]; + } else { + return null; + } + } + + pub fn hasComponent(self: *@This(), entity: usize, component: type) bool { + const set = switch (component) { + components.Speed => &self.speed, + components.Position => &self.position, + else => unreachable, + }; + + return set.dense.items[set.sparse.items[entity]] == entity; + } + pub fn addSystemGroup(self: *@This(), group: SystemGroup) !void { try self.system_groups.append(group); } diff --git a/src/main.zig b/src/main.zig index 30e1281..597011d 100644 --- a/src/main.zig +++ b/src/main.zig @@ -12,24 +12,14 @@ const components = @import("ecs/components.zig"); const entities = @import("ecs/entities.zig"); fn testSystem2(pool: *entities.Pool) void { - var i = @as(usize, 0); - //std.debug.print("test: {d}\n", .{pool.position.components.items.len}); - for (pool.position.components.items) |position| { - const entity = pool.position.dense.items[i]; - if (pool.speed.dense.items[pool.speed.sparse.items[entity]] == entity) { - const speed = pool.speed.components.items[pool.speed.sparse.items[entity]]; + for (pool.getQuery(components.Position), 0..) |position, i| { + const entity = pool.getEntity(i, components.Position); + if (pool.getComponent(entity, components.Speed)) |speed| { std.debug.print("entity{d}: {any},{any},{any} {any}\n", .{ i, position.x, position.y, position.z, speed.speed }); } - - i += 1; } } -fn testSystem(pool: *entities.Pool) void { - _ = pool; - std.debug.print("test\n", .{}); -} - pub fn main() !void { var gpa = std.heap.GeneralPurposeAllocator(.{}){}; const allocator = gpa.allocator(); @@ -58,9 +48,11 @@ pub fn main() !void { testSystem2, }); - const entity = try pool.createEntity(); - try pool.addComponent(entity, components.Position{ .x = 1.0, .y = 0.5, .z = 3.0 }); - try pool.addComponent(entity, components.Speed{ .speed = 5.0 }); + for (0..1000) |_| { + const entity = try pool.createEntity(); + try pool.addComponent(entity, components.Position{ .x = 1.0, .y = 0.5, .z = 3.0 }); + try pool.addComponent(entity, components.Speed{ .speed = 5.0 }); + } // TODO(luccie-cmd): Renderer.create shouldn't return an error var r = try Renderer.create(allocator, w); |