diff options
author | Julien Dessaux | 2022-08-14 00:08:32 +0200 |
---|---|---|
committer | Julien Dessaux | 2022-08-14 00:08:32 +0200 |
commit | 307183aad7d2a2d2bf8253621cd120441d487d00 (patch) | |
tree | d7e31b41d1f9d71a09e3478f248c30b69a193b29 /src | |
parent | Add environment handling (diff) | |
download | zigfunge98-307183aad7d2a2d2bf8253621cd120441d487d00.tar.gz zigfunge98-307183aad7d2a2d2bf8253621cd120441d487d00.tar.bz2 zigfunge98-307183aad7d2a2d2bf8253621cd120441d487d00.zip |
Implemented the y command requirements
Diffstat (limited to 'src')
-rw-r--r-- | src/field.zig | 3 | ||||
-rw-r--r-- | src/stack.zig | 10 |
2 files changed, 13 insertions, 0 deletions
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" { |