summaryrefslogtreecommitdiff
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
parent4340642f3caa6d8488dba6db9912c5f3eb1abe00 (diff)
exc. 107 migrated
-rw-r--r--exercises/107_files2.zig22
-rw-r--r--patches/patches/107_files2.patch14
2 files changed, 22 insertions, 14 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.
diff --git a/patches/patches/107_files2.patch b/patches/patches/107_files2.patch
index 001337d..597c260 100644
--- a/patches/patches/107_files2.patch
+++ b/patches/patches/107_files2.patch
@@ -1,6 +1,6 @@
---- exercises/107_files2.zig 2025-08-24 19:15:17.789371332 +0200
-+++ answers/107_files2.zig 2025-08-24 19:17:58.897538288 +0200
-@@ -33,7 +33,7 @@
+--- exercises/107_files2.zig 2025-12-28 21:17:29.658147954 +0100
++++ answers/107_files2.zig 2025-12-28 21:17:10.585787203 +0100
+@@ -38,7 +38,7 @@
// initialize an array of u8 with all letter 'A'
// we need to pick the size of the array, 64 seems like a good number
// fix the initialization below
@@ -9,12 +9,12 @@
// this should print out : `AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA`
std.debug.print("{s}\n", .{content});
-@@ -41,12 +41,12 @@
+@@ -49,12 +49,12 @@
// 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);
-+ const bytes_read = try file.read(&content);
++ const bytes_read = try reader.readSliceShort(&content);
// Woah, too screamy. I know you're excited for zigling time but tone it down a bit.
// Can you print only what we read from the file?