core: enable npm bin links on non-Windows platforms to allow plugin executables to work while keeping them disabled on Windows CI where symlink permissions are restricted

opencode/quiet-pixel
Dax Raad 2026-03-09 23:37:58 -04:00
parent 1b408cf06b
commit 0b5d54f2cb
2 changed files with 4 additions and 11 deletions

View File

@ -34,8 +34,6 @@ import { Account } from "@/account"
import { ConfigPaths } from "./paths"
import { Filesystem } from "@/util/filesystem"
import { Npm } from "@/npm"
import { BunProc } from "@/bun"
import { proxied } from "@/util/proxied"
export namespace Config {
const ModelId = z.string().meta({ $ref: "https://models.dev/model-schema.json#/$defs/Model" })
@ -289,14 +287,7 @@ export namespace Config {
// Install any additional dependencies defined in the package.json
// This allows local plugins and custom tools to use external packages
await BunProc.run(
[
"install",
// TODO: get rid of this case (see: https://github.com/oven-sh/bun/issues/19936)
...(proxied() || process.env.CI ? ["--no-cache"] : []),
],
{ cwd: dir },
).catch((err) => {
await Npm.install(dir).catch((err) => {
log.warn("failed to install dependencies", { dir, error: err })
})
}

View File

@ -84,9 +84,11 @@ export namespace Npm {
export async function install(dir: string) {
log.info("installing dependencies", { dir })
// Disable binLinks on Windows CI where symlink permissions are restricted
const isWindowsCI = process.platform === "win32" && process.env.CI
const arb = new Arborist({
path: dir,
binLinks: false,
binLinks: !isWindowsCI,
progress: false,
savePrefix: "",
})