Compare commits

...

34 Commits

Author SHA1 Message Date
Taiki Endo
d053c7f943 Release 2.75.6 2026-04-11 17:05:39 +00:00
Taiki Endo
9019f2ebb5 Update mise@latest to 2026.4.8 2026-04-11 12:30:04 +00:00
Taiki Endo
1b07fb7459 Update cargo-deny@latest to 0.19.1 2026-04-11 12:30:04 +00:00
Taiki Endo
be1e8a8637 Update vacuum manifest 2026-04-11 00:52:14 +00:00
Taiki Endo
1cc7501bf8 Update gungraun-runner manifest 2026-04-11 00:52:14 +00:00
Taiki Endo
44afe623be Update covgate manifest 2026-04-10 18:37:40 +00:00
Taiki Endo
7a4939c096 Release 2.75.5 2026-04-10 17:38:05 +00:00
Taiki Endo
7e0318acc6 Update wasm-bindgen manifest 2026-04-10 17:27:32 +00:00
Taiki Endo
2cc23c5dad Update biome@latest to 2.4.11 2026-04-10 17:27:32 +00:00
Taiki Endo
398d535c7e Update wasmtime manifest 2026-04-11 02:14:03 +09:00
Taiki Endo
f5624998da Update uv@latest to 0.11.6 2026-04-10 15:34:16 +00:00
Taiki Endo
992d50db8b Update mise@latest to 2026.4.7 2026-04-10 15:34:16 +00:00
Taiki Endo
ea5c6b4f9e Update gungraun-runner@latest to 0.18.0 2026-04-10 15:34:16 +00:00
Taiki Endo
10db9b5ea8 Update cargo-deny manifest 2026-04-10 15:34:16 +00:00
Taiki Endo
02cc5f8ca9 Touch up comment on unset 2026-04-10 16:52:13 +09:00
Taiki Endo
97a5807a60 Release 2.75.4 2026-04-10 07:36:08 +00:00
Taiki Endo
354932869f Update changelog 2026-04-10 16:25:24 +09:00
Taiki Endo
ba626b4d71 Early unset tokens from env 2026-04-10 16:21:15 +09:00
Taiki Endo
befe16e822 Update martin@latest to 1.5.0 2026-04-10 06:58:49 +00:00
Taiki Endo
0620033eb0 Use --arg for jq more 2026-04-10 15:42:08 +09:00
Taiki Endo
08a38582e3 Do not expose GITHUB_TOKEN to cargo-binstall's subprocess 2026-04-10 14:47:32 +09:00
Taiki Endo
3c299a507e ci: Update config 2026-04-10 14:47:26 +09:00
Taiki Endo
3c436a15a3 Use --arg for jq 2026-04-10 13:14:01 +09:00
Taiki Endo
0f9ae157f2 ci: Update release workflow 2026-04-10 13:14:01 +09:00
Taiki Endo
f69e524d67 Update readme 2026-04-10 13:14:01 +09:00
Taiki Endo
9c2513f9f4 Update uv@latest to 0.11.5 2026-04-09 21:32:20 +00:00
Taiki Endo
84505613db Update syft@latest to 1.42.4 2026-04-09 21:32:20 +00:00
Taiki Endo
9cfc7fba65 Update dprint@latest to 0.54.0 2026-04-09 21:32:20 +00:00
Taiki Endo
b8be7f5e14 Release 2.75.3 2026-04-09 18:02:50 +00:00
Taiki Endo
d3bc52a8b2 Update wasmtime manifest 2026-04-09 17:51:32 +00:00
Taiki Endo
08d452d0b7 Update biome manifest 2026-04-09 17:51:32 +00:00
Taiki Endo
77557fa399 Do not set DEFAULT_GITHUB_TOKEN if cargo-binstall fallback is disabled 2026-04-10 02:37:36 +09:00
Taiki Endo
8f20d38f44 Update rclone@latest to 1.73.4 2026-04-09 15:48:55 +00:00
Taiki Endo
ae5d3f20c2 Update gungraun-runner manifest 2026-04-09 15:48:55 +00:00
22 changed files with 492 additions and 97 deletions

View File

@@ -33,20 +33,20 @@ concurrency:
jobs:
miri:
uses: taiki-e/github-actions/.github/workflows/miri.yml@606d6c78d69927c489d319133073a03157928a7a # main
uses: taiki-e/github-actions/.github/workflows/miri.yml@dec917193d835117a7238865adf83273d9fcd27a # main
with:
# NB: sync with test job's --exclude option
args: --exclude install-action-internal-codegen
msrv:
uses: taiki-e/github-actions/.github/workflows/msrv.yml@606d6c78d69927c489d319133073a03157928a7a # main
uses: taiki-e/github-actions/.github/workflows/msrv.yml@dec917193d835117a7238865adf83273d9fcd27a # main
test-manifest-schema:
uses: taiki-e/github-actions/.github/workflows/test.yml@606d6c78d69927c489d319133073a03157928a7a # main
uses: taiki-e/github-actions/.github/workflows/test.yml@dec917193d835117a7238865adf83273d9fcd27a # main
with:
# NB: sync with miri job's --exclude option
test-args: --exclude install-action-internal-codegen
no-std: false
tidy:
uses: taiki-e/github-actions/.github/workflows/tidy.yml@606d6c78d69927c489d319133073a03157928a7a # main
uses: taiki-e/github-actions/.github/workflows/tidy.yml@dec917193d835117a7238865adf83273d9fcd27a # main
permissions:
contents: write # for creating branch for pr
pull-requests: write # unused (used in `codegen-automerge: true` case)

View File

@@ -33,7 +33,7 @@ concurrency:
jobs:
manifest:
uses: taiki-e/github-actions/.github/workflows/gen.yml@7e4093bf4e87dd120ac0c3be2e47ebe7f737a47d # main
uses: taiki-e/github-actions/.github/workflows/gen.yml@dec917193d835117a7238865adf83273d9fcd27a # main
permissions:
contents: write # for creating branch for pr
pull-requests: write # for gh pr review --approve

View File

@@ -39,7 +39,7 @@ jobs:
timeout-minutes: 60
steps:
- uses: taiki-e/checkout-action@7d1e50e93dc4fb3bba58f85018fadf77898aee8b # v1.4.2
- uses: taiki-e/install-action@7a562dfa955aa2e4d5b0fd6ebd57ff9715c07b0b # v2.73.0
- uses: taiki-e/install-action@b8be7f5e140177087325943c4a8e169d01c59b3d # v2.75.3
with:
tool: parse-changelog
fallback: none
@@ -208,7 +208,7 @@ jobs:
contents: write # for taiki-e/create-gh-release-action
steps:
- uses: taiki-e/checkout-action@7d1e50e93dc4fb3bba58f85018fadf77898aee8b # v1.4.2
- uses: taiki-e/install-action@7a562dfa955aa2e4d5b0fd6ebd57ff9715c07b0b # v2.73.0
- uses: taiki-e/install-action@b8be7f5e140177087325943c4a8e169d01c59b3d # v2.75.3
with:
tool: parse-changelog
fallback: none
@@ -304,6 +304,50 @@ jobs:
)
fi
major_version_tag="v${version%%.*}"
(
set -x
git tag "${tag}"
git branch "releases/${major_version_tag}"
git tag -f "${major_version_tag}"
)
refs=("refs/heads/${BRANCH}" "refs/tags/${tag}" "refs/heads/releases/${major_version_tag}" "+refs/tags/${major_version_tag}")
tools=()
for tool in tools/codegen/base/*.json; do
tool="${tool##*/}"
tools+=("${tool%.*}")
done
# Aliases.
# NB: Update case for aliases in main.sh, tool input option in test-alias job
# in .github/workflows/ci.yml, and match for alias for tools/codegen/src/tools-markdown.rs.
tools+=(
nextest
taplo-cli
typos-cli
wasm-bindgen-cli
wasmtime-cli
)
# Non-manifest-based tools.
tools+=(valgrind)
branches=()
for tool in "${tools[@]}"; do
(
set -x
git checkout -b "releases/${tool}"
sed -E "${in_place[@]}" action.yml \
-e "s/required: true/required: false/g" \
-e "s/# default: #publish:tool/default: ${tool}/g"
git add action.yml
git commit -m "${tool}"
git tag -f "${tool}"
git checkout refs/tags/"${tag}"
)
refs+=("+refs/heads/releases/${tool}" "+refs/tags/${tool}")
branches+=("releases/${tool}")
done
prev_credential_helper=$(git config get --local credential.helper || true)
if [[ -n "${prev_credential_helper}" ]]; then
printf 'credential helper is already set (%s)\n' "${prev_credential_helper}"
@@ -326,46 +370,6 @@ jobs:
(
set -x
git tag "${tag}"
retry git push origin HEAD
major_version_tag="v${version%%.*}"
git branch "releases/${major_version_tag}"
git tag -f "${major_version_tag}"
refs=("refs/tags/${tag}" "refs/heads/releases/${major_version_tag}" "+refs/tags/${major_version_tag}")
tools=()
for tool in tools/codegen/base/*.json; do
tool="${tool##*/}"
tools+=("${tool%.*}")
done
# Aliases.
# NB: Update case for aliases in main.sh, tool input option in test-alias job
# in .github/workflows/ci.yml, and match for alias for tools/codegen/src/tools-markdown.rs.
tools+=(
nextest
taplo-cli
typos-cli
wasm-bindgen-cli
wasmtime-cli
)
# Non-manifest-based tools.
tools+=(valgrind)
branches=()
for tool in "${tools[@]}"; do
git checkout -b "releases/${tool}"
sed -E "${in_place[@]}" action.yml \
-e "s/required: true/required: false/g" \
-e "s/# default: #publish:tool/default: ${tool}/g"
git add action.yml
git commit -m "${tool}"
git tag -f "${tool}"
git checkout refs/tags/"${tag}"
refs+=("+refs/heads/releases/${tool}" "+refs/tags/${tool}")
branches+=("releases/${tool}")
done
retry git push origin --atomic "${refs[@]}"
git branch -d "releases/${major_version_tag}"
git branch -D "${branches[@]}"
@@ -432,7 +436,7 @@ jobs:
release-manifest-schema:
if: github.repository_owner == 'taiki-e' && inputs.target == 'install-action-manifest-schema'
uses: taiki-e/github-actions/.github/workflows/rust-release.yml@606d6c78d69927c489d319133073a03157928a7a # main
uses: taiki-e/github-actions/.github/workflows/rust-release.yml@dec917193d835117a7238865adf83273d9fcd27a # main
permissions:
contents: write # for taiki-e/create-gh-release-action
id-token: write # for rust-lang/crates-io-auth-action

2
.github/zizmor.yml vendored
View File

@@ -2,5 +2,5 @@
# https://docs.zizmor.sh/configuration/
rules:
anonymous-definition: { disable: true }
anonymous-definition: { disable: true } # This is pedantic/auditor only audit and requires explicitly naming each job, but is usually redundant.
dependabot-cooldown: { config: { days: 14 } }

View File

@@ -10,6 +10,42 @@ Note: In this file, do not use the hard wrap in the middle of a sentence for com
## [Unreleased]
## [2.75.6] - 2026-04-11
- Update `mise@latest` to 2026.4.8.
- Update `cargo-deny@latest` to 0.19.1.
## [2.75.5] - 2026-04-10
- Update `biome@latest` to 2.4.11.
- Update `wasmtime@latest` to 43.0.1.
- Update `uv@latest` to 0.11.6.
- Update `mise@latest` to 2026.4.7.
- Update `gungraun-runner@latest` to 0.18.0.
## [2.75.4] - 2026-04-10
- Enhance security when cargo-binstall fallback is enabled. ([08a38582](https://github.com/taiki-e/install-action/commit/08a38582e35739e1fda5e4cd298e348536a1ddaa), [ba626b4d](https://github.com/taiki-e/install-action/commit/ba626b4d71edcae17f6ca956b7b81e925b2d24ef))
- Update `martin@latest` to 1.5.0.
- Update `uv@latest` to 0.11.5.
- Update `syft@latest` to 1.42.4.
- Update `dprint@latest` to 0.54.0.
## [2.75.3] - 2026-04-09
- Enhance security when cargo-binstall fallback is disabled. ([77557fa3](https://github.com/taiki-e/install-action/commit/77557fa3993e075c27572045b0d159865c23016b))
- Update `rclone@latest` to 1.73.4.
## [2.75.2] - 2026-04-09
- Update `uv@latest` to 0.11.4.
@@ -6179,7 +6215,11 @@ Note: This release is considered a breaking change because installing on version
Initial release
[Unreleased]: https://github.com/taiki-e/install-action/compare/v2.75.2...HEAD
[Unreleased]: https://github.com/taiki-e/install-action/compare/v2.75.6...HEAD
[2.75.6]: https://github.com/taiki-e/install-action/compare/v2.75.5...v2.75.6
[2.75.5]: https://github.com/taiki-e/install-action/compare/v2.75.4...v2.75.5
[2.75.4]: https://github.com/taiki-e/install-action/compare/v2.75.3...v2.75.4
[2.75.3]: https://github.com/taiki-e/install-action/compare/v2.75.2...v2.75.3
[2.75.2]: https://github.com/taiki-e/install-action/compare/v2.75.1...v2.75.2
[2.75.1]: https://github.com/taiki-e/install-action/compare/v2.75.0...v2.75.1
[2.75.0]: https://github.com/taiki-e/install-action/compare/v2.74.1...v2.75.0

View File

@@ -102,6 +102,10 @@ See the [development guide](DEVELOPMENT.md) for how to add support for new tool.
The `@v<major>` and `@<tool_name>` tags are updated with each release. If you want to enhance workflow stability and security against supply chain attacks, consider using the `@v<major>.<minor>.<patch>` tag or their hash to pin the version and regularly updating with [dependency cooldown]. Since all releases are immutable, pinning the version in either way should have the same effect. Pinning `@<tool_name>` tags by hash is strongly discouraged, as it causes the workflow to reference a [commit that is not present on the repository](https://docs.zizmor.sh/audits/#impostor-commit) when a new version is released.
The default fallback (cargo-binstall) is often affected by GitHub's API rate limits, so we [pass the `${{ github.token }}` to cargo-binstall](https://github.com/taiki-e/install-action/issues/561). Disabling the cargo-binstall fallback prevent passing token so helps enhance security.
See the [Supported tools section](#supported-tools) for how to ensure that fallback is not used.
<!-- omit in toc -->
### Security on installation from GitHub Releases

View File

@@ -47,7 +47,7 @@ runs:
INPUT_TOOL: ${{ inputs.tool }}
INPUT_CHECKSUM: ${{ inputs.checksum }}
INPUT_FALLBACK: ${{ inputs.fallback }}
DEFAULT_GITHUB_TOKEN: ${{ github.token }}
DEFAULT_GITHUB_TOKEN: ${{ inputs.fallback == 'cargo-binstall' && github.token || '' }}
ACTION_USER_AGENT: ${{ github.action_repository }} (${{ github.action_ref }})
if: runner.os != 'Windows'
# Use pwsh and retry on bash startup failure to work around windows-11-arm runner bug:
@@ -77,6 +77,6 @@ runs:
INPUT_TOOL: ${{ inputs.tool }}
INPUT_CHECKSUM: ${{ inputs.checksum }}
INPUT_FALLBACK: ${{ inputs.fallback }}
DEFAULT_GITHUB_TOKEN: ${{ github.token }}
DEFAULT_GITHUB_TOKEN: ${{ inputs.fallback == 'cargo-binstall' && github.token || '' }}
ACTION_USER_AGENT: ${{ github.action_repository }} (${{ github.action_ref }})
if: runner.os == 'Windows'

38
main.sh
View File

@@ -236,7 +236,7 @@ read_manifest() {
local version="$2"
local manifest
rust_crate=$(jq -r '.rust_crate' "${manifest_dir}/${tool}.json")
manifest=$(jq -r ".[\"${version}\"]" "${manifest_dir}/${tool}.json")
manifest=$(jq -r --arg version "${version}" '.[$version]' "${manifest_dir}/${tool}.json")
if [[ "${manifest}" == "null" ]]; then
download_info="null"
return 0
@@ -245,7 +245,7 @@ read_manifest() {
if [[ "${exact_version}" == "null" ]]; then
exact_version="${version}"
else
manifest=$(jq -r ".[\"${exact_version}\"]" "${manifest_dir}/${tool}.json")
manifest=$(jq -r --arg version "${exact_version}" '.[$version]' "${manifest_dir}/${tool}.json")
if [[ "${rust_crate}" != "null" ]]; then
# TODO: don't hardcode tool name and use 'immediate_yank_reflection' field in base manifest.
case "${tool}" in
@@ -253,7 +253,7 @@ read_manifest() {
crate_info=$(retry curl --user-agent "${ACTION_USER_AGENT}" --proto '=https' --tlsv1.2 -fsSL --retry 10 "https://crates.io/api/v1/crates/${rust_crate}" || true)
if [[ -n "${crate_info}" ]]; then
while true; do
yanked=$(jq -r ".versions[] | select(.num == \"${exact_version}\") | .yanked" <<<"${crate_info}")
yanked=$(jq -r --arg version "${exact_version}" '.versions[] | select(.num == $version) | .yanked' <<<"${crate_info}")
if [[ "${yanked}" != "true" ]]; then
break
fi
@@ -263,7 +263,7 @@ read_manifest() {
fi
info "${tool}@${exact_version} is yanked; downgrade to ${previous_stable_version}"
exact_version="${previous_stable_version}"
manifest=$(jq -r ".[\"${exact_version}\"]" "${manifest_dir}/${tool}.json")
manifest=$(jq -r --arg version "${exact_version}" '.[$version]' "${manifest_dir}/${tool}.json")
done
fi
;;
@@ -277,14 +277,14 @@ read_manifest() {
# usually preferred over linux-gnu binaries because they can avoid glibc version issues.
# (rustc enables statically linking for linux-musl by default, except for mips.)
host_platform="${host_arch}_linux_musl"
download_info=$(jq -r ".${host_platform}" <<<"${manifest}")
download_info=$(jq -r --arg p "${host_platform}" '.[$p]' <<<"${manifest}")
if [[ "${download_info}" == "null" ]]; then
# Even if host_env is musl, we won't issue an error here because it seems that in
# some cases linux-gnu binaries will work on linux-musl hosts.
# https://wiki.alpinelinux.org/wiki/Running_glibc_programs
# TODO: However, a warning may make sense.
host_platform="${host_arch}_linux_gnu"
download_info=$(jq -r ".${host_platform}" <<<"${manifest}")
download_info=$(jq -r --arg p "${host_platform}" '.[$p]' <<<"${manifest}")
elif [[ "${host_env}" == "gnu" ]]; then
# TODO: don't hardcode tool name and use 'prefer_linux_gnu' field in base manifest.
case "${tool}" in
@@ -296,7 +296,7 @@ read_manifest() {
# musl build of nextest is slow, so use glibc build if host_env is gnu.
# https://github.com/taiki-e/install-action/issues/13
host_platform="${host_arch}_linux_gnu"
download_info=$(jq -r ".${host_platform}" <<<"${manifest}")
download_info=$(jq -r --arg p "${host_platform}" '.[$p]' <<<"${manifest}")
fi
;;
esac
@@ -306,10 +306,10 @@ read_manifest() {
# Binaries compiled for x86_64 macOS will usually also work on AArch64 macOS.
# Binaries compiled for x86_64 Windows will usually also work on AArch64 Windows 11+.
host_platform="${host_arch}_${host_os}"
download_info=$(jq -r ".${host_platform}" <<<"${manifest}")
download_info=$(jq -r --arg p "${host_platform}" '.[$p]' <<<"${manifest}")
if [[ "${download_info}" == "null" ]] && [[ "${host_arch}" != "x86_64" ]]; then
host_platform="x86_64_${host_os}"
download_info=$(jq -r ".${host_platform}" <<<"${manifest}")
download_info=$(jq -r --arg p "${host_platform}" '.[$p]' <<<"${manifest}")
fi
;;
*) bail "unsupported OS type '${host_os}' for ${tool}" ;;
@@ -327,7 +327,7 @@ read_download_info() {
bin_in_archive=()
if [[ "${url}" == "null" ]]; then
local template
template=$(jq -c ".template.${host_platform}" "${manifest_dir}/${tool}.json")
template=$(jq -c --arg p "${host_platform}" '.template[$p]' "${manifest_dir}/${tool}.json")
template="${template//\$\{version\}/${exact_version}}"
url=$(jq -r '.url' <<<"${template}")
tmp=$(jq -r '.bin' <<<"${template}")
@@ -627,6 +627,14 @@ case "${fallback}" in
*) bail "'fallback' input option must be 'none', 'cargo-binstall', or 'cargo-install': '${fallback}'" ;;
esac
# Unlike gh command, cargo-binstall reads GITHUB_TOKEN first via cli parser, and then reads GH_TOKEN.
# https://github.com/cargo-bins/cargo-binstall/blob/v1.17.9/crates/bin/src/args.rs#L704
token="${GITHUB_TOKEN:-"${GH_TOKEN:-"${DEFAULT_GITHUB_TOKEN:-}"}"}"
# This prevents tokens from being exposed to subprocesses via environment variables.
# Since the tokens remain in memory, setting `fallback: none` (which prevents the tokens from being
# set in the first place) remains the best practice from a security standpoint, as readme says.
unset GITHUB_TOKEN GH_TOKEN DEFAULT_GITHUB_TOKEN
case "${host_os}" in
linux)
if ! type -P jq >/dev/null || ! type -P curl >/dev/null || ! type -P tar >/dev/null; then
@@ -917,13 +925,15 @@ if [[ ${#unsupported_tools[@]} -gt 0 ]]; then
case "${fallback}" in
cargo-binstall)
install_cargo_binstall
if [[ -z "${GITHUB_TOKEN:-}" ]] && [[ -n "${DEFAULT_GITHUB_TOKEN:-}" ]]; then
export GITHUB_TOKEN="${DEFAULT_GITHUB_TOKEN}"
fi
# By default, cargo-binstall enforce downloads over secure transports only.
# As a result, http will be disabled, and it will also set
# min tls version to be 1.2
cargo-binstall binstall --force --no-confirm --locked "${unsupported_tools[@]}"
binstall_args=(--force --no-confirm --locked "${unsupported_tools[@]}")
if [[ -n "${token}" ]]; then
cargo-binstall binstall --github-token "${token}" "${binstall_args[@]}"
else
cargo-binstall binstall "${binstall_args[@]}"
fi
if ! type -P cargo >/dev/null; then
_bin_dir=$(canonicalize_windows_path "${home}/.cargo/bin")
# TODO: avoid this when already added

44
manifests/biome.json generated
View File

@@ -3,13 +3,51 @@
"template": null,
"license_markdown": "[Apache-2.0](https://github.com/biomejs/biome/blob/main/LICENSE-APACHE) OR [MIT](https://github.com/biomejs/biome/blob/main/LICENSE-MIT)",
"latest": {
"version": "2.4.10"
"version": "2.4.11"
},
"2": {
"version": "2.4.10"
"version": "2.4.11"
},
"2.4": {
"version": "2.4.10"
"version": "2.4.11"
},
"2.4.11": {
"x86_64_linux_musl": {
"url": "https://github.com/biomejs/biome/releases/download/%40biomejs/biome%402.4.11/biome-linux-x64-musl",
"etag": "0x8DE9656A2924E77",
"hash": "f10d041ae17c8d4d659950941fec862dc342945ab3af811e3e90bd93770c08e6",
"bin": "biome"
},
"x86_64_macos": {
"url": "https://github.com/biomejs/biome/releases/download/%40biomejs/biome%402.4.11/biome-darwin-x64",
"etag": "0x8DE9656A24F9CFE",
"hash": "9069156955cfd53efc273cfcd4ece85a7af2ed715d20a8717a63bde3e05b5a40",
"bin": "biome"
},
"x86_64_windows": {
"url": "https://github.com/biomejs/biome/releases/download/%40biomejs/biome%402.4.11/biome-win32-x64.exe",
"etag": "0x8DE9656A2C64373",
"hash": "6c626fdf119215234cbe51455b07995eb67b24ada85819d9273a02b7c6770fbd",
"bin": "biome.exe"
},
"aarch64_linux_musl": {
"url": "https://github.com/biomejs/biome/releases/download/%40biomejs/biome%402.4.11/biome-linux-arm64-musl",
"etag": "0x8DE9656A253B713",
"hash": "f58e2abd4fa737b90d1d9a4f2a3e87af1583df064b9ec14a10b34f4f34f61d88",
"bin": "biome"
},
"aarch64_macos": {
"url": "https://github.com/biomejs/biome/releases/download/%40biomejs/biome%402.4.11/biome-darwin-arm64",
"etag": "0x8DE9656A22891CD",
"hash": "9de8fa513c170b33933f397e4906eb4f8af21890aa5f36a36db22df3d9ed1978",
"bin": "biome"
},
"aarch64_windows": {
"url": "https://github.com/biomejs/biome/releases/download/%40biomejs/biome%402.4.11/biome-win32-arm64.exe",
"etag": "0x8DE9656A280D5F1",
"hash": "a0b928f3894dfaea97906974e30785948e44e9fbab8b3d86897fb7da55ab36a9",
"bin": "biome.exe"
}
},
"2.4.10": {
"x86_64_linux_musl": {

View File

@@ -24,10 +24,32 @@
},
"license_markdown": "[MIT](https://github.com/EmbarkStudios/cargo-deny/blob/main/LICENSE-MIT) OR [Apache-2.0](https://github.com/EmbarkStudios/cargo-deny/blob/main/LICENSE-APACHE)",
"latest": {
"version": "0.19.0"
"version": "0.19.1"
},
"0.19": {
"version": "0.19.0"
"version": "0.19.1"
},
"0.19.1": {
"x86_64_linux_musl": {
"etag": "0x8DE96F183A112FE",
"hash": "baa0d618ce06bd1fb352115de47e31acba439c3e639b990dc43429c948364d70"
},
"x86_64_macos": {
"etag": "0x8DE96F1880BF6C5",
"hash": "aaf5970ea5241cbf552fc14dea1e8cc788b25a6b3d77f2729692964d0f4142c8"
},
"x86_64_windows": {
"etag": "0x8DE96F1B5ECB7E2",
"hash": "0b60886df60629e68511bc2445d249d3646390db47e78f60ea8094606f4b606a"
},
"aarch64_linux_musl": {
"etag": "0x8DE96F18AF78F66",
"hash": "8f09b71258750bc58c828e47bb73d75500a43feea3c07af923002ca4869c2be1"
},
"aarch64_macos": {
"etag": "0x8DE96F1661BFBFD",
"hash": "d8a162b2595117101b6769ba678bd3396e5d3fcb49612f385d7a9f6acf1c30b4"
}
},
"0.19.0": {
"x86_64_linux_musl": {

18
manifests/covgate.json generated
View File

@@ -25,6 +25,24 @@
"0.1": {
"version": "0.1.3"
},
"0.1.4": {
"x86_64_linux_musl": {
"etag": "0x8DE97290157DE06",
"hash": "443bcdb2d5bd550c374f9721a6663a42d0d402955cbd32bb61b3b875a04bc80f"
},
"x86_64_windows": {
"etag": "0x8DE9729014F3532",
"hash": "fcd6971cbcb58181b85042f6f80eb2a4e05bccfa1450aa203083dd6f95a14254"
},
"aarch64_linux_musl": {
"etag": "0x8DE97290159FE80",
"hash": "15477ecb35695955ebaf6677a18a94fe5ac50dadc9985f277651e5c9b0ea4471"
},
"aarch64_macos": {
"etag": "0x8DE9729015A4C45",
"hash": "af6713df579260053b1b5054f0750febc8e456ba54041154900fe19cf51f3160"
}
},
"0.1.3": {
"x86_64_linux_musl": {
"etag": "0x8DE8AA88DFE2E44",

5
manifests/dprint.json generated
View File

@@ -28,7 +28,10 @@
},
"license_markdown": "[MIT](https://github.com/dprint/dprint/blob/main/LICENSE)",
"latest": {
"version": "0.53.2"
"version": "0.54.0"
},
"0.54": {
"version": "0.54.0"
},
"0.54.0": {
"x86_64_linux_musl": {

View File

@@ -24,7 +24,54 @@
},
"license_markdown": "[Apache-2.0](https://github.com/gungraun/gungraun/blob/main/LICENSE-APACHE) OR [MIT](https://github.com/gungraun/gungraun/blob/main/LICENSE-MIT)",
"latest": {
"version": "0.17.2"
"version": "0.18.0"
},
"0.18": {
"version": "0.18.0"
},
"0.18.1": {
"x86_64_linux_musl": {
"etag": "0x8DE9748264D41CC",
"hash": "8e085908f9de28f4e4b599f171aff61e72342481c5af3a8086ed800be8e17a35"
},
"aarch64_linux_gnu": {
"etag": "0x8DE97471C4DE6D4",
"hash": "46b29d7bb529062256b28eca27d26c6f5ca1943a627f9dd024d7641b604ecf11"
},
"powerpc64le_linux_gnu": {
"etag": "0x8DE974857C237F9",
"hash": "c7833abfdd55440b8be85e854e7b673c6cd8933c85517eb6309dfee31079f4a7"
},
"riscv64_linux_gnu": {
"etag": "0x8DE974839AFEA4F",
"hash": "3374713f6e77b0f5329674a9d03bc0ed9ee5e899a9ad0d23382cff247097e8e0"
},
"s390x_linux_gnu": {
"etag": "0x8DE97483DFFED3C",
"hash": "997d992f59088c1d7b77cc4906f5c28fcbc1c59e01ecd5442ebcdeae9e47d87c"
}
},
"0.18.0": {
"x86_64_linux_musl": {
"etag": "0x8DE9642F0CF107C",
"hash": "6bc46e9b0b9df0a13897c277c9c529488e1746b5f6ad6fa33b966f4f395bec28"
},
"aarch64_linux_gnu": {
"etag": "0x8DE9642F5351AC4",
"hash": "9ffe79ab8523c1ada9a52c1352333d6499cd26fabb60d9ba6a8eeb1ab4102dc2"
},
"powerpc64le_linux_gnu": {
"etag": "0x8DE9642F38861F9",
"hash": "6b2ddd799fec1517aee95fd03eb021e125b46690c679d29d54824b87b97c61fe"
},
"riscv64_linux_gnu": {
"etag": "0x8DE9642EC2FBFDC",
"hash": "8bf2263ac4a41cb9132df94d4e570eb3e310e2afc970ff6581ccc6a32fc66c22"
},
"s390x_linux_gnu": {
"etag": "0x8DE9642EE460E79",
"hash": "e540f51a2621fe1a69cf9e7d0acf97d0e1c8b11866ba1ef08564614c496c5259"
}
},
"0.17": {
"version": "0.17.2"

7
manifests/martin.json generated
View File

@@ -32,10 +32,13 @@
},
"license_markdown": "[MIT](https://github.com/maplibre/martin/blob/main/LICENSE-MIT) OR [Apache-2.0](https://github.com/maplibre/martin/blob/main/LICENSE-APACHE)",
"latest": {
"version": "1.4.0"
"version": "1.5.0"
},
"1": {
"version": "1.4.0"
"version": "1.5.0"
},
"1.5": {
"version": "1.5.0"
},
"1.5.0": {
"x86_64_linux_musl": {

32
manifests/mise.json generated
View File

@@ -28,13 +28,39 @@
},
"license_markdown": "[MIT](https://github.com/jdx/mise/blob/main/LICENSE)",
"latest": {
"version": "2026.4.6"
"version": "2026.4.8"
},
"2026": {
"version": "2026.4.6"
"version": "2026.4.8"
},
"2026.4": {
"version": "2026.4.6"
"version": "2026.4.8"
},
"2026.4.8": {
"x86_64_linux_musl": {
"etag": "0x8DE96FA8585A4DB",
"hash": "9d670988a11e6af1a478fc2037b55af90c51e4f3bc538fe684b18b71c5a5fc4e"
},
"x86_64_macos": {
"etag": "0x8DE96FA882F0282",
"hash": "b8dd35a066ed7ccfba1c9217db04cd15f0f3976f06b1c59b99a9f38122a35bd6"
},
"x86_64_windows": {
"etag": "0x8DE96FA88E8CF31",
"hash": "6bc622404bcfda0bca3f87a69dfd3ea83b2da92a0e06596c2fd4953b4ab10c5a"
},
"aarch64_linux_musl": {
"etag": "0x8DE96FA8212FBA0",
"hash": "a5be964c2e29237dc6808c237793c73732db29877aa135b2457345f5d788b436"
},
"aarch64_macos": {
"etag": "0x8DE96FA8721A766",
"hash": "b27b067d5dc5ad208eabffffb001d87d1edee82d2140ebdc35332ec434ea8e98"
},
"aarch64_windows": {
"etag": "0x8DE96FA888159DE",
"hash": "0a13e8ec7dbacd13b4eeb88ffdfd8800c5646be9592a4e2781d3f92b97ab18b1"
}
},
"2026.4.7": {
"x86_64_linux_musl": {

6
manifests/rclone.json generated
View File

@@ -28,13 +28,13 @@
},
"license_markdown": "[MIT](https://github.com/rclone/rclone/blob/master/COPYING)",
"latest": {
"version": "1.73.3"
"version": "1.73.4"
},
"1": {
"version": "1.73.3"
"version": "1.73.4"
},
"1.73": {
"version": "1.73.3"
"version": "1.73.4"
},
"1.73.4": {
"x86_64_linux_musl": {

6
manifests/syft.json generated
View File

@@ -36,13 +36,13 @@
},
"license_markdown": "[Apache-2.0](https://github.com/anchore/syft/blob/main/LICENSE)",
"latest": {
"version": "1.42.3"
"version": "1.42.4"
},
"1": {
"version": "1.42.3"
"version": "1.42.4"
},
"1.42": {
"version": "1.42.3"
"version": "1.42.4"
},
"1.42.4": {
"x86_64_linux_musl": {

4
manifests/uv.json generated
View File

@@ -69,10 +69,10 @@
},
"license_markdown": "[Apache-2.0](https://github.com/astral-sh/uv/blob/main/LICENSE-APACHE) OR [MIT](https://github.com/astral-sh/uv/blob/main/LICENSE-MIT)",
"latest": {
"version": "0.11.4"
"version": "0.11.6"
},
"0.11": {
"version": "0.11.4"
"version": "0.11.6"
},
"0.11.6": {
"x86_64_linux_musl": {

26
manifests/vacuum.json generated
View File

@@ -27,6 +27,32 @@
"0.25": {
"version": "0.25.5"
},
"0.25.6": {
"x86_64_linux_musl": {
"etag": "0x8DE97526EC427DE",
"hash": "a72c3012e3fe1eb7e653be75b041e648cdd6b4b365a0c51e1ca344f9a106c9a6"
},
"x86_64_macos": {
"etag": "0x8DE97526F65311F",
"hash": "63362feaf01adec7d3a3ee557427acf6df32e2c3e1fa247e335e83d302dc2445"
},
"x86_64_windows": {
"etag": "0x8DE97526EBB3141",
"hash": "4663999cc8a5e10c2023129619af53340321cfb9c4eab963bf91f8edb1f320de"
},
"aarch64_linux_musl": {
"etag": "0x8DE97526EA9440E",
"hash": "d48fdd661f4484bbb44940595ff7e13cb6782aacea540868d0d44a87b5c1860a"
},
"aarch64_macos": {
"etag": "0x8DE97526F58BC05",
"hash": "77829aa18377f354d1629d7d069297b4a17597e20f7b6184d36744dc4c8358e5"
},
"aarch64_windows": {
"etag": "0x8DE97526EAE4774",
"hash": "18c9e645a1d97ebd333be634f960428d7f022dfa659ff8536673daf84b8c2a4a"
}
},
"0.25.5": {
"x86_64_linux_musl": {
"etag": "0x8DE8F75CFD30677",

View File

@@ -49,6 +49,28 @@
"0.2": {
"version": "0.2.117"
},
"0.2.118": {
"x86_64_linux_musl": {
"etag": "0x8DE972254F8FEF2",
"hash": "00b519c9fc2d6e087265da1a00f29160bfcc6a823993482bc2e691910287427b"
},
"x86_64_macos": {
"etag": "0x8DE972254EED135",
"hash": "2f1c1586c0b5bad9a25e6704825d6b1a9ccdd7c6830d57198645411545b566ad"
},
"x86_64_windows": {
"etag": "0x8DE972254D6A966",
"hash": "075902fd092f8e2a223783ccb73697f7a619bfa02e166d3b68319924a19d5a08"
},
"aarch64_linux_gnu": {
"etag": "0x8DE972254FA0F29",
"hash": "e8b75bf5055c189af5e4842bf7c58f616880fb8505a10f7cd575353a9f4e2dba"
},
"aarch64_macos": {
"etag": "0x8DE972254EE5C7F",
"hash": "f76553ae8d084dc3e96a7cef748813bf2dac4d78326166409328fc74646eef76"
}
},
"0.2.117": {
"x86_64_linux_musl": {
"etag": "0x8DE8F7E2EE60139",

150
manifests/wasmtime.json generated
View File

@@ -36,13 +36,47 @@
},
"license_markdown": "[Apache-2.0 WITH LLVM-exception](https://github.com/bytecodealliance/wasmtime/blob/main/LICENSE)",
"latest": {
"version": "43.0.0"
"version": "43.0.1"
},
"43": {
"version": "43.0.0"
"version": "43.0.1"
},
"43.0": {
"version": "43.0.0"
"version": "43.0.1"
},
"43.0.1": {
"x86_64_linux_gnu": {
"etag": "0x8DE96545D60CB65",
"hash": "9f3cf977fc29e2ccab2d198435265b066dce3d608fc6692d700ed1b9b74c35a1"
},
"x86_64_macos": {
"etag": "0x8DE96545D950E1A",
"hash": "c6ac5b23b52cb78ea7759ce9bd33985c515f2b620b9385021e32e4f51cdc0aa7"
},
"x86_64_windows": {
"etag": "0x8DE96545EE43160",
"hash": "cb627546a9f0f2f24f3d68fce34b40f13d6b1abe4b70f3afde0038ad9fe4e6ea"
},
"aarch64_linux_gnu": {
"etag": "0x8DE96545A4D6347",
"hash": "dbf36d4e9108df377ddfb88f2d8db4e07efce9726b68da53ae78ed5579293923"
},
"aarch64_macos": {
"etag": "0x8DE96545A9C6308",
"hash": "c93751ee2f0ecd34c0e799c6261b06c6efeb3c35f2bdb884569ba37931144980"
},
"aarch64_windows": {
"etag": "0x8DE96545AFDC4A6",
"hash": "0e8dc6155bda65e780279853af147b312fe62673e745a81a413b7a95be76c7ae"
},
"riscv64_linux_gnu": {
"etag": "0x8DE96545C448CDB",
"hash": "8ba5d2c2a9b613de09933998a91cae40a47fde78892f29144358f35ccf7e57c0"
},
"s390x_linux_gnu": {
"etag": "0x8DE96545C86C9A4",
"hash": "d19c7662bf478d46c235442a2ea2f230b6cb1d98bf99dfe4fc8f8892d43a8fdf"
}
},
"43.0.0": {
"x86_64_linux_gnu": {
@@ -79,10 +113,44 @@
}
},
"42": {
"version": "42.0.1"
"version": "42.0.2"
},
"42.0": {
"version": "42.0.1"
"version": "42.0.2"
},
"42.0.2": {
"x86_64_linux_gnu": {
"etag": "0x8DE9657610D0674",
"hash": "4eca8d3d6898b94cff4103dafac40610d81aaa85c10f575f82da78a1553e176d"
},
"x86_64_macos": {
"etag": "0x8DE96576193C77A",
"hash": "2baed23bfc1612e475d2f0eac7b66d12789838ec645fe8bbcd2f589d732b178b"
},
"x86_64_windows": {
"etag": "0x8DE9657632D34D9",
"hash": "4a687cf2f020ff0071c664511d1d8be2ea99dc7956d4e07e7f03aaac62cd63fa"
},
"aarch64_linux_gnu": {
"etag": "0x8DE96575E5F1A28",
"hash": "9d55dbe5cec028692ea8dd5ceaf0250541e9b7cc50a9f22586bf3e130034ad60"
},
"aarch64_macos": {
"etag": "0x8DE96575E85D785",
"hash": "94227ec56b07283c1184953c698a9b1d0cbac387a3b841e6c9dbddcd36d3a3c4"
},
"aarch64_windows": {
"etag": "0x8DE96575F3611F8",
"hash": "55ea7b324104bd55b3808129ad4159d719f0f8ef7378765b48e1e3ff0baebb2a"
},
"riscv64_linux_gnu": {
"etag": "0x8DE965760321B68",
"hash": "f0a344acd308c1d1a70466f3ec0225e1d563006cf8d21a5745eba6e529df2e3e"
},
"s390x_linux_gnu": {
"etag": "0x8DE96576067BC3E",
"hash": "663181c75c3c773052669d6c2eb34f83f1ae4d2b73368240152e5f4cadc03733"
}
},
"42.0.1": {
"x86_64_linux_gnu": {
@@ -897,10 +965,44 @@
}
},
"36": {
"version": "36.0.6"
"version": "36.0.7"
},
"36.0": {
"version": "36.0.6"
"version": "36.0.7"
},
"36.0.7": {
"x86_64_linux_gnu": {
"etag": "0x8DE9651FF60F756",
"hash": "13bd4d8865594a98811c4b5d577e30af6f6a1e3e64e2f211018963c456d4fe89"
},
"x86_64_macos": {
"etag": "0x8DE965200A57813",
"hash": "f6c21f1d69e68591bd3e0bfd72cef6a43c599db57d930fea96db89271505f782"
},
"x86_64_windows": {
"etag": "0x8DE965205C3F09A",
"hash": "02a8db01e9f6bb092c2eff51a710838f64370292ff126baac4a093b4b90cfb2d"
},
"aarch64_linux_gnu": {
"etag": "0x8DE9651EEFDD198",
"hash": "4f773bb8e587bc6d84f73aa5613fcec6e52368db452e5e13e38341e409d17a9a"
},
"aarch64_macos": {
"etag": "0x8DE9651F0509A53",
"hash": "5a2baa053e01d73f72282e3bd0b63f052f4fb41b9a690e87e3f0a0bdbb5c220c"
},
"aarch64_windows": {
"etag": "0x8DE9651F31EBBCD",
"hash": "749cbf0a84c9f347d6daff9024678e92f36bf7096ae0d24aba78c4e679f54ae0"
},
"riscv64_linux_gnu": {
"etag": "0x8DE9651F86A7A04",
"hash": "61018afd8982f9614bd898848406a59d1b97c971e37405f6655c62ac6dfbbac9"
},
"s390x_linux_gnu": {
"etag": "0x8DE9651F9AD0148",
"hash": "f94dd38b9840cf2b9dacf20ecc2f47431ac16f0740ede6f471faaf344c60eeb3"
}
},
"36.0.6": {
"x86_64_linux_gnu": {
@@ -2007,10 +2109,40 @@
}
},
"24": {
"version": "24.0.6"
"version": "24.0.7"
},
"24.0": {
"version": "24.0.6"
"version": "24.0.7"
},
"24.0.7": {
"x86_64_linux_gnu": {
"etag": "0x8DE964BC372C44C",
"hash": "98b00342031de99d5466fc3fe9b5749dc1bb1a83430a2e2335e187976a863422"
},
"x86_64_macos": {
"etag": "0x8DE964BC4D72C68",
"hash": "d8c6e8747b5f3779efff44bae34d2a9ad694a065552904611f76f6e4a7c29f01"
},
"x86_64_windows": {
"etag": "0x8DE964BCA6071C2",
"hash": "6797a846322909e61e472d2d0fa066fed301f684006133b88f6f5ab2a884603f"
},
"aarch64_linux_gnu": {
"etag": "0x8DE964BBA5101B4",
"hash": "b37d44a63237b24b86bbf891ab19ac66fcfeb6b15375d544cbc44d380a04853e"
},
"aarch64_macos": {
"etag": "0x8DE964BBB6C2FF4",
"hash": "15e38b4f2e11bdfa4b5978888192f3f85b456a19c75565dcba087817bac15dd7"
},
"riscv64_linux_gnu": {
"etag": "0x8DE964BBCC7C852",
"hash": "041d27633efdb8242dc9798e903e06a22622d7df7ccf300eb94c9435cf0fb4f6"
},
"s390x_linux_gnu": {
"etag": "0x8DE964BBE2360B4",
"hash": "38aa619242a781d61175dc57410b03a6d0da30f16e03b5a6356951b16faa0adc"
}
},
"24.0.6": {
"x86_64_linux_gnu": {

View File

@@ -147,12 +147,12 @@ for manifest in tools/codegen/base/*.json; do
fi
case "${host_os}" in
linux*)
if [[ "${host_arch}" != "x86_64" ]] && [[ "$(jq -r ".platform.${host_arch}_${host_os}_gnu" "${manifest}")" == "null" ]] && [[ "$(jq -r ".platform.${host_arch}_${host_os}_musl" "${manifest}")" == "null" ]]; then
if [[ "${host_arch}" != "x86_64" ]] && [[ "$(jq -r --arg p "${host_arch}_${host_os}_gnu" '.platform[$p]' "${manifest}")" == "null" ]] && [[ "$(jq -r --arg p "${host_arch}_${host_os}_musl" '.platform[$p]' "${manifest}")" == "null" ]]; then
continue
fi
;;
*)
if [[ "$(jq -r ".platform.x86_64_${host_os}" "${manifest}")" == "null" ]] && [[ "$(jq -r ".platform.${host_arch}_${host_os}" "${manifest}")" == "null" ]]; then
if [[ "$(jq -r --arg p "x86_64_${host_os}" '.platform[$p]' "${manifest}")" == "null" ]] && [[ "$(jq -r --arg p "${host_arch}_${host_os}" '.platform[$p]' "${manifest}")" == "null" ]]; then
continue
fi
;;