WIP: Implement package fetch retries #30171

Draft
joshua-holmes wants to merge 10 commits from joshua-holmes/zig:master into master
First-time contributor

The original PR is in GitHub.

Overview

Like in GitHub issue #17472, the package manager does not retry fetching when communication to the server fails in a way that could possibly be resolved by retrying the fetch.

Solution

  • Default retries is 3 (total of 4 attempts)
    • For some HTTP failures (500+, 429, 404), try parsing the "Retry-After" header, which could be a number of seconds or an HTTP date string referring to a date in the future.
      • I used the MDN Retry-After docs and MDN Date docs to inform me on how to parse Retry-After. If parsing fails, we skip reading it.
      • Adheres to our 10 sec max, so we will never wait longer than that, even if "Retry-After" tells us to, just like in Cargo.
      • If "Retry-After" is set to a point in time in the past, we ignore the header and calculate our delay (with jitter) as normal.
    • If we don't use "Retry-After", first delay is a randomized value between 500ms and 1500ms
    • Subsequent delays are linear backoff 3000ms, 6000ms, etc up to a max of 10 seconds. Note that Cargo uses 3500 and 6500, etc instead. I just felt this was simpler.
  • Classification of spurious (retryable) errors can be shown in the code linked here. This is a combination of what Cargo and uv thinks is spurious, plus my common sense. HTTP status codes 500+, 429, and 404 are considered spurious. Others are not.
  • Extended lib/std/time/epoch.zig, which was necessary to convert date to epoch seconds

Testing

I unit tested quite a bit of the new code, and the tests pass. I also tested this locally with and without network failures, while logging before and after the delays to see that the number matched with real delay. I also tested this with a local endpoint that includes a "Retry-After" header. All works really well.

That being said, I have rebased a few times since doing all that testing and have only lightly tested my code since the rebases. Trying to keep my PR up to date is time consuming and testing it every time is more time consuming. But so far my light tests have worked and I'm happy to perform my thorough tests again at any time. I am doubtful the rebases have introduced a bug, though.

The [original PR is in GitHub](https://github.com/ziglang/zig/pull/25120). # Overview Like in [GitHub issue #17472](https://github.com/ziglang/zig/issues/17472), the package manager does not retry fetching when communication to the server fails in a way that could possibly be resolved by retrying the fetch. # Solution - Default retries is 3 (total of 4 attempts) - For some HTTP failures (500+, 429, 404), try parsing the "Retry-After" header, which could be a number of seconds or an HTTP date string referring to a date in the future. - I used the [MDN Retry-After docs](https://developer.mozilla.org/en-US/docs/Web/HTTP/Reference/Headers/Retry-After) and [MDN Date docs](https://developer.mozilla.org/en-US/docs/Web/HTTP/Reference/Headers/Date) to inform me on how to parse Retry-After. If parsing fails, we skip reading it. - Adheres to our 10 sec max, so we will never wait longer than that, even if "Retry-After" tells us to, just like in Cargo. - If "Retry-After" is set to a point in time in the past, we ignore the header and calculate our delay (with jitter) as normal. - If we don't use "Retry-After", first delay is a randomized value between 500ms and 1500ms - Subsequent delays are linear backoff 3000ms, 6000ms, etc up to a max of 10 seconds. Note that Cargo uses 3500 and 6500, etc instead. I just felt this was simpler. - Classification of spurious (retryable) errors can be shown in the [code linked here](https://github.com/ziglang/zig/blob/6b3f0c411ee1c3530cbb552e9e2a8ab4647fd949/src/Package/Fetch.zig#L384). This is a combination of what Cargo and uv thinks is spurious, plus my common sense. HTTP status codes 500+, 429, and 404 are considered spurious. Others are not. - Extended `lib/std/time/epoch.zig`, which was necessary to convert date to epoch seconds # Testing I unit tested quite a bit of the new code, and the tests pass. I also tested this locally with and without network failures, while logging before and after the delays to see that the number matched with real delay. I also tested this with a local endpoint that includes a "Retry-After" header. All works really well. That being said, I have rebased a few times since doing all that testing and have only lightly tested my code since the rebases. Trying to keep my PR up to date is time consuming and testing it every time is more time consuming. But so far my light tests have worked and I'm happy to perform my thorough tests again at any time. I am doubtful the rebases have introduced a bug, though.
There are some locations where memory is being freed that wasn't being
freed before. This is because, in the case of the user possibly
configuring `Fetch` to retry many times, I don't want the allocator to
allocate without freeing each time it attempts to refetch the network
data, resulting in a memory leak.
`ConnectTcpError` is a subset of `ConnectError`, but the 4 additional
errors that `ConnectError` comes with:
```zig
error{
    UnsupportedUriScheme,
    UriMissingHost,
    UriHostTooLong,
    CertificateBundleLoadFailure,
}
```
...are never returned by `Client.connect()`. So we are communicating
that this method could return 1 of those 4 types, when in reality, it
never can. This commit fixes this communication error.
Write tests for "Retry-After" header parser
Some checks are pending
ci / aarch64-linux-debug (pull_request) Blocked by required conditions
ci / aarch64-linux-release (pull_request) Blocked by required conditions
ci / aarch64-macos-debug (pull_request) Blocked by required conditions
ci / aarch64-macos-release (pull_request) Blocked by required conditions
ci / loongarch64-linux-debug (pull_request) Blocked by required conditions
ci / loongarch64-linux-release (pull_request) Blocked by required conditions
ci / riscv64-linux-debug (pull_request) Blocked by required conditions
ci / riscv64-linux-release (pull_request) Blocked by required conditions
ci / s390x-linux-debug (pull_request) Blocked by required conditions
ci / s390x-linux-release (pull_request) Blocked by required conditions
ci / x86_64-freebsd-debug (pull_request) Blocked by required conditions
ci / x86_64-freebsd-release (pull_request) Blocked by required conditions
ci / x86_64-linux-debug (pull_request) Blocked by required conditions
ci / x86_64-linux-debug-llvm (pull_request) Blocked by required conditions
ci / x86_64-linux-release (pull_request) Blocked by required conditions
ci / x86_64-windows-debug (pull_request) Blocked by required conditions
ci / x86_64-windows-release (pull_request) Blocked by required conditions
226176018e
joshua-holmes force-pushed master from 226176018e
Some checks are pending
ci / aarch64-linux-debug (pull_request) Blocked by required conditions
ci / aarch64-linux-release (pull_request) Blocked by required conditions
ci / aarch64-macos-debug (pull_request) Blocked by required conditions
ci / aarch64-macos-release (pull_request) Blocked by required conditions
ci / loongarch64-linux-debug (pull_request) Blocked by required conditions
ci / loongarch64-linux-release (pull_request) Blocked by required conditions
ci / riscv64-linux-debug (pull_request) Blocked by required conditions
ci / riscv64-linux-release (pull_request) Blocked by required conditions
ci / s390x-linux-debug (pull_request) Blocked by required conditions
ci / s390x-linux-release (pull_request) Blocked by required conditions
ci / x86_64-freebsd-debug (pull_request) Blocked by required conditions
ci / x86_64-freebsd-release (pull_request) Blocked by required conditions
ci / x86_64-linux-debug (pull_request) Blocked by required conditions
ci / x86_64-linux-debug-llvm (pull_request) Blocked by required conditions
ci / x86_64-linux-release (pull_request) Blocked by required conditions
ci / x86_64-windows-debug (pull_request) Blocked by required conditions
ci / x86_64-windows-release (pull_request) Blocked by required conditions
to 66b7e1a20e
Some checks are pending
ci / aarch64-linux-debug (pull_request) Blocked by required conditions
ci / aarch64-linux-release (pull_request) Blocked by required conditions
ci / aarch64-macos-debug (pull_request) Blocked by required conditions
ci / aarch64-macos-release (pull_request) Blocked by required conditions
ci / loongarch64-linux-debug (pull_request) Blocked by required conditions
ci / loongarch64-linux-release (pull_request) Blocked by required conditions
ci / riscv64-linux-debug (pull_request) Blocked by required conditions
ci / riscv64-linux-release (pull_request) Blocked by required conditions
ci / s390x-linux-debug (pull_request) Blocked by required conditions
ci / s390x-linux-release (pull_request) Blocked by required conditions
ci / x86_64-freebsd-debug (pull_request) Blocked by required conditions
ci / x86_64-freebsd-release (pull_request) Blocked by required conditions
ci / x86_64-linux-debug (pull_request) Blocked by required conditions
ci / x86_64-linux-debug-llvm (pull_request) Blocked by required conditions
ci / x86_64-linux-release (pull_request) Blocked by required conditions
ci / x86_64-windows-debug (pull_request) Blocked by required conditions
ci / x86_64-windows-release (pull_request) Blocked by required conditions
2025-12-12 00:56:23 +01:00
Compare
joshua-holmes changed title from master to WIP: master 2025-12-12 00:57:02 +01:00
joshua-holmes force-pushed master from 66b7e1a20e
Some checks are pending
ci / aarch64-linux-debug (pull_request) Blocked by required conditions
ci / aarch64-linux-release (pull_request) Blocked by required conditions
ci / aarch64-macos-debug (pull_request) Blocked by required conditions
ci / aarch64-macos-release (pull_request) Blocked by required conditions
ci / loongarch64-linux-debug (pull_request) Blocked by required conditions
ci / loongarch64-linux-release (pull_request) Blocked by required conditions
ci / riscv64-linux-debug (pull_request) Blocked by required conditions
ci / riscv64-linux-release (pull_request) Blocked by required conditions
ci / s390x-linux-debug (pull_request) Blocked by required conditions
ci / s390x-linux-release (pull_request) Blocked by required conditions
ci / x86_64-freebsd-debug (pull_request) Blocked by required conditions
ci / x86_64-freebsd-release (pull_request) Blocked by required conditions
ci / x86_64-linux-debug (pull_request) Blocked by required conditions
ci / x86_64-linux-debug-llvm (pull_request) Blocked by required conditions
ci / x86_64-linux-release (pull_request) Blocked by required conditions
ci / x86_64-windows-debug (pull_request) Blocked by required conditions
ci / x86_64-windows-release (pull_request) Blocked by required conditions
to acc55ae3b6
Some checks are pending
ci / aarch64-linux-debug (pull_request) Blocked by required conditions
ci / aarch64-linux-release (pull_request) Blocked by required conditions
ci / aarch64-macos-debug (pull_request) Blocked by required conditions
ci / aarch64-macos-release (pull_request) Blocked by required conditions
ci / loongarch64-linux-debug (pull_request) Blocked by required conditions
ci / loongarch64-linux-release (pull_request) Blocked by required conditions
ci / riscv64-linux-debug (pull_request) Blocked by required conditions
ci / riscv64-linux-release (pull_request) Blocked by required conditions
ci / s390x-linux-debug (pull_request) Blocked by required conditions
ci / s390x-linux-release (pull_request) Blocked by required conditions
ci / x86_64-freebsd-debug (pull_request) Blocked by required conditions
ci / x86_64-freebsd-release (pull_request) Blocked by required conditions
ci / x86_64-linux-debug (pull_request) Blocked by required conditions
ci / x86_64-linux-debug-llvm (pull_request) Blocked by required conditions
ci / x86_64-linux-release (pull_request) Blocked by required conditions
ci / x86_64-windows-debug (pull_request) Blocked by required conditions
ci / x86_64-windows-release (pull_request) Blocked by required conditions
2025-12-12 00:59:12 +01:00
Compare
joshua-holmes changed title from WIP: master to master 2025-12-12 01:05:53 +01:00
Owner

Note that master on Codeberg and GitHub have diverged; a493e7923e is not on Codeberg. So you will need to rebase this PR on Codeberg master.

Note that `master` on Codeberg and GitHub have diverged; a493e7923e72594e9c364ad55f32c7c43cdd02e9 is not on Codeberg. So you will need to rebase this PR on Codeberg `master`.
joshua-holmes changed title from master to Implement package fetch retries 2025-12-12 01:08:53 +01:00
Author
First-time contributor

@alexrp thanks for letting me know, I have already done so.

@alexrp thanks for letting me know, I have already done so.
joshua-holmes force-pushed master from acc55ae3b6
Some checks are pending
ci / aarch64-linux-debug (pull_request) Blocked by required conditions
ci / aarch64-linux-release (pull_request) Blocked by required conditions
ci / aarch64-macos-debug (pull_request) Blocked by required conditions
ci / aarch64-macos-release (pull_request) Blocked by required conditions
ci / loongarch64-linux-debug (pull_request) Blocked by required conditions
ci / loongarch64-linux-release (pull_request) Blocked by required conditions
ci / riscv64-linux-debug (pull_request) Blocked by required conditions
ci / riscv64-linux-release (pull_request) Blocked by required conditions
ci / s390x-linux-debug (pull_request) Blocked by required conditions
ci / s390x-linux-release (pull_request) Blocked by required conditions
ci / x86_64-freebsd-debug (pull_request) Blocked by required conditions
ci / x86_64-freebsd-release (pull_request) Blocked by required conditions
ci / x86_64-linux-debug (pull_request) Blocked by required conditions
ci / x86_64-linux-debug-llvm (pull_request) Blocked by required conditions
ci / x86_64-linux-release (pull_request) Blocked by required conditions
ci / x86_64-windows-debug (pull_request) Blocked by required conditions
ci / x86_64-windows-release (pull_request) Blocked by required conditions
to 07eb2a2f16
Some checks are pending
ci / aarch64-linux-debug (pull_request) Blocked by required conditions
ci / aarch64-linux-release (pull_request) Blocked by required conditions
ci / aarch64-macos-debug (pull_request) Blocked by required conditions
ci / aarch64-macos-release (pull_request) Blocked by required conditions
ci / loongarch64-linux-debug (pull_request) Blocked by required conditions
ci / loongarch64-linux-release (pull_request) Blocked by required conditions
ci / riscv64-linux-debug (pull_request) Blocked by required conditions
ci / riscv64-linux-release (pull_request) Blocked by required conditions
ci / s390x-linux-debug (pull_request) Blocked by required conditions
ci / s390x-linux-release (pull_request) Blocked by required conditions
ci / x86_64-freebsd-debug (pull_request) Blocked by required conditions
ci / x86_64-freebsd-release (pull_request) Blocked by required conditions
ci / x86_64-linux-debug (pull_request) Blocked by required conditions
ci / x86_64-linux-debug-llvm (pull_request) Blocked by required conditions
ci / x86_64-linux-release (pull_request) Blocked by required conditions
ci / x86_64-windows-debug (pull_request) Blocked by required conditions
ci / x86_64-windows-release (pull_request) Blocked by required conditions
2025-12-12 01:12:21 +01:00
Compare
joshua-holmes force-pushed master from 07eb2a2f16
Some checks are pending
ci / aarch64-linux-debug (pull_request) Blocked by required conditions
ci / aarch64-linux-release (pull_request) Blocked by required conditions
ci / aarch64-macos-debug (pull_request) Blocked by required conditions
ci / aarch64-macos-release (pull_request) Blocked by required conditions
ci / loongarch64-linux-debug (pull_request) Blocked by required conditions
ci / loongarch64-linux-release (pull_request) Blocked by required conditions
ci / riscv64-linux-debug (pull_request) Blocked by required conditions
ci / riscv64-linux-release (pull_request) Blocked by required conditions
ci / s390x-linux-debug (pull_request) Blocked by required conditions
ci / s390x-linux-release (pull_request) Blocked by required conditions
ci / x86_64-freebsd-debug (pull_request) Blocked by required conditions
ci / x86_64-freebsd-release (pull_request) Blocked by required conditions
ci / x86_64-linux-debug (pull_request) Blocked by required conditions
ci / x86_64-linux-debug-llvm (pull_request) Blocked by required conditions
ci / x86_64-linux-release (pull_request) Blocked by required conditions
ci / x86_64-windows-debug (pull_request) Blocked by required conditions
ci / x86_64-windows-release (pull_request) Blocked by required conditions
to 021910f65d
Some checks are pending
ci / aarch64-linux-debug (pull_request) Blocked by required conditions
ci / aarch64-linux-release (pull_request) Blocked by required conditions
ci / aarch64-macos-debug (pull_request) Blocked by required conditions
ci / aarch64-macos-release (pull_request) Blocked by required conditions
ci / loongarch64-linux-debug (pull_request) Blocked by required conditions
ci / loongarch64-linux-release (pull_request) Blocked by required conditions
ci / riscv64-linux-debug (pull_request) Blocked by required conditions
ci / riscv64-linux-release (pull_request) Blocked by required conditions
ci / s390x-linux-debug (pull_request) Blocked by required conditions
ci / s390x-linux-release (pull_request) Blocked by required conditions
ci / x86_64-freebsd-debug (pull_request) Blocked by required conditions
ci / x86_64-freebsd-release (pull_request) Blocked by required conditions
ci / x86_64-linux-debug (pull_request) Blocked by required conditions
ci / x86_64-linux-debug-llvm (pull_request) Blocked by required conditions
ci / x86_64-linux-release (pull_request) Blocked by required conditions
ci / x86_64-windows-debug (pull_request) Blocked by required conditions
ci / x86_64-windows-release (pull_request) Blocked by required conditions
2025-12-12 01:16:22 +01:00
Compare
joshua-holmes force-pushed master from 021910f65d
Some checks are pending
ci / aarch64-linux-debug (pull_request) Blocked by required conditions
ci / aarch64-linux-release (pull_request) Blocked by required conditions
ci / aarch64-macos-debug (pull_request) Blocked by required conditions
ci / aarch64-macos-release (pull_request) Blocked by required conditions
ci / loongarch64-linux-debug (pull_request) Blocked by required conditions
ci / loongarch64-linux-release (pull_request) Blocked by required conditions
ci / riscv64-linux-debug (pull_request) Blocked by required conditions
ci / riscv64-linux-release (pull_request) Blocked by required conditions
ci / s390x-linux-debug (pull_request) Blocked by required conditions
ci / s390x-linux-release (pull_request) Blocked by required conditions
ci / x86_64-freebsd-debug (pull_request) Blocked by required conditions
ci / x86_64-freebsd-release (pull_request) Blocked by required conditions
ci / x86_64-linux-debug (pull_request) Blocked by required conditions
ci / x86_64-linux-debug-llvm (pull_request) Blocked by required conditions
ci / x86_64-linux-release (pull_request) Blocked by required conditions
ci / x86_64-windows-debug (pull_request) Blocked by required conditions
ci / x86_64-windows-release (pull_request) Blocked by required conditions
to 8ad6fbdb01
Some checks failed
ci / x86_64-windows-release (pull_request) Failing after 35m10s
ci / x86_64-freebsd-release (pull_request) Successful in 44m42s
ci / x86_64-linux-debug (pull_request) Successful in 48m10s
ci / x86_64-windows-debug (pull_request) Failing after 49m33s
ci / x86_64-freebsd-debug (pull_request) Successful in 55m24s
ci / aarch64-macos-release (pull_request) Successful in 1h8m27s
ci / aarch64-linux-release (pull_request) Successful in 1h24m16s
ci / aarch64-linux-debug (pull_request) Successful in 1h51m58s
ci / aarch64-macos-debug (pull_request) Successful in 2h4m48s
ci / x86_64-linux-release (pull_request) Successful in 2h6m18s
ci / s390x-linux-release (pull_request) Successful in 1h22m23s
ci / x86_64-linux-debug-llvm (pull_request) Successful in 2h56m45s
ci / s390x-linux-debug (pull_request) Successful in 2h30m30s
ci / loongarch64-linux-debug (pull_request) Successful in 2h40m35s
ci / loongarch64-linux-release (pull_request) Successful in 2h5m59s
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
2025-12-12 01:17:33 +01:00
Compare
joshua-holmes changed title from Implement package fetch retries to WIP: Implement package fetch retries 2025-12-14 21:33:26 +01:00
joshua-holmes force-pushed master from 8ad6fbdb01
Some checks failed
ci / x86_64-windows-release (pull_request) Failing after 35m10s
ci / x86_64-freebsd-release (pull_request) Successful in 44m42s
ci / x86_64-linux-debug (pull_request) Successful in 48m10s
ci / x86_64-windows-debug (pull_request) Failing after 49m33s
ci / x86_64-freebsd-debug (pull_request) Successful in 55m24s
ci / aarch64-macos-release (pull_request) Successful in 1h8m27s
ci / aarch64-linux-release (pull_request) Successful in 1h24m16s
ci / aarch64-linux-debug (pull_request) Successful in 1h51m58s
ci / aarch64-macos-debug (pull_request) Successful in 2h4m48s
ci / x86_64-linux-release (pull_request) Successful in 2h6m18s
ci / s390x-linux-release (pull_request) Successful in 1h22m23s
ci / x86_64-linux-debug-llvm (pull_request) Successful in 2h56m45s
ci / s390x-linux-debug (pull_request) Successful in 2h30m30s
ci / loongarch64-linux-debug (pull_request) Successful in 2h40m35s
ci / loongarch64-linux-release (pull_request) Successful in 2h5m59s
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
to 3384e8c22f
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 33m12s
ci / x86_64-windows-release (pull_request) Failing after 34m2s
ci / x86_64-windows-debug (pull_request) Failing after 42m45s
ci / x86_64-freebsd-debug (pull_request) Successful in 44m4s
ci / aarch64-macos-release (pull_request) Successful in 47m44s
ci / x86_64-linux-debug (pull_request) Successful in 59m28s
ci / x86_64-linux-debug-llvm (pull_request) Successful in 1h15m49s
ci / aarch64-linux-release (pull_request) Successful in 1h21m22s
ci / s390x-linux-release (pull_request) Successful in 1h27m6s
ci / aarch64-macos-debug (pull_request) Successful in 1h29m40s
ci / aarch64-linux-debug (pull_request) Successful in 1h48m15s
ci / loongarch64-linux-release (pull_request) Successful in 1h55m36s
ci / x86_64-linux-release (pull_request) Successful in 2h9m36s
ci / s390x-linux-debug (pull_request) Successful in 2h28m24s
ci / loongarch64-linux-debug (pull_request) Successful in 2h55m34s
2025-12-14 23:30:00 +01:00
Compare
joshua-holmes force-pushed master from 3384e8c22f
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 33m12s
ci / x86_64-windows-release (pull_request) Failing after 34m2s
ci / x86_64-windows-debug (pull_request) Failing after 42m45s
ci / x86_64-freebsd-debug (pull_request) Successful in 44m4s
ci / aarch64-macos-release (pull_request) Successful in 47m44s
ci / x86_64-linux-debug (pull_request) Successful in 59m28s
ci / x86_64-linux-debug-llvm (pull_request) Successful in 1h15m49s
ci / aarch64-linux-release (pull_request) Successful in 1h21m22s
ci / s390x-linux-release (pull_request) Successful in 1h27m6s
ci / aarch64-macos-debug (pull_request) Successful in 1h29m40s
ci / aarch64-linux-debug (pull_request) Successful in 1h48m15s
ci / loongarch64-linux-release (pull_request) Successful in 1h55m36s
ci / x86_64-linux-release (pull_request) Successful in 2h9m36s
ci / s390x-linux-debug (pull_request) Successful in 2h28m24s
ci / loongarch64-linux-debug (pull_request) Successful in 2h55m34s
to d137fd040b
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) Has been cancelled
ci / aarch64-macos-debug (pull_request) Has been cancelled
ci / x86_64-linux-debug (pull_request) Has been cancelled
ci / aarch64-linux-release (pull_request) Has been cancelled
ci / x86_64-freebsd-debug (pull_request) Has been cancelled
ci / x86_64-linux-release (pull_request) Has been cancelled
ci / aarch64-linux-debug (pull_request) Has been cancelled
ci / x86_64-linux-debug-llvm (pull_request) Has been cancelled
ci / aarch64-macos-release (pull_request) Has been cancelled
ci / loongarch64-linux-debug (pull_request) Has been cancelled
ci / loongarch64-linux-release (pull_request) Has been cancelled
ci / s390x-linux-debug (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 / x86_64-windows-release (pull_request) Has been cancelled
2025-12-15 01:02:21 +01:00
Compare
joshua-holmes force-pushed master from d137fd040b
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) Has been cancelled
ci / aarch64-macos-debug (pull_request) Has been cancelled
ci / x86_64-linux-debug (pull_request) Has been cancelled
ci / aarch64-linux-release (pull_request) Has been cancelled
ci / x86_64-freebsd-debug (pull_request) Has been cancelled
ci / x86_64-linux-release (pull_request) Has been cancelled
ci / aarch64-linux-debug (pull_request) Has been cancelled
ci / x86_64-linux-debug-llvm (pull_request) Has been cancelled
ci / aarch64-macos-release (pull_request) Has been cancelled
ci / loongarch64-linux-debug (pull_request) Has been cancelled
ci / loongarch64-linux-release (pull_request) Has been cancelled
ci / s390x-linux-debug (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 / x86_64-windows-release (pull_request) Has been cancelled
to ee2fa2b971
Some checks failed
ci / aarch64-linux-debug (pull_request) Has been cancelled
ci / aarch64-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 / loongarch64-linux-debug (pull_request) Has been cancelled
ci / loongarch64-linux-release (pull_request) Has been cancelled
ci / riscv64-linux-debug (pull_request) Has been cancelled
ci / riscv64-linux-release (pull_request) Has been cancelled
ci / s390x-linux-debug (pull_request) Has been cancelled
ci / s390x-linux-release (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 / x86_64-linux-debug-llvm (pull_request) Has been cancelled
ci / x86_64-linux-release (pull_request) Has been cancelled
ci / x86_64-windows-debug (pull_request) Has been cancelled
ci / x86_64-windows-release (pull_request) Has been cancelled
2025-12-15 01:08:07 +01:00
Compare
joshua-holmes force-pushed master from ee2fa2b971
Some checks failed
ci / aarch64-linux-debug (pull_request) Has been cancelled
ci / aarch64-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 / loongarch64-linux-debug (pull_request) Has been cancelled
ci / loongarch64-linux-release (pull_request) Has been cancelled
ci / riscv64-linux-debug (pull_request) Has been cancelled
ci / riscv64-linux-release (pull_request) Has been cancelled
ci / s390x-linux-debug (pull_request) Has been cancelled
ci / s390x-linux-release (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 / x86_64-linux-debug-llvm (pull_request) Has been cancelled
ci / x86_64-linux-release (pull_request) Has been cancelled
ci / x86_64-windows-debug (pull_request) Has been cancelled
ci / x86_64-windows-release (pull_request) Has been cancelled
to 0b6222945f
Some checks failed
ci / aarch64-linux-debug (pull_request) Has been cancelled
ci / aarch64-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 / riscv64-linux-debug (pull_request) Has been cancelled
ci / riscv64-linux-release (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-llvm (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 / loongarch64-linux-debug (pull_request) Has been cancelled
ci / x86_64-linux-debug (pull_request) Has been cancelled
ci / s390x-linux-release (pull_request) Has been cancelled
ci / loongarch64-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
2025-12-15 01:09:44 +01:00
Compare
joshua-holmes force-pushed master from 0b6222945f
Some checks failed
ci / aarch64-linux-debug (pull_request) Has been cancelled
ci / aarch64-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 / riscv64-linux-debug (pull_request) Has been cancelled
ci / riscv64-linux-release (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-llvm (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 / loongarch64-linux-debug (pull_request) Has been cancelled
ci / x86_64-linux-debug (pull_request) Has been cancelled
ci / s390x-linux-release (pull_request) Has been cancelled
ci / loongarch64-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
to 1abdae7541
Some checks failed
ci / x86_64-freebsd-release (pull_request) Successful in 32m14s
ci / x86_64-windows-release (pull_request) Failing after 35m15s
ci / x86_64-windows-debug (pull_request) Failing after 40m28s
ci / x86_64-freebsd-debug (pull_request) Successful in 45m9s
ci / aarch64-macos-release (pull_request) Successful in 45m6s
ci / x86_64-linux-debug (pull_request) Successful in 53m31s
ci / x86_64-linux-debug-llvm (pull_request) Successful in 1h14m11s
ci / aarch64-linux-release (pull_request) Successful in 1h19m14s
ci / aarch64-macos-debug (pull_request) Successful in 1h21m32s
ci / aarch64-linux-debug (pull_request) Successful in 1h54m29s
ci / s390x-linux-release (pull_request) Successful in 1h20m10s
ci / x86_64-linux-release (pull_request) Successful in 2h33m57s
ci / s390x-linux-debug (pull_request) Successful in 2h29m33s
ci / loongarch64-linux-release (pull_request) Successful in 2h10m2s
ci / loongarch64-linux-debug (pull_request) Successful in 3h4m51s
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
2025-12-15 04:05:40 +01:00
Compare
joshua-holmes force-pushed master from 1abdae7541
Some checks failed
ci / x86_64-freebsd-release (pull_request) Successful in 32m14s
ci / x86_64-windows-release (pull_request) Failing after 35m15s
ci / x86_64-windows-debug (pull_request) Failing after 40m28s
ci / x86_64-freebsd-debug (pull_request) Successful in 45m9s
ci / aarch64-macos-release (pull_request) Successful in 45m6s
ci / x86_64-linux-debug (pull_request) Successful in 53m31s
ci / x86_64-linux-debug-llvm (pull_request) Successful in 1h14m11s
ci / aarch64-linux-release (pull_request) Successful in 1h19m14s
ci / aarch64-macos-debug (pull_request) Successful in 1h21m32s
ci / aarch64-linux-debug (pull_request) Successful in 1h54m29s
ci / s390x-linux-release (pull_request) Successful in 1h20m10s
ci / x86_64-linux-release (pull_request) Successful in 2h33m57s
ci / s390x-linux-debug (pull_request) Successful in 2h29m33s
ci / loongarch64-linux-release (pull_request) Successful in 2h10m2s
ci / loongarch64-linux-debug (pull_request) Successful in 3h4m51s
ci / riscv64-linux-debug (pull_request) Has been skipped
ci / riscv64-linux-release (pull_request) Has been skipped
to 4cacf87dcf
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 29m34s
ci / x86_64-freebsd-release (pull_request) Successful in 33m33s
ci / x86_64-freebsd-debug (pull_request) Successful in 42m47s
ci / aarch64-macos-release (pull_request) Successful in 43m27s
ci / x86_64-windows-debug (pull_request) Failing after 45m2s
ci / x86_64-linux-debug (pull_request) Successful in 54m20s
ci / x86_64-linux-debug-llvm (pull_request) Successful in 1h15m27s
ci / aarch64-macos-debug (pull_request) Successful in 1h25m35s
ci / aarch64-linux-release (pull_request) Successful in 1h25m30s
ci / s390x-linux-release (pull_request) Successful in 1h27m49s
ci / x86_64-linux-release (pull_request) Failing after 1h48m57s
ci / loongarch64-linux-release (pull_request) Successful in 1h49m16s
ci / s390x-linux-debug (pull_request) Successful in 2h20m37s
ci / aarch64-linux-debug (pull_request) Successful in 2h27m50s
ci / loongarch64-linux-debug (pull_request) Successful in 2h35m58s
2025-12-24 16:05:33 +01:00
Compare
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 29m34s
Required
Details
ci / x86_64-freebsd-release (pull_request) Successful in 33m33s
Required
Details
ci / x86_64-freebsd-debug (pull_request) Successful in 42m47s
Required
Details
ci / aarch64-macos-release (pull_request) Successful in 43m27s
Required
Details
ci / x86_64-windows-debug (pull_request) Failing after 45m2s
Required
Details
ci / x86_64-linux-debug (pull_request) Successful in 54m20s
Required
Details
ci / x86_64-linux-debug-llvm (pull_request) Successful in 1h15m27s
Required
Details
ci / aarch64-macos-debug (pull_request) Successful in 1h25m35s
Required
Details
ci / aarch64-linux-release (pull_request) Successful in 1h25m30s
Required
Details
ci / s390x-linux-release (pull_request) Successful in 1h27m49s
Required
Details
ci / x86_64-linux-release (pull_request) Failing after 1h48m57s
Required
Details
ci / loongarch64-linux-release (pull_request) Successful in 1h49m16s
Required
Details
ci / s390x-linux-debug (pull_request) Successful in 2h20m37s
Required
Details
ci / aarch64-linux-debug (pull_request) Successful in 2h27m50s
Required
Details
ci / loongarch64-linux-debug (pull_request) Successful in 2h35m58s
Required
Details
This pull request has changes conflicting with the target branch.
  • src/Package/Fetch.zig
View command line instructions

Checkout

From your project repository, check out a new branch and test the changes.
git fetch -u master:joshua-holmes-master
git switch joshua-holmes-master
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/v850
arch/vax
arch/vc4
arch/ve
arch/wasm
arch/we32k
arch/x86
arch/x86_16
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
2 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!30171
No description provided.