From 307183aad7d2a2d2bf8253621cd120441d487d00 Mon Sep 17 00:00:00 2001 From: Julien Dessaux Date: Sun, 14 Aug 2022 00:08:32 +0200 Subject: Implemented the y command requirements --- src/field.zig | 3 +++ src/stack.zig | 10 ++++++++++ 2 files changed, 13 insertions(+) diff --git a/src/field.zig b/src/field.zig index e96a44a..9a12a80 100644 --- a/src/field.zig +++ b/src/field.zig @@ -244,6 +244,9 @@ pub const Field = struct { if (y >= f.y and y < f.y + @intCast(i64, f.lines.items.len)) return f.lines.items[@intCast(usize, y - @intCast(i64, f.y))].get(x); return ' '; } + pub fn getSize(f: Field) [4]i64 { + return [4]i64{ f.x, f.y, @intCast(i64, f.lx), @intCast(i64, f.lines.items.len) }; + } fn init(allocator: std.mem.Allocator) !*Field { var f = try allocator.create(Field); errdefer allocator.destroy(f); diff --git a/src/stack.zig b/src/stack.zig index e02cb20..09edd2e 100644 --- a/src/stack.zig +++ b/src/stack.zig @@ -147,6 +147,16 @@ pub const Stack = struct { const emptyResult2 = [_]i64{ 4, 5 }; try std.testing.expectEqualSlices(i64, empty.data.items, emptyResult2[0..]); } + pub fn yCommandPick(self: *Stack, n: usize, h: usize) !void { + if (n > self.data.items.len) { + self.data.items.len = 1; + self.data.items[0] = 0; + } else { + const v = self.data.items[self.data.items.len - n]; + self.data.items.len = h; + try self.push(v); + } + } }; test "all" { -- cgit v1.2.3