mirror of
https://github.com/oven-sh/setup-bun.git
synced 2025-04-04 10:40:40 +08:00
fix: getPlatform, getArchitecture + eversion
This commit is contained in:
parent
c3e2edf950
commit
528c4707b7
@ -13,7 +13,7 @@ import { downloadTool, extractZip } from "@actions/tool-cache";
|
|||||||
import { getExecOutput } from "@actions/exec";
|
import { getExecOutput } from "@actions/exec";
|
||||||
import { writeBunfig } from "./bunfig";
|
import { writeBunfig } from "./bunfig";
|
||||||
import { saveState } from "@actions/core";
|
import { saveState } from "@actions/core";
|
||||||
import { addExtension, request } from "./utils";
|
import { addExtension, getArchitecture, getPlatform, request } from "./utils";
|
||||||
import { compareVersions, satisfies, validate } from "compare-versions";
|
import { compareVersions, satisfies, validate } from "compare-versions";
|
||||||
|
|
||||||
export type Input = {
|
export type Input = {
|
||||||
@ -179,18 +179,18 @@ async function getDownloadUrl(options: Input): Promise<string> {
|
|||||||
if (!tag) {
|
if (!tag) {
|
||||||
tags = tags.filter((t) => validate(t)).sort(compareVersions);
|
tags = tags.filter((t) => validate(t)).sort(compareVersions);
|
||||||
|
|
||||||
if (version === "latest") tag = tags.at(-1);
|
if (version === "latest") tag = `bun-v${tags.at(-1)}`;
|
||||||
else tag = tags.filter((t) => satisfies(t, version)).at(-1);
|
else tag = `bun-${tags.filter((t) => satisfies(t, version)).at(-1)}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
const eversion = encodeURIComponent(tag ?? version);
|
const eversion = encodeURIComponent(tag ?? version);
|
||||||
const eos = encodeURIComponent(os ?? process.platform);
|
const eos = encodeURIComponent(os ?? getPlatform());
|
||||||
const earch = encodeURIComponent(arch ?? process.arch);
|
const earch = encodeURIComponent(arch ?? getArchitecture());
|
||||||
const eavx2 = encodeURIComponent(avx2 ? "-baseline" : "");
|
const eavx2 = encodeURIComponent(avx2 ? "-baseline" : "");
|
||||||
const eprofile = encodeURIComponent(profile ? "-profile" : "");
|
const eprofile = encodeURIComponent(profile ? "-profile" : "");
|
||||||
|
|
||||||
const { href } = new URL(
|
const { href } = new URL(
|
||||||
`bun-${eversion}/bun-${eos}-${earch}${eavx2}${eprofile}.zip`,
|
`${eversion}/bun-${eos}-${earch}${eavx2}${eprofile}.zip`,
|
||||||
"https://github.com/oven-sh/bun/releases/download/"
|
"https://github.com/oven-sh/bun/releases/download/"
|
||||||
);
|
);
|
||||||
|
|
||||||
|
14
src/utils.ts
14
src/utils.ts
@ -26,6 +26,20 @@ export function addExtension(path: string, ext: string): string {
|
|||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function getPlatform(): string {
|
||||||
|
const platform = process.platform;
|
||||||
|
if (platform === "win32") return "windows";
|
||||||
|
|
||||||
|
return platform;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function getArchitecture(): string {
|
||||||
|
const arch = process.arch;
|
||||||
|
if (arch === "arm64") return "aarch64";
|
||||||
|
|
||||||
|
return arch;
|
||||||
|
}
|
||||||
|
|
||||||
const FILE_VERSION_READERS = {
|
const FILE_VERSION_READERS = {
|
||||||
"package.json": (content: string) =>
|
"package.json": (content: string) =>
|
||||||
JSON.parse(content).packageManager?.split("bun@")?.[1],
|
JSON.parse(content).packageManager?.split("bun@")?.[1],
|
||||||
|
Loading…
x
Reference in New Issue
Block a user