aboutsummaryrefslogtreecommitdiff
path: root/lib/init/src
diff options
context:
space:
mode:
authorAndrew Kelley <andrewrk@noreply.codeberg.org>2025-12-27 14:10:46 +0100
committerAndrew Kelley <andrewrk@noreply.codeberg.org>2025-12-27 14:10:46 +0100
commite55e6b5528bb2f01de242fcf32b172e244e98e74 (patch)
tree3a5eb3193d3d192c54ab0c2b7295a7f21861c27e /lib/init/src
parentc3f2de5e519926eb0029062fe8e782a6f9df9c05 (diff)
parent60a1ba0a8f3517356fa2941462f002a7f580545b (diff)
downloadzig-e55e6b5528bb2f01de242fcf32b172e244e98e74.tar.gz
zig-e55e6b5528bb2f01de242fcf32b172e244e98e74.zip
Merge pull request 'std: migrate all `fs` APIs to `Io`' (#30232) from std.Io-fs into master
Reviewed-on: https://codeberg.org/ziglang/zig/pulls/30232
Diffstat (limited to 'lib/init/src')
-rw-r--r--lib/init/src/main.zig26
-rw-r--r--lib/init/src/root.zig19
2 files changed, 31 insertions, 14 deletions
diff --git a/lib/init/src/main.zig b/lib/init/src/main.zig
index 88dd8348e1..865e6c5322 100644
--- a/lib/init/src/main.zig
+++ b/lib/init/src/main.zig
@@ -1,10 +1,32 @@
const std = @import("std");
+const Io = std.Io;
+
const _NAME = @import(".NAME");
pub fn main() !void {
- // Prints to stderr, ignoring potential errors.
+ // Prints to stderr, unbuffered, ignoring potential errors.
std.debug.print("All your {s} are belong to us.\n", .{"codebase"});
- try _NAME.bufferedPrint();
+
+ // In order to allocate memory we must construct an `Allocator` instance.
+ var debug_allocator: std.heap.DebugAllocator(.{}) = .init;
+ defer _ = debug_allocator.deinit(); // This checks for leaks.
+ const gpa = debug_allocator.allocator();
+
+ // In order to do I/O operations we must construct an `Io` instance.
+ var threaded: std.Io.Threaded = .init(gpa, .{});
+ defer threaded.deinit();
+ const io = threaded.io();
+
+ // Stdout is for the actual output of your application, for example if you
+ // are implementing gzip, then only the compressed bytes should be sent to
+ // stdout, not any debugging messages.
+ var stdout_buffer: [1024]u8 = undefined;
+ var stdout_file_writer: Io.File.Writer = .init(.stdout(), io, &stdout_buffer);
+ const stdout_writer = &stdout_file_writer.interface;
+
+ try _NAME.printAnotherMessage(stdout_writer);
+
+ try stdout_writer.flush(); // Don't forget to flush!
}
test "simple test" {
diff --git a/lib/init/src/root.zig b/lib/init/src/root.zig
index 94c7cd0119..5a7125032b 100644
--- a/lib/init/src/root.zig
+++ b/lib/init/src/root.zig
@@ -1,17 +1,12 @@
-//! By convention, root.zig is the root source file when making a library.
+//! By convention, root.zig is the root source file when making a package.
const std = @import("std");
+const Io = std.Io;
-pub fn bufferedPrint() !void {
- // Stdout is for the actual output of your application, for example if you
- // are implementing gzip, then only the compressed bytes should be sent to
- // stdout, not any debugging messages.
- var stdout_buffer: [1024]u8 = undefined;
- var stdout_writer = std.fs.File.stdout().writer(&stdout_buffer);
- const stdout = &stdout_writer.interface;
-
- try stdout.print("Run `zig build test` to run the tests.\n", .{});
-
- try stdout.flush(); // Don't forget to flush!
+/// This is a documentation comment to explain the `printAnotherMessage` function below.
+///
+/// Accepting an `Io.Writer` instance is a handy way to write reusable code.
+pub fn printAnotherMessage(writer: *Io.Writer) Io.Writer.Error!void {
+ try writer.print("Run `zig build test` to run the tests.\n", .{});
}
pub fn add(a: i32, b: i32) i32 {