deps: update dependency jdx/mise to v2026.5.9#1404
Merged
Conversation
91edeb5 to
4a939b2
Compare
4a939b2 to
8a2ce13
Compare
8a2ce13 to
279877b
Compare
279877b to
99d4a67
Compare
99d4a67 to
ac3fdab
Compare
ac3fdab to
9962451
Compare
9962451 to
9b40004
Compare
phm07
approved these changes
May 15, 2026
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
2026.5.2→2026.5.92026.4.19→2026.5.9Release Notes
jdx/mise (jdx/mise)
v2026.5.9: : SwiftPM artifact bundles and per-hook watch shellsCompare Source
A modest release: SwiftPM gains artifact bundle support,
[[watch_files]]hooks can pick their own inline shell, and a handful of fixes land for aqua latest-tag resolution, vfoxcmd.exec, and GitHub OAuth device-flow URLs. Plain-string Tera rendering also gets a fast path.Added
(spm) SwiftPM installs now prefer prebuilt artifact bundles (
*.artifactbundle.zip) when a release publishes one for the current Swift target triple, falling back to a source build otherwise (#9825) by @ikesyo. New controls:(config)
[[watch_files]]entries withrunaccept an optionalshellfield, rendered through templates and falling back to the configured default inline shell when unset (#9810) by @risu729:shellonly applies torunhooks; combining it withtaskproduces a warning and the value is ignored.Fixed
latestrelease pointed at a tag that aqua's registry rejected viaversion_filterorversion_constraint, mise would return it anyway. The latest fast path now applies both checks before accepting a tag (#9834) by @risu729.cmd.execcalls inside vfox plugins now build commands from mise's configuredunix_default_inline_shell_args/windows_default_inline_shell_argsinstead of hardcodingsh -corcmd /C, aligning plugin behavior with tasks, Tera command rendering, and other inline shell users (#9837) by @risu729.oauth_auth_urlis now the GitHub login base, with mise appending/device/codeand/oauth/access_tokenper GitHub's device-flow docs (#9791) by @jasisk.mise patronsnow points the "become a patron" link to the en.dev homepage instead of/sponsor(#9868) by @jdx.Changed
npmis now resolved throughaqua:npm/cli(withnpm:npmretained as a fallback), andbuck2switches toaqua:facebook/buck2withprerelease = trueso its always-prerelease releases are visible (#9762, #9805) by @risu729.aqua:SonarSource/sonarqube-cli(#9824) by @3PeatVR.Performance
{{,{%,{#, including whitespace-trimmed forms) now bypass the Tera renderer at config evaluation sites, skipping context construction, async context fetches, andget_terasetup. Tera 1.20.1's grammar guarantees these are the only block openers, so output is unchanged for both well-formed and malformed templates (#9833) by @risu729.Documentation
New Contributors
Full Changelog: jdx/mise@v2026.5.8...v2026.5.9
💚 Sponsor mise
mise is built by @jdx under en.dev — an independent studio making developer tooling (mise, aube, and more). Development is funded by sponsors.
If mise saves you or your team time, please consider sponsoring at en.dev. Individual and company sponsorships keep mise fast, free, and independent.
v2026.5.8: : Patrons, cleaner task output, and sigstore-rustCompare Source
A small release: a new
mise patronscommand, cleaner task command output when scripts start with a shebang, and a fix formise upgradesummaries getting wiped by progress cleanup. Under the hood, signature verification moves to the modern sigstore-rust stack.Added
(patrons) New
mise patronssubcommand lists individuals on the Patron tier supporting mise development (#9841) by @jdx. Data is fetched from the en.dev patrons feed, cached for 24h, and falls back to stale cache on network failure. Each patron's name renders as a clickable OSC 8 hyperlink in supporting terminals.Flags:
-J/--json,--refresh.(registry) Add a
racketshorthand backed by the aquaracket/racket/minimalpackage, exposing bothracketandracofrom the official racket-lang.org release artifacts (#9784) by @albertnetymk.Fixed
(task) When a task's
runbody starts with#!/usr/bin/env bashorset -Eeuo pipefail, the echoed command line would show only that boilerplate and hide the rest of the script. Leading shebang, blank, andset ...lines are now skipped when building the displayed command, so the first real command shows up. Execution is unchanged (#9844) by @jdx. Fixes #9842.(upgrade)
mise upgradecould erase its ownUpgraded N tools:summary detail lines when an upgrade also performed an uninstall — fresh progress jobs registered for the cleanup phase were still active at shutdown, sostop_clear()wiped them along with the summary. Progress jobs are now finished and reset before the summary prints (#9860) by @risu729. Regression from #9779; addresses #9856.Changed
verify_github_attestation,verify_cosign_signature,verify_slsa_provenance,detect_attestations) now runs on a localmise-sigstoreadapter built onsigstore-verify0.7 from sigstore-rust, replacing the previoussigstore-verification0.2 dependency (#9260) by @jdx. The mise call sites and helper API are unchanged. The new adapter still covers legacy cosign v1 bundles (e.g. goreleaser-signed releases) and raw DSSE*.intoto.jsonlenvelopes (slsa-github-generator) that the upstreamBundle::from_jsonrejects.Deprecated
(config) The top-level
env_filesetting (andMISE_ENV_FILE) is now marked deprecated. Useenv._.fileinmise.tomlinstead (#9862) by @risu729. The JSON Schema gains thedeprecatedkeyword, a warning is scheduled for 2026.11.0, and removal is planned for 2027.11.0.New Contributors
Full Changelog: jdx/mise@v2026.5.7...v2026.5.8
💚 Sponsor mise
mise is built by @jdx under en.dev — an independent studio making developer tooling (mise, aube, and more). Development is funded by sponsors.
If mise saves you or your team time, please consider sponsoring at en.dev. Individual and company sponsorships keep mise fast, free, and independent.
v2026.5.7: : Lazy GitHub tokens, hardened version parsing, and faster task freshnessCompare Source
A round of correctness and performance fixes: vfox-managed tools no longer prompt your password manager on every shell hook,
mise upgradestops double-printing its summary,mise settings getfinally distinguishes typos from unset values, and conda installs that pulled inadwaita-icon-themeare unstuck. Plus a security pass that hardens version-string parsing against shell injection.Fixed
(vfox) GitHub tokens are now resolved lazily inside Lua plugins. Previously,
mise hook-env,mise activate,mise completion, and evenmise --helpwould callgithub.credential_commandfor every installed vfox tool — potentially unlocking a password manager on every prompt. The resolver is now only invoked when a Lua plugin actually issues an HTTP request to a GitHub API URL, e.g. during an install (#9816) by @jdx. Fixes #9797.(upgrade)
mise upgrade(andmise up) no longer prints the installed-tools block twice when an upgrade also needs to uninstall an older version. The shared progress-job registry is now cleared after each phase so the subsequent uninstall renders cleanly (#9779) by @jdx. Fixes #9774.(settings)
mise settings getdistinguishes between a known setting that hasn't been set and a typo:$ mise settings get python.compile mise ERROR Setting [python.compile] is not set $ mise settings get not.a.real.setting mise ERROR Unknown setting: not.a.real.settingPreviously both returned
Unknown setting, sinceOption<T>fields skipped by TOML serialization were indistinguishable from missing keys (#9818) by @jdx.(backend) Several backends (
aqua,github/gitlab/forgejo,http,s3,ubi,vfox,conda, Windowsnpm) reportedbin-pathspointing at the concrete resolved install dir (e.g.installs/tiny/1.0.0/...) instead of the stable runtime symlink for the requested label (e.g.installs/tiny/latest/...). A newruntime_path_for_install_pathhelper remaps backend-discovered absolute paths onto the runtime path while leaving explicit relativebin_pathvalues alone (#9606) by @risu729.(conda)
mise use -g imagemagick(and other tools pulling inadwaita-icon-theme) failed withconda solve failed: encountered duplicate records for adwaita-icon-theme-40.1.1-.... rattler-solve detects duplicates byDistArchiveIdentifierrather than URL, so when conda-forge served the same archive under multiple CDN URLs, the existing URL-based dedup wasn't enough. Dedup now usesr.identifier, the exact key the solver uses (#9831) by @jdx. Fixes #9829.Added
github.credential_commandnow runs through the configured default inline shell (instead of hardcodedsh -c) and is invoked withMISE_CREDENTIAL_HOSTandMISE_CREDENTIAL_PROVIDERin the environment. The deprecated$1/${1}hostname positional argument continues to work for sh-compatible shells (ash,bash,dash,ksh,sh,zsh); a deprecation warning lands in2026.11.0and removal is planned for2027.11.0(#9664) by @risu729.Performance
(aqua) The baked aqua standard-registry package and alias lookup tables are now generated as static
phf::Maps at build time viaphf_codegen, instead of lazy runtimeHashMaps. Warmed lookup is comparable, but first-use no longer allocates ~115 KiB of heap or builds a 2,179-entry bucket table (#9763) by @risu729.(task) When
task.source_freshness_hash_contents = true, mise now caches each source file's blake3 hash keyed by(size, mtime_secs, mtime_nanos)— git's stat-info trick — in a per-task file underSTATE/task-sources/. Unchanged files are skipped on subsequent runs; entries for files removed fromsourcesare pruned automatically (#9819) by @jdx. See discussion #9802.Security
ToolRequestboundary (#9814) by @jdx.ToolRequest::newnow validatesversion,prefix,ref/*,sub-*, andpath:requests, rejecting$, backticks, quotes,\, control chars, and..traversal. This single change neutralizes the CRITICAL RCE class flagged againstvfox-ag,vfox-bfs,vfox-bpkg,vfox-chezscheme,vfox-redis,vfox-yarn, and shell-injection findings onclickhouse,leiningen,pipenv,poetry,azure-functions-core-tools,carthage, andandroid-sdk, since no Lua hook can observe a hostilectx.version/ctx.rootPath. Real-world strings like1.2.3-beta,lts/hydrogen,3.12.0a1, andnightlycontinue to validate. The PR also tightensworkflow_dispatchinput validation in the COPR, PPA, npm-publish, and Docker workflows.Registry
exe = ...options across ~30 GitHub/GitLab registry entries (astro,babashka,coursier,glab,odin,openbao,purescript, and many more) (#9587) by @risu729. Two entries gained real config to fix Linux installs:soliditynow usesbin = "solc"so the installed binary matches the upstreamsolc-static-linuxasset.sourcerynow usesformat = "tar.gz"because the upstream Linux asset is gzip-compressed despite its.tar.xzfilename.pitoearendil-works/pi(#9792) by @garysassano.Documentation
Full Changelog: jdx/mise@v2026.5.6...v2026.5.7
💚 Sponsor mise
mise is built by @jdx under en.dev — an independent studio making developer tooling (mise, aube, and more). Development is funded by sponsors.
If mise saves you or your team time, please consider sponsoring at en.dev. Individual and company sponsorships keep mise fast, free, and independent.
v2026.5.6: : Native GitHub OAuth, project-scoped OCI builds, faster registriesCompare Source
A mix of features and correctness work: a native GitHub OAuth token source (experimental) that drops the dependency on
gh/ghtkn,mise ocicommands scoped to the current project by default, and two registry-lookup performance wins — plus fixes across activate, exec, java, lock, pipx, and vfox.Added
(cli) Add
--before <date>tomise ls-remoteandmise lockfor release-date-aware version discovery (#9269) by @risu729(config) Hooks can now be defined as a table —
{ run = "...", shell = "bash -c" }— to pick a shell inline, alongside the existing string form (#9718) by @risu729(github) Add native GitHub OAuth device-flow token source (experimental) — no dependency on
gh/ghtkn(#9654) by @jdx. Create a GitHub App with device flow enabled, then authorize once:mise caches and refreshes the token for its own GitHub API calls, and auto-exports it as
GITHUB_TOKENto shells started undermise activate/execsogh,git, and other GitHub-aware tools pick it up too. See GitHub Tokens → Native GitHub OAuth for the full setup.(oci)
mise oci build/run/pushare now scoped to the current project's config by default; pass--include-globalto opt back into the previous behavior of including global config (#9766) by @jdx(outdated) Prefixed-version requests now resolve to the latest within the prefix — e.g.
temurin-17.0.19+10for atemurin-17.xrequest, instead of jumping ahead totemurin-26.x(#9767) by @roeleFixed
chpwd_functionsexpansion underset -uso activated shells no longer fail withchpwd_functions[@​]: unbound variable(#9716) by @risu729latest_stable_versionfast path when--beforeorminimum_release_ageis active, instead of returning a too-new version (#9650) by @risu729[depends=...]andos=set the named core fields (#9742) by @risu729mise -C <dir> execcorrectly resolves the inner toolset's tools again —__MISE_DIFFis now propagated to children so the child no longer inherits a mutated PATH that hides its own tools (#9765) by @jdxprerelease = true/MISE_PRERELEASES=1is set (#9717) by @risu729core:javalockfile URLs/checksums from mise Java metadata, fixingmise install --lockedfor Java (#9719) by @risu729github_attestations = "unavailable"so locked installs stop hitting the GitHub attestation API for artifacts known to have none (#9741) by @risu729uvx_args/pipx_args/extras/uvx = falsewhen pipx tools are reinstalled after a Python upgrade (#9663) by @risu729provenance = "github-attestations"(#9739) by @risu729pre_uninstallhooks before removing install directories (#9662) by @risu729programandargsincmd::cmd(..)debug output so logged commands are unambiguous (#9777) by @ktetzlaffPerformance
phffor the mise registry lookup table, around 3.3x faster than the previousBTreeMappath (#9769) by @risu729Registry
vector(#9761) by @kquinslandopenshift-installand anhttp:backend foroc(#9669) by @kononoNew Contributors
Full Changelog: jdx/mise@v2026.5.5...v2026.5.6
💚 Sponsor mise
mise is built by @jdx under en.dev — an independent studio making developer tooling (mise, aube, and more). Development is funded by sponsors.
If mise saves you or your team time, please consider sponsoring at en.dev. Individual and company sponsorships keep mise fast, free, and independent.
v2026.5.5: : Inactive upgrades, Windows bash and bunx fixesCompare Source
A grab-bag release: a new
--inactiveflag for catching installed-but-unconfigured tools, several Windows fixes aroundbunxand thebashtask shell, and correctness fixes for the npm shim, aqua bin-path resolution, and dotnet prereleases.Added
(outdated/upgrade) New
--inactiveflag onmise outdatedandmise upgradethat includes installed-but-inactive tools — versions you have installed but that aren't referenced by the current config (#9640) by @roele. Useful for cleaning up or upgrading old tool installs:When a tool has no config source,
--inactiveresolves against the backend's latest version rather than the pinned installed version.Fixed
(node) The generated npm shim now invokes
<this-install>/bin/nodedirectly instead ofnodefromPATH. Previously, running one Node install'snpmwhile a different Node version was active could let npm derive its global prefix from the other install, sending default packages to the wrong place (#9749) by @jdx.(bun, Windows)
mise install bunon Windows now creates abunxentry alongsidebun.exe, matching what the upstream PowerShell installer does. mise tries abunx.exe -> bun.exehardlink first (bun switches to bunx mode based on argv[0]) and falls back to abunx.cmdshim.reshimpicks it up automatically, sobunx <pkg>finally works under mise-managed bun on Windows (#9732) by @JamBalaya56562.(task, Windows) When a task uses
shell = "bash -c"and mise is invoked from PowerShell,C:\Windows\System32\bash.exe(the WSL launcher) used to win thePATHsearch, silently running the task body inside a WSL Linux user-space where mise-managed Windows tools aren't visible. mise now resolves bash in this order:MISE_BASH_PATH, common Git Bash install locations (C:\Program Files\Git\bin\bash.exe, the x86 variant,%LOCALAPPDATA%\Programs\Git\bin\bash.exe), the existing PATH search, and finally an explicit reject of the WSL launcher with a warning (#9750) by @JamBalaya56562.sh/zsh/fish/ksh/dashand non-Windows builds are unaffected.(aqua) Aqua
list_bin_paths()correctly handles packages whose actual git tags add an extravafter a version prefix (e.g.tool-v1.2.3for canonical1.2.3), without putting remote resolution back on the bin-path hot path that was reverted in #5574. Install passes the already-resolved tag/version directly into file-link creation instead of recomputing it (#9759) by @risu729.(dotnet) The dotnet backend now uses the shared
prerelease = truetool option used by aqua/github, fetches the NuGet prerelease superset, and skips the latest fast paths when prereleases are enabled. The globalprereleasessetting and the deprecateddotnet.package_flags = ["prerelease"]continue to work (#9720) by @risu729:MISE_EXPERIMENTAL=1 mise ls-remote 'dotnet:GitVersion.Tool[prerelease=true]'Registry
scalafmt(github:scalameta/scalafmt) — the official Scala formatter (#9757) by @pokir.flarectl: upstreamcloudflare/cloudflare-gono longer ships release binaries (the existing registry test was already commented out) (#9756) by @risu729.mise use aqua:cloudfoundry/uaa-cli).Documentation
age.strict=falseskips undecryptable values and keeps resolving the environment (#9737) by @risu729.size,strip_components,bin, andrename_exe; addno_appto GitLab and Forgejo; clarify that GitHub-familyapi_urlcovers release lookup and private/self-hosted API downloads, not just version listing (#9738) by @risu729.New Contributors
Full Changelog: jdx/mise@v2026.5.4...v2026.5.5
💚 Sponsor mise
mise is built by @jdx under en.dev — an independent studio making developer tooling (mise, aube, and more). Development is funded by sponsors.
If mise saves you or your team time, please consider sponsoring at en.dev. Individual and company sponsorships keep mise fast, free, and independent.
v2026.5.4: : Java on Alpine, faster pwsh exitsCompare Source
A small release that smooths out Java installs on Alpine, makes pwsh shell activation noticeably snappier, and cleans up
ibmcloud's$PATHfootprint.Added
(java) Automatic musl detection on Alpine Linux (#9688) by @roele. Java versions on Alpine no longer require an explicit
-muslfeature suffix —mise-javanow exposes analpine-linuxOS containing the musl builds, and mise selects it automatically when running on a musl libc. So this:picks the Alpine/musl Corretto build on Alpine, and
-musl-suffixed versions (e.g.corretto-musl-25) continue to resolve for backwards compatibility.Fixed
ibmcloudnow usessymlink_bins, so only theibmcloudbinary is placed on$PATHinstead of the entire install directory. This prevents the bundledinstallbinary from shadowing/usr/bin/install(#9685) by @dnwe.Performance
pwsh -NoProfile -Command exit $status(orpowershellon PS 5) after every hook just to propagate mise's exit code — it now assigns$global:LASTEXITCODE = $statusdirectly. On a typical machine that's ~270ms (pwsh) or ~185ms (powershell) shaved off every prompt (#9723) by @vemoo.Changed
xtasks/render/schema.tsno longer overwrites$defs.task_templateand the trailing$defs.task.oneOfbranch on everymise run render:schema; those shapes already live inschema/mise.json, with lightweight guard checks remaining (#9680) by @risu729.Aqua Registry Updates
New packages:
DataDog/managed-kubernetes-auditing-toolkitoracle.com/sqlclUpdated packages:
alltuner/mise-completions-synciann0036/iamlivepnpm/pnpmFull Changelog: jdx/mise@v2026.5.3...v2026.5.4
💚 Sponsor mise
mise is built by @jdx under en.dev — an independent studio making developer tooling (mise, aube, and more). Development is funded by sponsors.
If mise saves you or your team time, please consider sponsoring at en.dev. Individual and company sponsorships keep mise fast, free, and independent.
v2026.5.3: : Aqua latest from GitHub releasesCompare Source
A small patch release that fixes how the aqua backend resolves
latestfor tools backed by GitHub releases.Fixed
latestvia GitHub's latest-release endpoint instead of walking the chronological tag list, somise use <tool>@​latestand similar requests pick the upstream "latest" release rather than the newest tag. Packages usingversion_source = github_tagcontinue to use the existing tag-based fallback, andbefore_date/minimum_release_agesettings still bypass the fast path. Tag-to-version normalization (version prefixes, leadingv, asset checks) is now shared across remote listing, install lookup, and latest resolution (#9277) by @risu729.Full Changelog: jdx/mise@v2026.5.2...v2026.5.3
💚 Sponsor mise
mise is built by @jdx under en.dev — an independent studio making developer tooling (mise, aube, and more). Development is funded by sponsors.
If mise saves you or your team time, please consider sponsoring at en.dev. Individual and company sponsorships keep mise fast, free, and independent.
Configuration
📅 Schedule: (UTC)
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about these updates again.
This PR was generated by Mend Renovate. View the repository job log.