summaryrefslogtreecommitdiff
path: root/src/test/strings.zig
diff options
context:
space:
mode:
authorTaylan Kammer <taylan.kammer@gmail.com>2025-03-30 20:10:10 +0200
committerTaylan Kammer <taylan.kammer@gmail.com>2025-03-30 20:10:10 +0200
commit4922f3a4437f7ea8495f32aea0aa329830bd2d8b (patch)
tree2a31c4679114d27351f8d156a31409fd72eef60a /src/test/strings.zig
parent3d05c94b9d8aa964e4ff848c95d5999cec170e04 (diff)
moar cleanup
Diffstat (limited to 'src/test/strings.zig')
-rw-r--r--src/test/strings.zig30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/test/strings.zig b/src/test/strings.zig
new file mode 100644
index 0000000..629bc46
--- /dev/null
+++ b/src/test/strings.zig
@@ -0,0 +1,30 @@
+const std = @import("std");
+
+const testing = std.testing;
+
+pub const value = @import("../zisp/value.zig");
+
+test "istr" {
+ const istr = value.istr;
+ const fx = value.fixnum;
+
+ const s1 = "foo bar baz";
+ const v1 = istr.intern(s1, false);
+ const v1_len: usize = @intCast(fx.unpack(istr.len(v1)));
+ try testing.expectEqualStrings(s1, istr.getHeader(v1).bytes());
+ try testing.expectEqual(s1.len, v1_len);
+
+ const file = try std.fs.cwd().openFile("src/test/data/string.txt", .{});
+ defer file.close();
+ var s2_buf: [4096]u8 = undefined;
+ const s2_len = try file.readAll(&s2_buf);
+ var s2: []u8 = s2_buf[0..s2_len];
+ const v2 = istr.intern(s2, false);
+ const v2_len: usize = @intCast(fx.unpack(istr.len(v2)));
+ var s2_orig_buf: [4096]u8 = undefined;
+ @memcpy(&s2_orig_buf, &s2_buf);
+ const s2_orig = s2_orig_buf[0..s2_len];
+ s2[0] = s2[0] +% 1;
+ try testing.expectEqualStrings(s2_orig, istr.getHeader(v2).bytes());
+ try testing.expectEqual(s2_len, v2_len);
+}