summaryrefslogtreecommitdiff
path: root/exercises
diff options
context:
space:
mode:
authorChris Boesch <chrboesch@noreply.codeberg.org>2025-12-28 21:19:31 +0100
committerChris Boesch <chrboesch@noreply.codeberg.org>2025-12-28 21:19:31 +0100
commit3a645ac9dbe77bd0a83ca6ae3266f16628924861 (patch)
tree8891c774cd57bfa95a85bdb1ac7e31951e8d456c /exercises
parent4340642f3caa6d8488dba6db9912c5f3eb1abe00 (diff)
exc. 107 migrated
Diffstat (limited to 'exercises')
-rw-r--r--exercises/107_files2.zig22
1 files changed, 15 insertions, 7 deletions
diff --git a/exercises/107_files2.zig b/exercises/107_files2.zig
index 9b94101..a11c46a 100644
--- a/exercises/107_files2.zig
+++ b/exercises/107_files2.zig
@@ -15,20 +15,25 @@
// - Then, we initialize an array of characters with all letter 'A', and print it
// - After that, we read the content of the file into the array
// - Finally, we print out the content we just read
+//
+// Note: For simplicity, we read byte-by-byte without buffering.
+// In real applications, you'd typically use a buffer for better
+// performance. We'll learn about buffered I/O in a later exercise.
const std = @import("std");
+const io = std.Options.debug_io;
pub fn main() !void {
// Get the current working directory
- const cwd = std.fs.cwd();
+ const cwd = std.Io.Dir.cwd();
// try to open ./output assuming you did your 106_files exercise
- var output_dir = try cwd.openDir("output", .{});
- defer output_dir.close();
+ var output_dir = try cwd.openDir(io, "output", .{});
+ defer output_dir.close(io);
// try to open the file
- const file = try output_dir.openFile("zigling.txt", .{});
- defer file.close();
+ const file = try output_dir.openFile(io, "zigling.txt", .{});
+ defer file.close(io);
// initialize an array of u8 with all letter 'A'
// we need to pick the size of the array, 64 seems like a good number
@@ -37,10 +42,13 @@ pub fn main() !void {
// this should print out : `AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA`
std.debug.print("{s}\n", .{content});
+ var file_reader = file.reader(io, &.{});
+ const reader = &file_reader.interface;
+
// okay, seems like a threat of violence is not the answer in this case
// can you go here to find a way to read the content?
- // https://ziglang.org/documentation/master/std/#std.fs.File
- // hint: you might find two answers that are both valid in this case
+ // https://ziglang.org/documentation/master/std/#std.Io.Reader
+ // hint: look for a method that reads into a slice
const bytes_read = zig_read_the_file_or_i_will_fight_you(&content);
// Woah, too screamy. I know you're excited for zigling time but tone it down a bit.