std: migrate all fs APIs to Io #30232

Merged
andrewrk merged 195 commits from std.Io-fs into master 2025-12-27 14:10:53 +01:00
Image
Owner

This branch deletes std.fs.File in favor of std.Io.File and std.fs.Dir in favor of std.Io.Dir, as well as moving almost all std.fs API into std.Io.Dir.

The main purpose is to integrate file system I/O with the std.Io interface, which is a major part of #30150.

I also took advantage of the breakage to rename a number of file system APIs for consistency.

Upgrade Guide

Although it's a lot of breaking changes, unlike "writergate", this changeset is expected to be generally easy for Zig programmers to manage, because it does not require much critical thinking. For example, typical upgrade path will look something like this:

-file.close();
+file.close(io);

Although your upgrade diff might be large, it will be quite simple to understand what needs to be done.

Added:

  • std.Io.Dir.hardLink
  • std.Io.Dir.Reader
  • std.Io.Dir.setFilePermissions
  • std.Io.Dir.setFileOwner
  • std.Io.File.NLink

Removed with no replacement:

  • std.fs.realpathZ
  • std.fs.realpathW
  • std.fs.realpathW2
  • std.fs.makeDirAbsoluteZ
  • std.fs.deleteDirAbsoluteZ
  • std.fs.openDirAbsoluteZ
  • std.fs.renameAbsoluteZ
  • std.fs.renameZ
  • std.fs.deleteTreeAbsolute
  • std.fs.symLinkAbsoluteW
  • std.fs.Dir.realpathZ
  • std.fs.Dir.realpathW
  • std.fs.Dir.realpathW2
  • std.fs.Dir.deleteFileZ
  • std.fs.Dir.deleteFileW
  • std.fs.Dir.deleteDirZ
  • std.fs.Dir.deleteDirW
  • std.fs.Dir.renameZ
  • std.fs.Dir.renameW
  • std.fs.Dir.symLinkWasi
  • std.fs.Dir.symLinkZ
  • std.fs.Dir.symLinkW
  • std.fs.Dir.readLinkWasi
  • std.fs.Dir.readLinkZ
  • std.fs.Dir.readLinkW
  • std.fs.Dir.adaptToNewApi
  • std.fs.Dir.adaptFromNewApi
  • std.fs.File.isCygwinPty
  • std.fs.File.adaptToNewApi
  • std.fs.File.adaptFromNewApi

Changed:

Many functions now have a std.Io parameter.

  • std.fs.copyFileAbsolute -> std.Io.Dir.copyFileAbsolute

  • std.fs.makeDirAbsolute -> std.Io.Dir.createDirAbsolute

  • std.fs.deleteDirAbsolute -> std.Io.Dir.deleteDirAbsolute

  • std.fs.openDirAbsolute -> std.Io.Dir.openDirAbsolute

  • std.fs.openFileAbsolute -> std.Io.Dir.openFileAbsolute

  • std.fs.accessAbsolute -> std.Io.Dir.accessAbsolute

  • std.fs.createFileAbsolute -> std.Io.Dir.createFileAbsolute

  • std.fs.deleteFileAbsolute -> std.Io.Dir.deleteFileAbsolute

  • std.fs.renameAbsolute -> std.Io.Dir.renameAbsolute

  • std.fs.readLinkAbsolute -> std.Io.Dir.readLinkAbsolute

  • std.fs.symLinkAbsolute -> std.Io.Dir.symLinkAbsolute

  • std.fs.has_executable_bit -> std.Io.File.Permissions.has_executable_bit

  • std.fs.realpath -> std.Io.Dir.realPathFileAbsolute

  • std.fs.rename -> std.Io.Dir.rename

  • std.fs.cwd -> std.Io.Dir.cwd

  • std.fs.defaultWasiCwd -> std.os.defaultWasiCwd

  • std.fs.realpathAlloc -> std.Io.Dir.realPathFileAbsoluteAlloc

  • std.fs.openSelfExe -> std.process.openExecutable

  • std.fs.selfExePathAlloc -> std.process.executablePathAlloc

  • std.fs.selfExePath -> std.process.executablePath

  • std.fs.selfExeDirPath -> std.process.executableDirPath

  • std.fs.selfExeDirPathAlloc -> std.process.executableDirPathAlloc

  • std.fs.Dir.setAsCwd -> std.process.setCurrentDir

  • std.fs.Dir.realpath -> std.Io.Dir.realPathFile

  • std.fs.Dir.realpathAlloc -> std.Io.Dir.realPathFileAlloc

  • std.fs.Dir -> std.Io.Dir

  • std.fs.File -> std.Io.File

  • std.fs.Dir.makeDir -> std.Io.Dir.createDir

  • std.fs.Dir.makePath -> std.Io.Dir.createDirPath

  • std.fs.Dir.makeOpenDir -> std.Io.Dir.createDirPathOpen

  • std.fs.Dir.rename: now accepts two Dir parameters (plus Io)

  • std.fs.Dir.atomicSymLink -> std.Io.Dir.symLinkAtomic

  • std.fs.Dir.chmod -> std.Io.Dir.setPermissions

  • std.fs.Dir.chown -> std.Io.Dir.setOwner

  • std.fs.File.Mode -> std.Io.File.Permissions

  • std.fs.File.PermissionsWindows -> std.Io.File.Permissions

  • std.fs.File.PermissionsUnix -> std.Io.File.Permissions

  • std.fs.File.default_mode -> std.Io.File.Permissions.default_file

  • std.fs.File.getOrEnableAnsiEscapeSupport -> std.Io.File.enableAnsiEscapeCodes

  • std.fs.File.setEndPos -> std.Io.File.setLength

  • std.fs.File.getEndPos -> std.Io.File.length

  • std.fs.File.seekTo, std.fs.File.seekBy, std.fs.File.seekFromEnd -> std.Io.File.Reader.seekTo, std.Io.File.Reader.seekBy, std.Io.File.Writer.seekTo

  • std.fs.File.getPos -> std.Io.File.Reader.logicalPos, std.Io.Writer.logicalPos

  • std.fs.File.mode() -> std.Io.File.stat().permissions.toMode

  • std.fs.File.chmod -> std.Io.File.setPermissions

  • std.fs.File.chown -> std.Io.File.setOwner

  • std.fs.File.updateTimes -> std.Io.File.setTimestamps, std.Io.File.setTimestampsNow

  • std.fs.File.read -> std.Io.File.readStreaming

  • std.fs.File.readv -> std.Io.File.readStreaming

  • std.fs.File.pread -> std.Io.File.readPositional

  • std.fs.File.preadv -> std.Io.File.readPositional

  • std.fs.File.preadAll -> std.Io.File.readPositionalAll

  • std.fs.File.write -> std.Io.File.writeStreaming

  • std.fs.File.writev -> std.Io.File.writeStreaming

  • std.fs.File.pwrite -> std.Io.File.writePositional

  • std.fs.File.pwritev -> std.Io.File.writePositional

  • std.fs.File.writeAll -> std.Io.File.writeStreamingAll

  • std.fs.File.pwriteAll -> std.Io.File.writePositionalAll

  • std.fs.File.copyRange, std.fs.File.copyRangeAll -> std.Io.File.writer

Deprecated:

  • std.fs.path -> std.Io.Dir.path
  • std.fs.max_path_bytes -> std.Io.Dir.max_path_bytes
  • std.fs.max_name_bytes -> std.Io.Dir.max_name_bytes

std.Progress Note

After updating your application that uses std.Progress:

-        const root_progress_node = std.Progress.start(.{
+        const root_progress_node = std.Progress.start(io, .{

Make sure you have defer root_progress_node.end(); there. Before, if control flow got to the end of main(), start code would exit all threads, including the std.Progress thread. Now, it is not a thread but a task, and you likely have defer threaded.deinit(); above there, which will wait until all tasks are finished. If your application hangs, double check that your std.Progress.start have a matching node.end().

Followup Tasks


closes https://github.com/ziglang/zig/issues/25738
closes #30131
closes #30189
closes #30593

This branch deletes `std.fs.File` in favor of `std.Io.File` and `std.fs.Dir` in favor of `std.Io.Dir`, as well as moving almost all `std.fs` API into `std.Io.Dir`. The main purpose is to integrate file system I/O with the `std.Io` interface, which is a major part of #30150. I also took advantage of the breakage to rename a number of file system APIs for consistency. ## Upgrade Guide Although it's a lot of breaking changes, unlike ["writergate"](https://github.com/ziglang/zig/pull/24329), this changeset is expected to be generally easy for Zig programmers to manage, because it does not require much critical thinking. For example, typical upgrade path will look something like this: ```diff -file.close(); +file.close(io); ``` Although your upgrade diff might be large, it will be quite simple to understand what needs to be done. ### Added: * `std.Io.Dir.hardLink` * `std.Io.Dir.Reader` * `std.Io.Dir.setFilePermissions` * `std.Io.Dir.setFileOwner` * `std.Io.File.NLink` ### Removed with no replacement: * `std.fs.realpathZ` * `std.fs.realpathW` * `std.fs.realpathW2` * `std.fs.makeDirAbsoluteZ` * `std.fs.deleteDirAbsoluteZ` * `std.fs.openDirAbsoluteZ` * `std.fs.renameAbsoluteZ` * `std.fs.renameZ` * `std.fs.deleteTreeAbsolute` * `std.fs.symLinkAbsoluteW` * `std.fs.Dir.realpathZ` * `std.fs.Dir.realpathW` * `std.fs.Dir.realpathW2` * `std.fs.Dir.deleteFileZ` * `std.fs.Dir.deleteFileW` * `std.fs.Dir.deleteDirZ` * `std.fs.Dir.deleteDirW` * `std.fs.Dir.renameZ` * `std.fs.Dir.renameW` * `std.fs.Dir.symLinkWasi` * `std.fs.Dir.symLinkZ` * `std.fs.Dir.symLinkW` * `std.fs.Dir.readLinkWasi` * `std.fs.Dir.readLinkZ` * `std.fs.Dir.readLinkW` * `std.fs.Dir.adaptToNewApi` * `std.fs.Dir.adaptFromNewApi` * `std.fs.File.isCygwinPty` * `std.fs.File.adaptToNewApi` * `std.fs.File.adaptFromNewApi` ### Changed: Many functions now have a `std.Io` parameter. * `std.fs.copyFileAbsolute` -> `std.Io.Dir.copyFileAbsolute` * `std.fs.makeDirAbsolute` -> `std.Io.Dir.createDirAbsolute` * `std.fs.deleteDirAbsolute` -> `std.Io.Dir.deleteDirAbsolute` * `std.fs.openDirAbsolute` -> `std.Io.Dir.openDirAbsolute` * `std.fs.openFileAbsolute` -> `std.Io.Dir.openFileAbsolute` * `std.fs.accessAbsolute` -> `std.Io.Dir.accessAbsolute` * `std.fs.createFileAbsolute` -> `std.Io.Dir.createFileAbsolute` * `std.fs.deleteFileAbsolute` -> `std.Io.Dir.deleteFileAbsolute` * `std.fs.renameAbsolute` -> `std.Io.Dir.renameAbsolute` * `std.fs.readLinkAbsolute` -> `std.Io.Dir.readLinkAbsolute` * `std.fs.symLinkAbsolute` -> `std.Io.Dir.symLinkAbsolute` * `std.fs.has_executable_bit` -> `std.Io.File.Permissions.has_executable_bit` * `std.fs.realpath` -> `std.Io.Dir.realPathFileAbsolute` * `std.fs.rename` -> `std.Io.Dir.rename` * `std.fs.cwd` -> `std.Io.Dir.cwd` * `std.fs.defaultWasiCwd` -> `std.os.defaultWasiCwd` * `std.fs.realpathAlloc` -> `std.Io.Dir.realPathFileAbsoluteAlloc` * `std.fs.openSelfExe` -> `std.process.openExecutable` * `std.fs.selfExePathAlloc` -> `std.process.executablePathAlloc` * `std.fs.selfExePath` -> `std.process.executablePath` * `std.fs.selfExeDirPath` -> `std.process.executableDirPath` * `std.fs.selfExeDirPathAlloc` -> `std.process.executableDirPathAlloc` * `std.fs.Dir.setAsCwd` -> `std.process.setCurrentDir` * `std.fs.Dir.realpath` -> `std.Io.Dir.realPathFile` * `std.fs.Dir.realpathAlloc` -> `std.Io.Dir.realPathFileAlloc` * `std.fs.Dir` -> `std.Io.Dir` * `std.fs.File` -> `std.Io.File` * `std.fs.Dir.makeDir` -> `std.Io.Dir.createDir` * `std.fs.Dir.makePath` -> `std.Io.Dir.createDirPath` * `std.fs.Dir.makeOpenDir` -> `std.Io.Dir.createDirPathOpen` * `std.fs.Dir.rename`: now accepts two `Dir` parameters (plus `Io`) * `std.fs.Dir.atomicSymLink` -> `std.Io.Dir.symLinkAtomic` * `std.fs.Dir.chmod` -> `std.Io.Dir.setPermissions` * `std.fs.Dir.chown` -> `std.Io.Dir.setOwner` * `std.fs.File.Mode` -> `std.Io.File.Permissions` * `std.fs.File.PermissionsWindows` -> `std.Io.File.Permissions` * `std.fs.File.PermissionsUnix` -> `std.Io.File.Permissions` * `std.fs.File.default_mode` -> `std.Io.File.Permissions.default_file` * `std.fs.File.getOrEnableAnsiEscapeSupport` -> `std.Io.File.enableAnsiEscapeCodes` * `std.fs.File.setEndPos` -> `std.Io.File.setLength` * `std.fs.File.getEndPos` -> `std.Io.File.length` * `std.fs.File.seekTo`, `std.fs.File.seekBy`, `std.fs.File.seekFromEnd` -> `std.Io.File.Reader.seekTo`, `std.Io.File.Reader.seekBy`, `std.Io.File.Writer.seekTo` * `std.fs.File.getPos` -> `std.Io.File.Reader.logicalPos`, `std.Io.Writer.logicalPos` * `std.fs.File.mode()` -> `std.Io.File.stat().permissions.toMode` * `std.fs.File.chmod` -> `std.Io.File.setPermissions` * `std.fs.File.chown` -> `std.Io.File.setOwner` * `std.fs.File.updateTimes` -> `std.Io.File.setTimestamps`, `std.Io.File.setTimestampsNow` * `std.fs.File.read` -> `std.Io.File.readStreaming` * `std.fs.File.readv` -> `std.Io.File.readStreaming` * `std.fs.File.pread` -> `std.Io.File.readPositional` * `std.fs.File.preadv` -> `std.Io.File.readPositional` * `std.fs.File.preadAll` -> `std.Io.File.readPositionalAll` * `std.fs.File.write` -> `std.Io.File.writeStreaming` * `std.fs.File.writev` -> `std.Io.File.writeStreaming` * `std.fs.File.pwrite` -> `std.Io.File.writePositional` * `std.fs.File.pwritev` -> `std.Io.File.writePositional` * `std.fs.File.writeAll` -> `std.Io.File.writeStreamingAll` * `std.fs.File.pwriteAll` -> `std.Io.File.writePositionalAll` * `std.fs.File.copyRange`, `std.fs.File.copyRangeAll` -> `std.Io.File.writer` ### Deprecated: * `std.fs.path` -> `std.Io.Dir.path` * `std.fs.max_path_bytes` -> `std.Io.Dir.max_path_bytes` * `std.fs.max_name_bytes` -> `std.Io.Dir.max_name_bytes` ### `std.Progress` Note After updating your application that uses `std.Progress`: ```diff - const root_progress_node = std.Progress.start(.{ + const root_progress_node = std.Progress.start(io, .{ ``` Make sure you have `defer root_progress_node.end();` there. Before, if control flow got to the end of main(), start code would exit all threads, including the `std.Progress` thread. Now, it is not a thread but a task, and you likely have `defer threaded.deinit();` above there, which will wait until all tasks are finished. If your application hangs, double check that your `std.Progress.start` have a matching `node.end()`. ## Followup Tasks * remove error.UnsupportedClock from some error sets * #30150 * https://github.com/ziglang/zig/issues/24510 ---- closes https://github.com/ziglang/zig/issues/25738 closes #30131 closes #30189 closes #30593
andrewrk force-pushed std.Io-fs from e5c5b78399
Some checks failed
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / x86_64-windows-release (pull_request) Failing after 6m2s
ci / x86_64-windows-debug (pull_request) Failing after 7m2s
ci / aarch64-macos-release (pull_request) Failing after 8m44s
ci / aarch64-macos-debug (pull_request) Failing after 9m50s
ci / x86_64-freebsd-release (pull_request) Failing after 14m55s
ci / x86_64-freebsd-debug (pull_request) Failing after 15m27s
ci / x86_64-linux-debug-llvm (pull_request) Failing after 29m50s
ci / x86_64-linux-debug (pull_request) Failing after 58m14s
ci / x86_64-linux-release (pull_request) Failing after 57m43s
ci / aarch64-linux-release (pull_request) Failing after 1h5m10s
ci / s390x-linux-release (pull_request) Failing after 1h3m23s
ci / loongarch64-linux-release (pull_request) Failing after 1h18m21s
ci / aarch64-linux-debug (pull_request) Failing after 3h0m31s
ci / loongarch64-linux-debug (pull_request) Failing after 4h0m27s
ci / s390x-linux-debug (pull_request) Failing after 5h0m39s
to a8554912fb
Some checks failed
ci / x86_64-linux-release (pull_request) Failing after 1m38s
ci / x86_64-freebsd-release (pull_request) Failing after 1m38s
ci / x86_64-windows-release (pull_request) Failing after 2m32s
ci / x86_64-freebsd-debug (pull_request) Failing after 2m21s
ci / aarch64-macos-debug (pull_request) Failing after 2m40s
ci / x86_64-linux-debug (pull_request) Failing after 2m48s
ci / aarch64-macos-release (pull_request) Failing after 2m20s
ci / x86_64-windows-debug (pull_request) Failing after 3m9s
ci / aarch64-linux-release (pull_request) Failing after 4m44s
ci / aarch64-linux-debug (pull_request) Failing after 6m20s
ci / x86_64-linux-debug-llvm (pull_request) Failing after 6m41s
ci / s390x-linux-debug (pull_request) Failing after 9m9s
ci / s390x-linux-release (pull_request) Failing after 6m37s
ci / loongarch64-linux-debug (pull_request) Failing after 11m45s
ci / loongarch64-linux-release (pull_request) Failing after 9m20s
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
2025-12-22 23:39:38 +01:00
Compare
andrewrk force-pushed std.Io-fs from 57390e70cb
Some checks failed
ci / x86_64-windows-release (pull_request) Failing after 4m23s
ci / aarch64-macos-release (pull_request) Failing after 3m54s
ci / aarch64-macos-debug (pull_request) Failing after 4m35s
ci / x86_64-windows-debug (pull_request) Failing after 4m56s
ci / x86_64-linux-release (pull_request) Failing after 9m12s
ci / x86_64-freebsd-release (pull_request) Failing after 26m48s
ci / s390x-linux-release (pull_request) Failing after 1h8m51s
ci / aarch64-linux-release (pull_request) Failing after 1h10m30s
ci / x86_64-freebsd-debug (pull_request) Failing after 2h0m15s
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / x86_64-linux-debug-llvm (pull_request) Failing after 2h54m14s
ci / x86_64-linux-debug (pull_request) Failing after 3h0m15s
ci / aarch64-linux-debug (pull_request) Failing after 3h0m26s
ci / loongarch64-linux-release (pull_request) Failing after 1h20m14s
ci / loongarch64-linux-debug (pull_request) Failing after 4h0m28s
ci / s390x-linux-debug (pull_request) Failing after 5h0m38s
to e8153cfd0a
Some checks failed
ci / x86_64-windows-release (pull_request) Failing after 4m50s
ci / aarch64-macos-release (pull_request) Failing after 3m52s
ci / aarch64-macos-debug (pull_request) Failing after 4m35s
ci / x86_64-windows-debug (pull_request) Failing after 5m51s
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / x86_64-freebsd-release (pull_request) Failing after 30m52s
ci / x86_64-linux-release (pull_request) Failing after 38m44s
ci / aarch64-linux-release (pull_request) Failing after 1h14m30s
ci / x86_64-freebsd-debug (pull_request) Failing after 2h0m16s
ci / s390x-linux-release (pull_request) Failing after 1h25m10s
ci / loongarch64-linux-release (pull_request) Failing after 1h31m41s
ci / aarch64-linux-debug (pull_request) Failing after 3h0m28s
ci / x86_64-linux-debug (pull_request) Failing after 3h0m24s
ci / x86_64-linux-debug-llvm (pull_request) Failing after 3h31m8s
ci / loongarch64-linux-debug (pull_request) Failing after 4h0m28s
ci / s390x-linux-debug (pull_request) Failing after 5h0m38s
2025-12-23 06:04:49 +01:00
Compare
Image
Author
Owner

Lots of these:

test-cases
└─ run exe safety.slicing null C pointer - runtime len
   └─ compile exe safety.slicing null C pointer - runtime len Debug aarch64-linux failure
error: Compiler crash context:
       Generating function 'Io.Threaded.dirSetTimestamps'
       
       thread 1184089 panic: reached unreachable code
       /home/andy/src/zig/lib/std/debug.zig:419:14: 0x678b029 in assert (std.zig)
           if (!ok) unreachable; // assertion failure
                    ^
       /home/andy/src/zig/src/codegen/aarch64/Select.zig:12263:31: 0x936e3ba in param (main.zig)
                               assert(parts_len == part_sizes.len);
                                     ^
       /home/andy/src/zig/src/codegen/aarch64.zig:82:47: 0x9397f73 in generate (main.zig)
                   break :param_vi try param_it.param(&isel, param_ty);
                                                     ^
       /home/andy/src/zig/src/codegen.zig:163:45: 0x939bfce in generateFunction (main.zig)
                   const mir = try CodeGen.generate(lf, pt, src_loc, func_index, air, liveness);
                                                   ^
       /home/andy/src/zig/src/Zcu/PerThread.zig:4612:36: 0x8d0d177 in runCodegenInner (main.zig)
           return codegen.generateFunction(lf, pt, zcu.navSrcLoc(nav), func_index, air, &liveness) catch |err| switch (err) {
                                          ^
       /home/andy/src/zig/src/Zcu/PerThread.zig:4488:43: 0x85dc75f in runCodegen (main.zig)
           const codegen_result = runCodegenInner(pt, func_index, air);
                                                 ^
       /home/andy/src/zig/src/Zcu.zig:5002:29: 0x7f891f4 in workerCodegenOwnedAir (main.zig)
               return pt.runCodegen(func_index, &air);
                                   ^
       /home/andy/src/zig/lib/std/Io.zig:2086:13: 0x795c4ff in start (std.zig)
                   result_casted.* = @call(.auto, function, args_casted.*);
                   ^
       /home/andy/src/zig/lib/std/Io/Threaded.zig:1081:16: 0x686bf2e in start (std.zig)
               ac.func(ac.contextPointer(), ac.resultPointer());
                      ^
       /home/andy/src/zig/lib/std/Io/Threaded.zig:755:26: 0x68f6be7 in worker (std.zig)
                   closure.start(closure, t);
                                ^
       /home/andy/src/zig/lib/std/Thread.zig:558:13: 0x68b3700 in callFn__anon_37224 (std.zig)
                   @call(.auto, f, args);
                   ^
       /home/andy/src/zig/lib/std/Thread.zig:829:30: 0x686caa9 in entryFn (std.zig)
                       return callFn(f, args_ptr.*);
                                    ^
       ???:?:?: 0x7f38b52978ed in start_thread (/nix/store/g8zyryr9cr6540xsyg4avqkwgxpnwj2a-glibc-2.40-66/lib/libc.so.6)
       ???:?:?: 0x7f38b531b9bb in __clone3 (/nix/store/g8zyryr9cr6540xsyg4avqkwgxpnwj2a-glibc-2.40-66/lib/libc.so.6)
       Compiler crash context:
       Generating function 'Io.Threaded.fileSetTimestamps'
error: process terminated unexpectedly
failed command: /home/andy/src/zig/build-release/stage4/bin/zig build-exe -fno-llvm -fno-lld -ODebug -target aarch64-linux -mcpu baseline -Mroot=/home/andy/src/zig/.zig-cache/o/aed59870eb519527fd6ac5f6397f24aa/tmp.zig --cache-dir /home/andy/src/zig/.zig-cache --global-cache-dir /home/andy/.cache/zig --name "safety.slicing null C pointer - runtime len" --zig-lib-dir /home/andy/src/zig/lib/ --listen=-

@jacobly shall I disable the test coverage, or do you want to land a fix prior to merging?

Lots of these: ``` test-cases └─ run exe safety.slicing null C pointer - runtime len └─ compile exe safety.slicing null C pointer - runtime len Debug aarch64-linux failure error: Compiler crash context: Generating function 'Io.Threaded.dirSetTimestamps' thread 1184089 panic: reached unreachable code /home/andy/src/zig/lib/std/debug.zig:419:14: 0x678b029 in assert (std.zig) if (!ok) unreachable; // assertion failure ^ /home/andy/src/zig/src/codegen/aarch64/Select.zig:12263:31: 0x936e3ba in param (main.zig) assert(parts_len == part_sizes.len); ^ /home/andy/src/zig/src/codegen/aarch64.zig:82:47: 0x9397f73 in generate (main.zig) break :param_vi try param_it.param(&isel, param_ty); ^ /home/andy/src/zig/src/codegen.zig:163:45: 0x939bfce in generateFunction (main.zig) const mir = try CodeGen.generate(lf, pt, src_loc, func_index, air, liveness); ^ /home/andy/src/zig/src/Zcu/PerThread.zig:4612:36: 0x8d0d177 in runCodegenInner (main.zig) return codegen.generateFunction(lf, pt, zcu.navSrcLoc(nav), func_index, air, &liveness) catch |err| switch (err) { ^ /home/andy/src/zig/src/Zcu/PerThread.zig:4488:43: 0x85dc75f in runCodegen (main.zig) const codegen_result = runCodegenInner(pt, func_index, air); ^ /home/andy/src/zig/src/Zcu.zig:5002:29: 0x7f891f4 in workerCodegenOwnedAir (main.zig) return pt.runCodegen(func_index, &air); ^ /home/andy/src/zig/lib/std/Io.zig:2086:13: 0x795c4ff in start (std.zig) result_casted.* = @call(.auto, function, args_casted.*); ^ /home/andy/src/zig/lib/std/Io/Threaded.zig:1081:16: 0x686bf2e in start (std.zig) ac.func(ac.contextPointer(), ac.resultPointer()); ^ /home/andy/src/zig/lib/std/Io/Threaded.zig:755:26: 0x68f6be7 in worker (std.zig) closure.start(closure, t); ^ /home/andy/src/zig/lib/std/Thread.zig:558:13: 0x68b3700 in callFn__anon_37224 (std.zig) @call(.auto, f, args); ^ /home/andy/src/zig/lib/std/Thread.zig:829:30: 0x686caa9 in entryFn (std.zig) return callFn(f, args_ptr.*); ^ ???:?:?: 0x7f38b52978ed in start_thread (/nix/store/g8zyryr9cr6540xsyg4avqkwgxpnwj2a-glibc-2.40-66/lib/libc.so.6) ???:?:?: 0x7f38b531b9bb in __clone3 (/nix/store/g8zyryr9cr6540xsyg4avqkwgxpnwj2a-glibc-2.40-66/lib/libc.so.6) Compiler crash context: Generating function 'Io.Threaded.fileSetTimestamps' error: process terminated unexpectedly failed command: /home/andy/src/zig/build-release/stage4/bin/zig build-exe -fno-llvm -fno-lld -ODebug -target aarch64-linux -mcpu baseline -Mroot=/home/andy/src/zig/.zig-cache/o/aed59870eb519527fd6ac5f6397f24aa/tmp.zig --cache-dir /home/andy/src/zig/.zig-cache --global-cache-dir /home/andy/.cache/zig --name "safety.slicing null C pointer - runtime len" --zig-lib-dir /home/andy/src/zig/lib/ --listen=- ``` @jacobly shall I disable the test coverage, or do you want to land a fix prior to merging?
andrewrk force-pushed std.Io-fs from 75e3903a70
Some checks failed
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / aarch64-macos-release (pull_request) Failing after 3m52s
ci / aarch64-macos-debug (pull_request) Failing after 4m32s
ci / x86_64-windows-release (pull_request) Failing after 4m35s
ci / x86_64-windows-debug (pull_request) Failing after 5m14s
ci / x86_64-freebsd-release (pull_request) Failing after 38m48s
ci / x86_64-freebsd-debug (pull_request) Failing after 52m26s
ci / aarch64-linux-release (pull_request) Failing after 1h10m19s
ci / x86_64-linux-debug (pull_request) Failing after 1h13m53s
ci / x86_64-linux-release (pull_request) Failing after 1h12m54s
ci / x86_64-linux-debug-llvm (pull_request) Failing after 1h13m19s
ci / aarch64-linux-debug (pull_request) Failing after 2h7m31s
ci / s390x-linux-release (pull_request) Failing after 1h42m47s
ci / s390x-linux-debug (pull_request) Failing after 2h21m2s
ci / loongarch64-linux-debug (pull_request) Failing after 2h30m47s
ci / loongarch64-linux-release (pull_request) Failing after 1h51m43s
to c9a609a61a
Some checks failed
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / aarch64-macos-release (pull_request) Failing after 4m36s
ci / aarch64-macos-debug (pull_request) Failing after 5m19s
ci / x86_64-windows-release (pull_request) Failing after 6m45s
ci / x86_64-windows-debug (pull_request) Failing after 7m57s
ci / x86_64-freebsd-release (pull_request) Failing after 40m36s
ci / x86_64-freebsd-debug (pull_request) Failing after 46m48s
ci / x86_64-linux-debug (pull_request) Failing after 1h11m37s
ci / aarch64-linux-release (pull_request) Failing after 1h16m7s
ci / s390x-linux-release (pull_request) Failing after 1h18m9s
ci / x86_64-linux-release (pull_request) Failing after 1h23m8s
ci / aarch64-linux-debug (pull_request) Failing after 1h49m13s
ci / loongarch64-linux-release (pull_request) Failing after 1h56m52s
ci / loongarch64-linux-debug (pull_request) Failing after 2h50m0s
ci / x86_64-linux-debug-llvm (pull_request) Failing after 2h52m30s
ci / s390x-linux-debug (pull_request) Failing after 2h58m31s
2025-12-24 07:15:29 +01:00
Compare
Image fix the guess number game example
Some checks failed
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / x86_64-windows-release (pull_request) Failing after 4m55s
ci / x86_64-windows-debug (pull_request) Failing after 5m42s
ci / aarch64-macos-release (pull_request) Failing after 5m25s
ci / aarch64-macos-debug (pull_request) Failing after 6m23s
ci / x86_64-freebsd-release (pull_request) Failing after 38m10s
ci / x86_64-freebsd-debug (pull_request) Failing after 53m28s
ci / x86_64-linux-debug (pull_request) Failing after 1h20m19s
ci / aarch64-linux-release (pull_request) Successful in 1h35m26s
ci / x86_64-linux-release (pull_request) Failing after 1h50m47s
ci / aarch64-linux-debug (pull_request) Failing after 1h57m25s
ci / s390x-linux-release (pull_request) Successful in 1h51m11s
ci / x86_64-linux-debug-llvm (pull_request) Failing after 2h52m39s
ci / s390x-linux-debug (pull_request) Failing after 2h39m4s
ci / loongarch64-linux-release (pull_request) Successful in 2h9m26s
ci / loongarch64-linux-debug (pull_request) Failing after 2h50m26s
2708a3c1ac
Image std.Io.Threaded: implement process executable path on darwin
Some checks failed
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / x86_64-windows-release (pull_request) Failing after 5m36s
ci / x86_64-windows-debug (pull_request) Failing after 6m21s
ci / x86_64-freebsd-release (pull_request) Failing after 33m45s
ci / aarch64-macos-release (pull_request) Failing after 47m34s
ci / x86_64-freebsd-debug (pull_request) Failing after 52m9s
ci / aarch64-linux-release (pull_request) Failing after 1h12m11s
ci / x86_64-linux-debug (pull_request) Failing after 1h38m53s
ci / x86_64-linux-debug-llvm (pull_request) Failing after 1h46m15s
ci / x86_64-linux-release (pull_request) Failing after 1h45m45s
ci / aarch64-linux-debug (pull_request) Failing after 1h53m45s
ci / aarch64-macos-debug (pull_request) Failing after 1h56m2s
ci / s390x-linux-release (pull_request) Failing after 1h19m11s
ci / s390x-linux-debug (pull_request) Failing after 2h24m13s
ci / loongarch64-linux-release (pull_request) Failing after 1h37m54s
ci / loongarch64-linux-debug (pull_request) Failing after 2h52m54s
a901e92413
Image std.Io.Threaded: prevent 0-byte file writes
Some checks failed
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / x86_64-windows-release (pull_request) Failing after 4m32s
ci / x86_64-windows-debug (pull_request) Failing after 5m6s
ci / x86_64-freebsd-release (pull_request) Failing after 38m0s
ci / x86_64-linux-debug (pull_request) Failing after 30m47s
ci / x86_64-freebsd-debug (pull_request) Failing after 48m12s
ci / aarch64-macos-release (pull_request) Failing after 56m31s
ci / aarch64-linux-release (pull_request) Failing after 1h10m29s
ci / aarch64-macos-debug (pull_request) Failing after 1h57m42s
ci / aarch64-linux-debug (pull_request) Failing after 1h53m3s
ci / x86_64-linux-release (pull_request) Failing after 2h6m1s
ci / x86_64-linux-debug-llvm (pull_request) Failing after 2h6m31s
ci / s390x-linux-release (pull_request) Failing after 1h15m18s
ci / s390x-linux-debug (pull_request) Failing after 2h33m8s
ci / loongarch64-linux-release (pull_request) Failing after 1h45m51s
ci / loongarch64-linux-debug (pull_request) Failing after 2h48m50s
ace08ba642
these cause EINVAL on darwin and are generally a wasted syscall.

and remove a bogus error from File.Writer.Error.
Image std.Io.Threaded: wasi does not support processExecutablePath
Some checks failed
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / x86_64-windows-release (pull_request) Failing after 4m20s
ci / x86_64-windows-debug (pull_request) Failing after 5m3s
ci / x86_64-freebsd-release (pull_request) Failing after 29m47s
ci / x86_64-freebsd-debug (pull_request) Failing after 38m48s
ci / aarch64-macos-release (pull_request) Successful in 52m28s
ci / aarch64-macos-debug (pull_request) Failing after 1h29m2s
ci / x86_64-linux-debug-llvm (pull_request) Failing after 1h29m38s
ci / aarch64-linux-release (pull_request) Successful in 1h32m51s
ci / x86_64-linux-debug (pull_request) Failing after 1h43m1s
ci / x86_64-linux-release (pull_request) Failing after 1h42m34s
ci / aarch64-linux-debug (pull_request) Failing after 1h55m13s
ci / s390x-linux-release (pull_request) Successful in 1h45m16s
ci / s390x-linux-debug (pull_request) Failing after 1h55m49s
ci / loongarch64-linux-debug (pull_request) Failing after 2h23m54s
ci / loongarch64-linux-release (pull_request) Successful in 1h55m43s
6f4e93f0dd
Image
Author
Owner

Another one:

       stack trace:
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:12026:29: 0x89128f6 in finishReturn (zig)
                           else => unreachable,
                                   ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:3649:34: 0x823db64 in body (zig)
                   try call.finishReturn(isel);
                                        ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:4575:30: 0x824cbf9 in body (zig)
                       try isel.body(case.body);
                                    ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:4529:26: 0x824bf4a in body (zig)
                   try isel.body(@ptrCast(isel.air.extra.items[extra.end + extra.data.then_body_len ..][0..extra.data.else_body_len]));
                                ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:8006:18: 0x891419c in block (zig)
           try isel.body(air_body);
                        ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:3520:27: 0x823c1cd in body (zig)
                   try isel.block(air.inst_index, ty_pl.ty.toType(), @ptrCast(
                                 ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64.zig:155:18: 0x821d2eb in generate (zig)
           try isel.body(air_main_body);
                        ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen.zig:163:45: 0x7decf57 in generateFunction (zig)
                   const mir = try CodeGen.generate(lf, pt, src_loc, func_index, air, liveness);
                                                   ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/Zcu/PerThread.zig:4612:36: 0x7968d43 in runCodegenInner (zig)
           return codegen.generateFunction(lf, pt, zcu.navSrcLoc(nav), func_index, air, &liveness) catch |err| switch (err) {
                                          ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/Zcu/PerThread.zig:4488:43: 0x73f094b in runCodegen (zig)
           const codegen_result = runCodegenInner(pt, func_index, air);
                                                 ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/Zcu.zig:5002:29: 0x701b35e in workerCodegenOwnedAir (zig)
               return pt.runCodegen(func_index, &air);
                                   ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/std/Io.zig:2087:13: 0x6b33c3d in start (zig)
                   result_casted.* = @call(.auto, function, args_casted.*);
                   ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/std/Io/Threaded.zig:1086:16: 0x5f87a05 in start (zig)
               ac.func(ac.contextPointer(), ac.resultPointer());
                      ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/std/Io/Threaded.zig:758:26: 0x5ff88b1 in worker (zig)
                   closure.start(closure, t);
                                ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/std/Thread.zig:558:13: 0x5fc035d in callFn__anon_36861 (zig)
                   @call(.auto, f, args);
                   ^
       /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/std/Thread.zig:829:30: 0x5f888ab in entryFn (zig)
                       return callFn(f, args_ptr.*);
                                    ^

error: process terminated unexpectedly
failed command: /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/build-debug-llvm/stage3-debug/bin/zig test -fno-llvm -fno-lld -fstrip -fbuiltin -OReleaseFast -target aarch64-linux-none -mcpu baseline -Mroot=/home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/compiler_rt.zig --cache-dir /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/zig-local-cache --global-cache-dir /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/zig-global-cache --name test -L /home/ci/deps/zig+llvm+lld+clang-x86_64-linux-musl-0.16.0-dev.104+689461e31/lib -I /home/ci/deps/zig+llvm+lld+clang-x86_64-linux-musl-0.16.0-dev.104+689461e31/include --zig-lib-dir /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib --listen=-

I'm going to fully disable aarch64 backend tests for now.

Another one: ``` stack trace: /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:12026:29: 0x89128f6 in finishReturn (zig) else => unreachable, ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:3649:34: 0x823db64 in body (zig) try call.finishReturn(isel); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:4575:30: 0x824cbf9 in body (zig) try isel.body(case.body); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:4529:26: 0x824bf4a in body (zig) try isel.body(@ptrCast(isel.air.extra.items[extra.end + extra.data.then_body_len ..][0..extra.data.else_body_len])); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:8006:18: 0x891419c in block (zig) try isel.body(air_body); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64/Select.zig:3520:27: 0x823c1cd in body (zig) try isel.block(air.inst_index, ty_pl.ty.toType(), @ptrCast( ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen/aarch64.zig:155:18: 0x821d2eb in generate (zig) try isel.body(air_main_body); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/codegen.zig:163:45: 0x7decf57 in generateFunction (zig) const mir = try CodeGen.generate(lf, pt, src_loc, func_index, air, liveness); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/Zcu/PerThread.zig:4612:36: 0x7968d43 in runCodegenInner (zig) return codegen.generateFunction(lf, pt, zcu.navSrcLoc(nav), func_index, air, &liveness) catch |err| switch (err) { ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/Zcu/PerThread.zig:4488:43: 0x73f094b in runCodegen (zig) const codegen_result = runCodegenInner(pt, func_index, air); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/src/Zcu.zig:5002:29: 0x701b35e in workerCodegenOwnedAir (zig) return pt.runCodegen(func_index, &air); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/std/Io.zig:2087:13: 0x6b33c3d in start (zig) result_casted.* = @call(.auto, function, args_casted.*); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/std/Io/Threaded.zig:1086:16: 0x5f87a05 in start (zig) ac.func(ac.contextPointer(), ac.resultPointer()); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/std/Io/Threaded.zig:758:26: 0x5ff88b1 in worker (zig) closure.start(closure, t); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/std/Thread.zig:558:13: 0x5fc035d in callFn__anon_36861 (zig) @call(.auto, f, args); ^ /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/std/Thread.zig:829:30: 0x5f888ab in entryFn (zig) return callFn(f, args_ptr.*); ^ error: process terminated unexpectedly failed command: /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/build-debug-llvm/stage3-debug/bin/zig test -fno-llvm -fno-lld -fstrip -fbuiltin -OReleaseFast -target aarch64-linux-none -mcpu baseline -Mroot=/home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib/compiler_rt.zig --cache-dir /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/zig-local-cache --global-cache-dir /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/zig-global-cache --name test -L /home/ci/deps/zig+llvm+lld+clang-x86_64-linux-musl-0.16.0-dev.104+689461e31/lib -I /home/ci/deps/zig+llvm+lld+clang-x86_64-linux-musl-0.16.0-dev.104+689461e31/include --zig-lib-dir /home/ci/.cache/act/8818d6f864b3b4d3/hostexecutor/lib --listen=- ``` I'm going to fully disable aarch64 backend tests for now.
this isn't meant to be a precisely measured thing that is different per
operating system. it's meant to have some room for growth but not too
much.
When linking libc, and the directory is the cwd.

This avoids bugs on FreeBSD.
andrewrk force-pushed std.Io-fs from 27510854ce
Some checks failed
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / aarch64-linux-debug (pull_request) Has been cancelled
ci / aarch64-macos-release (pull_request) Has been cancelled
ci / x86_64-linux-debug-llvm (pull_request) Has been cancelled
ci / s390x-linux-release (pull_request) Has been cancelled
ci / s390x-linux-debug (pull_request) Has been cancelled
ci / aarch64-macos-debug (pull_request) Has been cancelled
ci / aarch64-linux-release (pull_request) Has been cancelled
ci / loongarch64-linux-debug (pull_request) Has been cancelled
ci / x86_64-linux-release (pull_request) Has been cancelled
ci / x86_64-windows-release (pull_request) Has been cancelled
ci / x86_64-windows-debug (pull_request) Has been cancelled
ci / x86_64-freebsd-debug (pull_request) Has been cancelled
ci / x86_64-freebsd-release (pull_request) Has been cancelled
ci / x86_64-linux-debug (pull_request) Has been cancelled
ci / loongarch64-linux-release (pull_request) Has been cancelled
to d8460910b4
Some checks failed
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / x86_64-freebsd-release (pull_request) Successful in 33m15s
ci / x86_64-windows-release (pull_request) Successful in 40m8s
ci / x86_64-windows-debug (pull_request) Successful in 40m27s
ci / x86_64-freebsd-debug (pull_request) Successful in 46m40s
ci / aarch64-macos-release (pull_request) Successful in 46m30s
ci / x86_64-linux-debug (pull_request) Successful in 57m46s
ci / aarch64-macos-debug (pull_request) Successful in 1h23m30s
ci / s390x-linux-release (pull_request) Successful in 1h26m20s
ci / aarch64-linux-release (pull_request) Successful in 1h26m1s
ci / x86_64-linux-release (pull_request) Failing after 1h43m24s
ci / loongarch64-linux-release (pull_request) Successful in 1h57m59s
ci / x86_64-linux-debug-llvm (pull_request) Successful in 2h14m27s
ci / aarch64-linux-debug (pull_request) Successful in 2h26m10s
ci / s390x-linux-debug (pull_request) Successful in 2h44m0s
ci / loongarch64-linux-debug (pull_request) Successful in 2h44m15s
2025-12-27 04:59:25 +01:00
Compare
andrewrk scheduled this pull request to auto merge when all checks succeed 2025-12-27 05:01:05 +01:00
mlugg force-pushed std.Io-fs from f2ab220bdc
Some checks failed
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / aarch64-linux-debug (pull_request) Has been cancelled
ci / loongarch64-linux-debug (pull_request) Has been cancelled
ci / aarch64-linux-release (pull_request) Has been cancelled
ci / loongarch64-linux-release (pull_request) Has been cancelled
ci / aarch64-macos-debug (pull_request) Has been cancelled
ci / aarch64-macos-release (pull_request) Has been cancelled
ci / s390x-linux-release (pull_request) Has been cancelled
ci / x86_64-windows-debug (pull_request) Has been cancelled
ci / s390x-linux-debug (pull_request) Has been cancelled
ci / x86_64-windows-release (pull_request) Has been cancelled
ci / x86_64-freebsd-release (pull_request) Has been cancelled
ci / x86_64-freebsd-debug (pull_request) Has been cancelled
ci / x86_64-linux-debug (pull_request) Has been cancelled
ci / x86_64-linux-release (pull_request) Has been cancelled
ci / x86_64-linux-debug-llvm (pull_request) Has been cancelled
to 60a1ba0a8f
All checks were successful
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
ci / x86_64-freebsd-release (pull_request) Successful in 32m54s
ci / aarch64-macos-release (pull_request) Successful in 37m6s
ci / x86_64-windows-debug (pull_request) Successful in 38m30s
ci / x86_64-windows-release (pull_request) Successful in 43m37s
ci / x86_64-freebsd-debug (pull_request) Successful in 46m41s
ci / x86_64-linux-debug (pull_request) Successful in 59m7s
ci / x86_64-linux-release (pull_request) Successful in 1h21m25s
ci / aarch64-macos-debug (pull_request) Successful in 1h21m24s
ci / aarch64-linux-release (pull_request) Successful in 1h25m27s
ci / s390x-linux-release (pull_request) Successful in 1h26m13s
ci / loongarch64-linux-release (pull_request) Successful in 1h53m23s
ci / x86_64-linux-debug-llvm (pull_request) Successful in 2h16m47s
ci / s390x-linux-debug (pull_request) Successful in 2h40m57s
ci / aarch64-linux-debug (pull_request) Successful in 2h41m24s
ci / loongarch64-linux-debug (pull_request) Successful in 2h44m43s
2025-12-27 11:25:44 +01:00
Compare
Image andrewrk merged commit e55e6b5528 into master 2025-12-27 14:10:53 +01:00
Image andrewrk deleted branch std.Io-fs 2025-12-27 14:11:30 +01:00
Image
Contributor

std.fs.File.getEndPos -> std.Io.File.getLength

The getLength function doesn't exist in std.Io.File, however, I am able the length function for this functionality.

Is there a typo here or should I create a PR renaming length to getLength ?

> `std.fs.File.getEndPos -> std.Io.File.getLength` The `getLength` function doesn't exist in `std.Io.File`, however, I am able the `length` function for this functionality. Is there a typo here or should I create a PR renaming `length` to `getLength` ?
Image
Author
Owner

Thank you, it is a typo here

Thank you, it is a typo here
Image
Contributor

Just to have it documented here (for release notes): This breaks stack walking on freestanding by making things like captureStackTrace implicitly depend on std.Options.debug_io.

There, we, on freestanding, need to set root.std_options_debug_io to some std.Io interface that:

  • needs to work when we have our debug.SelfInfo.can_unwind == true (iirc) and our unwind_frame function actually uses any function from the std.Io interface
  • does not need to work when we either use stack unwinding (called the "unsafe" option) or don't use the std.Io interface while unwinding (if it stays so that captureStackTrace does nothing with the io parameter and only gives it to unwindFrame).

Option 2 ("does not need to work") could be #30691.

Just to have it documented here (for release notes): This breaks stack walking on freestanding by making things like `captureStackTrace` implicitly depend on `std.Options.debug_io`. There, we, on freestanding, need to set `root.std_options_debug_io` to some `std.Io` interface that: * needs to work when we have our `debug.SelfInfo.can_unwind == true` (iirc) and our `unwind_frame` function actually uses any function from the std.Io interface * does not need to work when we either use stack unwinding (called the "unsafe" option) or don't use the std.Io interface while unwinding (if it stays so that captureStackTrace does nothing with the `io` parameter and only gives it to `unwindFrame`). Option 2 ("does not need to work") could be #30691.
Image
Author
Owner

This is a closed issue, could you make an open issue to track that problem, please?

This is a closed issue, could you make an open issue to track that problem, please?
Sign in to join this conversation.
No reviewers
No labels
abi/f32
abi/ilp32
abi/n32
abi/sf
abi/x32
accepted
arch/1750a
arch/21k
arch/6502
arch/a29k
arch/aarch64
arch/alpha
arch/amdgcn
arch/arc
arch/arc32
arch/arc64
arch/arm
arch/avr
arch/avr32
arch/bfin
arch/bpf
arch/clipper
arch/colossus
arch/cr16
arch/cris
arch/csky
arch/dlx
arch/dsp16xx
arch/elxsi
arch/epiphany
arch/fr30
arch/frv
arch/h8300
arch/h8500
arch/hexagon
arch/hppa
arch/hppa64
arch/i370
arch/i860
arch/i960
arch/ia64
arch/ip2k
arch/kalimba
arch/kvx
arch/lanai
arch/lm32
arch/loongarch32
arch/loongarch64
arch/m32r
arch/m68k
arch/m88k
arch/maxq
arch/mcore
arch/metag
arch/microblaze
arch/mips
arch/mips64
arch/mmix
arch/mn10200
arch/mn10300
arch/moxie
arch/mrisc32
arch/msp430
arch/nds32
arch/nios2
arch/ns32k
arch/nvptx
arch/or1k
arch/pdp10
arch/pdp11
arch/pj
arch/powerpc
arch/powerpc64
arch/propeller
arch/riscv32
arch/riscv64
arch/rl78
arch/rx
arch/s390
arch/s390x
arch/sh
arch/sh64
arch/sparc
arch/sparc64
arch/spirv
arch/spu
arch/st200
arch/starcore
arch/tilegx
arch/tilepro
arch/tricore
arch/ts
arch/ubicom8
arch/v850
arch/vax
arch/vc4
arch/ve
arch/wasm
arch/we32k
arch/x86
arch/x86_64
arch/xcore
arch/xgate
arch/xstormy16
arch/xtensa
autodoc
backend/c
backend/llvm
backend/self-hosted
binutils
breaking
build system
debug info
docs
error message
frontend
fuzzing
incremental
lib/c
lib/compiler-rt
lib/cxx
lib/std
lib/tsan
lib/ubsan-rt
lib/unwind
linking
miscompilation
os/aix
os/android
os/bridgeos
os/contiki
os/dragonfly
os/driverkit
os/emscripten
os/freebsd
os/fuchsia
os/haiku
os/hermit
os/hurd
os/illumos
os/ios
os/kfreebsd
os/linux
os/maccatalyst
os/macos
os/managarm
os/netbsd
os/ohos
os/openbsd
os/plan9
os/redox
os/rtems
os/serenity
os/solaris
os/tvos
os/uefi
os/visionos
os/wali
os/wasi
os/watchos
os/windows
os/zos
proposal
release notes
testing
tier system
zig cc
zig fmt
bounty
bug
contributor-friendly
downstream
enhancement
infra
optimization
question
regression
upstream
No milestone
No project
No assignees
4 participants
Notifications
Due date
The due date is invalid or out of range. Please use the format "yyyy-mm-dd".

No due date set.

Dependencies

No dependencies set.

Reference
ziglang/zig!30232
No description provided.