chore: update Prettier settings and add settings for vscode

This commit is contained in:
Okinea Dev 2025-02-04 09:40:22 +02:00
parent 6fb6603cc1
commit f6221cd95f
No known key found for this signature in database
GPG Key ID: 07944BC5E01E7B43
11 changed files with 191 additions and 183 deletions

4
.prettierrc Normal file
View File

@ -0,0 +1,4 @@
{
"semi": false,
"quoteProps": "preserve"
}

3
.vscode/extensions.json vendored Normal file
View File

@ -0,0 +1,3 @@
{
"recommendations": ["esbenp.prettier-vscode", "github.vscode-github-actions"]
}

3
.vscode/settings.json vendored Normal file
View File

@ -0,0 +1,3 @@
{
"editor.defaultFormatter": "esbenp.prettier-vscode"
}

6
bun.lock Executable file → Normal file
View File

@ -1,5 +1,5 @@
{ {
"lockfileVersion": 0, "lockfileVersion": 1,
"workspaces": { "workspaces": {
"": { "": {
"dependencies": { "dependencies": {
@ -13,7 +13,7 @@
"devDependencies": { "devDependencies": {
"@types/node": "^20.8.2", "@types/node": "^20.8.2",
"esbuild": "^0.19.2", "esbuild": "^0.19.2",
"prettier": "^2.8.4", "prettier": "^3.4.2",
"typescript": "^4.9.5", "typescript": "^4.9.5",
}, },
}, },
@ -139,7 +139,7 @@
"node-fetch": ["node-fetch@2.7.0", "", { "dependencies": { "whatwg-url": "^5.0.0" }, "peerDependencies": { "encoding": "^0.1.0" }, "optionalPeers": ["encoding"] }, "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A=="], "node-fetch": ["node-fetch@2.7.0", "", { "dependencies": { "whatwg-url": "^5.0.0" }, "peerDependencies": { "encoding": "^0.1.0" }, "optionalPeers": ["encoding"] }, "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A=="],
"prettier": ["prettier@2.8.8", "", { "bin": { "prettier": "bin-prettier.js" } }, "sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q=="], "prettier": ["prettier@3.4.2", "", { "bin": { "prettier": "bin/prettier.cjs" } }, "sha512-e9MewbtFo+Fevyuxn/4rrcDAaq0IYxPGLvObpQjiZBMAzB9IGmzlnG9RZy3FFas+eBMu2vA0CszMeduow5dIuQ=="],
"process": ["process@0.11.10", "", {}, "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A=="], "process": ["process@0.11.10", "", {}, "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A=="],

10
package-lock.json generated
View File

@ -19,7 +19,7 @@
"devDependencies": { "devDependencies": {
"@types/node": "^20.8.2", "@types/node": "^20.8.2",
"esbuild": "^0.19.2", "esbuild": "^0.19.2",
"prettier": "^2.8.4", "prettier": "^3.4.2",
"typescript": "^4.9.5" "typescript": "^4.9.5"
} }
}, },
@ -473,14 +473,16 @@
} }
}, },
"node_modules/prettier": { "node_modules/prettier": {
"version": "2.8.8", "version": "3.4.2",
"resolved": "https://registry.npmjs.org/prettier/-/prettier-3.4.2.tgz",
"integrity": "sha512-e9MewbtFo+Fevyuxn/4rrcDAaq0IYxPGLvObpQjiZBMAzB9IGmzlnG9RZy3FFas+eBMu2vA0CszMeduow5dIuQ==",
"dev": true, "dev": true,
"license": "MIT", "license": "MIT",
"bin": { "bin": {
"prettier": "bin-prettier.js" "prettier": "bin/prettier.cjs"
}, },
"engines": { "engines": {
"node": ">=10.13.0" "node": ">=14"
}, },
"funding": { "funding": {
"url": "https://github.com/prettier/prettier?sponsor=1" "url": "https://github.com/prettier/prettier?sponsor=1"

View File

@ -32,10 +32,7 @@
"devDependencies": { "devDependencies": {
"@types/node": "^20.8.2", "@types/node": "^20.8.2",
"esbuild": "^0.19.2", "esbuild": "^0.19.2",
"prettier": "^2.8.4", "prettier": "^3.4.2",
"typescript": "^4.9.5" "typescript": "^4.9.5"
},
"prettier": {
"quoteProps": "preserve"
} }
} }

View File

@ -1,117 +1,117 @@
import { createHash } from "node:crypto"; import { createHash } from "node:crypto"
import { homedir } from "node:os"; import { homedir } from "node:os"
import { join } from "node:path"; import { join } from "node:path"
import { import {
mkdirSync, mkdirSync,
readdirSync, readdirSync,
symlinkSync, symlinkSync,
renameSync, renameSync,
copyFileSync, copyFileSync,
} from "node:fs"; } from "node:fs"
import { addPath, info, warning } from "@actions/core"; import { addPath, info, warning } from "@actions/core"
import { isFeatureAvailable, restoreCache } from "@actions/cache"; import { isFeatureAvailable, restoreCache } from "@actions/cache"
import { downloadTool, extractZip } from "@actions/tool-cache"; 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, retry } from "./utils"; import { addExtension, retry } from "./utils"
export type Input = { export type Input = {
customUrl?: string; customUrl?: string
version?: string; version?: string
os?: string; os?: string
arch?: string; arch?: string
avx2?: boolean; avx2?: boolean
profile?: boolean; profile?: boolean
scope?: string; scope?: string
registryUrl?: string; registryUrl?: string
noCache?: boolean; noCache?: boolean
}; }
export type Output = { export type Output = {
version: string; version: string
revision: string; revision: string
bunPath: string; bunPath: string
url: string; url: string
cacheHit: boolean; cacheHit: boolean
}; }
export type CacheState = { export type CacheState = {
cacheEnabled: boolean; cacheEnabled: boolean
cacheHit: boolean; cacheHit: boolean
bunPath: string; bunPath: string
url: string; url: string
}; }
export default async (options: Input): Promise<Output> => { export default async (options: Input): Promise<Output> => {
const bunfigPath = join(process.cwd(), "bunfig.toml"); const bunfigPath = join(process.cwd(), "bunfig.toml")
writeBunfig(bunfigPath, options); writeBunfig(bunfigPath, options)
const url = getDownloadUrl(options); const url = getDownloadUrl(options)
const cacheEnabled = isCacheEnabled(options); const cacheEnabled = isCacheEnabled(options)
const binPath = join(homedir(), ".bun", "bin"); const binPath = join(homedir(), ".bun", "bin")
try { try {
mkdirSync(binPath, { recursive: true }); mkdirSync(binPath, { recursive: true })
} catch (error) { } catch (error) {
if (error.code !== "EEXIST") { if (error.code !== "EEXIST") {
throw error; throw error
} }
} }
addPath(binPath); addPath(binPath)
const exe = (name: string) => const exe = (name: string) =>
process.platform === "win32" ? `${name}.exe` : name; process.platform === "win32" ? `${name}.exe` : name
const bunPath = join(binPath, exe("bun")); const bunPath = join(binPath, exe("bun"))
try { try {
symlinkSync(bunPath, join(binPath, exe("bunx"))); symlinkSync(bunPath, join(binPath, exe("bunx")))
} catch (error) { } catch (error) {
if (error.code !== "EEXIST") { if (error.code !== "EEXIST") {
throw error; throw error
} }
} }
let revision: string | undefined; let revision: string | undefined
let cacheHit = false; let cacheHit = false
if (cacheEnabled) { if (cacheEnabled) {
const cacheKey = createHash("sha1").update(url).digest("base64"); const cacheKey = createHash("sha1").update(url).digest("base64")
const cacheRestored = await restoreCache([bunPath], cacheKey); const cacheRestored = await restoreCache([bunPath], cacheKey)
if (cacheRestored) { if (cacheRestored) {
revision = await getRevision(bunPath); revision = await getRevision(bunPath)
if (revision) { if (revision) {
cacheHit = true; cacheHit = true
info(`Using a cached version of Bun: ${revision}`); info(`Using a cached version of Bun: ${revision}`)
} else { } else {
warning( warning(
`Found a cached version of Bun: ${revision} (but it appears to be corrupted?)` `Found a cached version of Bun: ${revision} (but it appears to be corrupted?)`,
); )
} }
} }
} }
if (!cacheHit) { if (!cacheHit) {
info(`Downloading a new version of Bun: ${url}`); info(`Downloading a new version of Bun: ${url}`)
// TODO: remove this, temporary fix for https://github.com/oven-sh/setup-bun/issues/73 // TODO: remove this, temporary fix for https://github.com/oven-sh/setup-bun/issues/73
revision = await retry(async () => await downloadBun(url, bunPath), 3); revision = await retry(async () => await downloadBun(url, bunPath), 3)
} }
if (!revision) { if (!revision) {
throw new Error( throw new Error(
"Downloaded a new version of Bun, but failed to check its version? Try again." "Downloaded a new version of Bun, but failed to check its version? Try again.",
); )
} }
const [version] = revision.split("+"); const [version] = revision.split("+")
const cacheState: CacheState = { const cacheState: CacheState = {
cacheEnabled, cacheEnabled,
cacheHit, cacheHit,
bunPath, bunPath,
url, url,
}; }
saveState("cache", JSON.stringify(cacheState)); saveState("cache", JSON.stringify(cacheState))
return { return {
version, version,
@ -119,92 +119,92 @@ export default async (options: Input): Promise<Output> => {
bunPath, bunPath,
url, url,
cacheHit, cacheHit,
}; }
}; }
async function downloadBun( async function downloadBun(
url: string, url: string,
bunPath: string bunPath: string,
): Promise<string | undefined> { ): Promise<string | undefined> {
// Workaround for https://github.com/oven-sh/setup-bun/issues/79 and https://github.com/actions/toolkit/issues/1179 // Workaround for https://github.com/oven-sh/setup-bun/issues/79 and https://github.com/actions/toolkit/issues/1179
const zipPath = addExtension(await downloadTool(url), ".zip"); const zipPath = addExtension(await downloadTool(url), ".zip")
const extractedZipPath = await extractZip(zipPath); const extractedZipPath = await extractZip(zipPath)
const extractedBunPath = await extractBun(extractedZipPath); const extractedBunPath = await extractBun(extractedZipPath)
try { try {
renameSync(extractedBunPath, bunPath); renameSync(extractedBunPath, bunPath)
} catch { } catch {
// If mv does not work, try to copy the file instead. // If mv does not work, try to copy the file instead.
// For example: EXDEV: cross-device link not permitted // For example: EXDEV: cross-device link not permitted
copyFileSync(extractedBunPath, bunPath); copyFileSync(extractedBunPath, bunPath)
} }
return await getRevision(bunPath); return await getRevision(bunPath)
} }
function isCacheEnabled(options: Input): boolean { function isCacheEnabled(options: Input): boolean {
const { customUrl, version, noCache } = options; const { customUrl, version, noCache } = options
if (noCache) { if (noCache) {
return false; return false
} }
if (customUrl) { if (customUrl) {
return false; return false
} }
if (!version || /latest|canary|action/i.test(version)) { if (!version || /latest|canary|action/i.test(version)) {
return false; return false
} }
return isFeatureAvailable(); return isFeatureAvailable()
} }
function getDownloadUrl(options: Input): string { function getDownloadUrl(options: Input): string {
const { customUrl } = options; const { customUrl } = options
if (customUrl) { if (customUrl) {
return customUrl; return customUrl
} }
const { version, os, arch, avx2, profile } = options; const { version, os, arch, avx2, profile } = options
const eversion = encodeURIComponent(version ?? "latest"); const eversion = encodeURIComponent(version ?? "latest")
const eos = encodeURIComponent(os ?? process.platform); const eos = encodeURIComponent(os ?? process.platform)
const earch = encodeURIComponent(arch ?? process.arch); const earch = encodeURIComponent(arch ?? process.arch)
const eavx2 = encodeURIComponent(avx2 ?? true); const eavx2 = encodeURIComponent(avx2 ?? true)
const eprofile = encodeURIComponent(profile ?? false); const eprofile = encodeURIComponent(profile ?? false)
const { href } = new URL( const { href } = new URL(
`${eversion}/${eos}/${earch}?avx2=${eavx2}&profile=${eprofile}`, `${eversion}/${eos}/${earch}?avx2=${eavx2}&profile=${eprofile}`,
"https://bun.sh/download/" "https://bun.sh/download/",
); )
return href; return href
} }
async function extractBun(path: string): Promise<string> { async function extractBun(path: string): Promise<string> {
for (const entry of readdirSync(path, { withFileTypes: true })) { for (const entry of readdirSync(path, { withFileTypes: true })) {
const { name } = entry; const { name } = entry
const entryPath = join(path, name); const entryPath = join(path, name)
if (entry.isFile()) { if (entry.isFile()) {
if (name === "bun" || name === "bun.exe") { if (name === "bun" || name === "bun.exe") {
return entryPath; return entryPath
} }
if (/^bun.*\.zip/.test(name)) { if (/^bun.*\.zip/.test(name)) {
const extractedPath = await extractZip(entryPath); const extractedPath = await extractZip(entryPath)
return extractBun(extractedPath); return extractBun(extractedPath)
} }
} }
if (/^bun/.test(name) && entry.isDirectory()) { if (/^bun/.test(name) && entry.isDirectory()) {
return extractBun(entryPath); return extractBun(entryPath)
} }
} }
throw new Error("Could not find executable: bun"); throw new Error("Could not find executable: bun")
} }
async function getRevision(exe: string): Promise<string | undefined> { async function getRevision(exe: string): Promise<string | undefined> {
const revision = await getExecOutput(exe, ["--revision"], { const revision = await getExecOutput(exe, ["--revision"], {
ignoreReturnCode: true, ignoreReturnCode: true,
}); })
if (revision.exitCode === 0 && /^\d+\.\d+\.\d+/.test(revision.stdout)) { if (revision.exitCode === 0 && /^\d+\.\d+\.\d+/.test(revision.stdout)) {
return revision.stdout.trim(); return revision.stdout.trim()
} }
const version = await getExecOutput(exe, ["--version"], { const version = await getExecOutput(exe, ["--version"], {
ignoreReturnCode: true, ignoreReturnCode: true,
}); })
if (version.exitCode === 0 && /^\d+\.\d+\.\d+/.test(version.stdout)) { if (version.exitCode === 0 && /^\d+\.\d+\.\d+/.test(version.stdout)) {
return version.stdout.trim(); return version.stdout.trim()
} }
return undefined; return undefined
} }

View File

@ -1,50 +1,50 @@
import { EOL } from "node:os"; import { EOL } from "node:os"
import { appendFileSync } from "node:fs"; import { appendFileSync } from "node:fs"
import { info } from "@actions/core"; import { info } from "@actions/core"
type BunfigOptions = { type BunfigOptions = {
registryUrl?: string; registryUrl?: string
scope?: string; scope?: string
}; }
export function createBunfig(options: BunfigOptions): string | null { export function createBunfig(options: BunfigOptions): string | null {
const { registryUrl, scope } = options; const { registryUrl, scope } = options
let url: URL | undefined; let url: URL | undefined
if (registryUrl) { if (registryUrl) {
try { try {
url = new URL(registryUrl); url = new URL(registryUrl)
} catch { } catch {
throw new Error(`Invalid registry-url: ${registryUrl}`); throw new Error(`Invalid registry-url: ${registryUrl}`)
} }
} }
let owner: string | undefined; let owner: string | undefined
if (scope) { if (scope) {
owner = scope.startsWith("@") owner = scope.startsWith("@")
? scope.toLocaleLowerCase() ? scope.toLocaleLowerCase()
: `@${scope.toLocaleLowerCase()}`; : `@${scope.toLocaleLowerCase()}`
} }
if (url && owner) { if (url && owner) {
return `[install.scopes]${EOL}'${owner}' = { token = "$BUN_AUTH_TOKEN", url = "${url}"}${EOL}`; return `[install.scopes]${EOL}'${owner}' = { token = "$BUN_AUTH_TOKEN", url = "${url}"}${EOL}`
} }
if (url && !owner) { if (url && !owner) {
return `[install]${EOL}registry = "${url}"${EOL}`; return `[install]${EOL}registry = "${url}"${EOL}`
} }
return null; return null
} }
export function writeBunfig(path: string, options: BunfigOptions): void { export function writeBunfig(path: string, options: BunfigOptions): void {
const bunfig = createBunfig(options); const bunfig = createBunfig(options)
if (!bunfig) { if (!bunfig) {
return; return
} }
info(`Writing bunfig.toml to '${path}'.`); info(`Writing bunfig.toml to '${path}'.`)
appendFileSync(path, bunfig, { appendFileSync(path, bunfig, {
encoding: "utf8", encoding: "utf8",
}); })
} }

View File

@ -1,18 +1,17 @@
import { saveCache } from "@actions/cache"; import { saveCache } from "@actions/cache"
import { getState, warning } from "@actions/core"; import { getState, warning } from "@actions/core"
import { CacheState } from "./action"; import { CacheState } from "./action"
import { createHash } from "node:crypto"; import { createHash } from "node:crypto"
;(async () => {
(async () => { const state: CacheState = JSON.parse(getState("cache"))
const state: CacheState = JSON.parse(getState("cache"));
if (state.cacheEnabled && !state.cacheHit) { if (state.cacheEnabled && !state.cacheHit) {
const cacheKey = createHash("sha1").update(state.url).digest("base64"); const cacheKey = createHash("sha1").update(state.url).digest("base64")
try { try {
await saveCache([state.bunPath], cacheKey); await saveCache([state.bunPath], cacheKey)
process.exit(0); process.exit(0)
} catch (error) { } catch (error) {
warning("Failed to save Bun to cache."); warning("Failed to save Bun to cache.")
} }
} }
})(); })()

View File

@ -1,10 +1,10 @@
import { tmpdir } from "node:os"; import { tmpdir } from "node:os"
import { getInput, setOutput, setFailed, getBooleanInput } from "@actions/core"; import { getInput, setOutput, setFailed, getBooleanInput } from "@actions/core"
import runAction from "./action.js"; import runAction from "./action.js"
import { readVersionFromFile } from "./utils.js"; import { readVersionFromFile } from "./utils.js"
if (!process.env.RUNNER_TEMP) { if (!process.env.RUNNER_TEMP) {
process.env.RUNNER_TEMP = tmpdir(); process.env.RUNNER_TEMP = tmpdir()
} }
runAction({ runAction({
@ -18,14 +18,14 @@ runAction({
noCache: getBooleanInput("no-cache") || false, noCache: getBooleanInput("no-cache") || false,
}) })
.then(({ version, revision, bunPath, url, cacheHit }) => { .then(({ version, revision, bunPath, url, cacheHit }) => {
setOutput("bun-version", version); setOutput("bun-version", version)
setOutput("bun-revision", revision); setOutput("bun-revision", revision)
setOutput("bun-path", bunPath); setOutput("bun-path", bunPath)
setOutput("bun-download-url", url); setOutput("bun-download-url", url)
setOutput("cache-hit", cacheHit); setOutput("cache-hit", cacheHit)
process.exit(0); process.exit(0)
}) })
.catch((error) => { .catch((error) => {
setFailed(error); setFailed(error)
process.exit(1); process.exit(1)
}); })

View File

@ -1,30 +1,30 @@
import { debug, warning } from "@actions/core"; import { debug, warning } from "@actions/core"
import { info } from "node:console"; import { info } from "node:console"
import { existsSync, readFileSync, renameSync } from "node:fs"; import { existsSync, readFileSync, renameSync } from "node:fs"
import { resolve, basename } from "node:path"; import { resolve, basename } from "node:path"
export function retry<T>( export function retry<T>(
fn: () => Promise<T>, fn: () => Promise<T>,
retries: number, retries: number,
timeout = 10000 timeout = 10000,
): Promise<T> { ): Promise<T> {
return fn().catch((err) => { return fn().catch((err) => {
if (retries <= 0) { if (retries <= 0) {
throw err; throw err
} }
return new Promise((resolve) => setTimeout(resolve, timeout)).then(() => return new Promise((resolve) => setTimeout(resolve, timeout)).then(() =>
retry(fn, retries - 1, timeout) retry(fn, retries - 1, timeout),
); )
}); })
} }
export function addExtension(path: string, ext: string): string { export function addExtension(path: string, ext: string): string {
if (!path.endsWith(ext)) { if (!path.endsWith(ext)) {
renameSync(path, path + ext); renameSync(path, path + ext)
return path + ext; return path + ext
} }
return path; return path
} }
const FILE_VERSION_READERS = { const FILE_VERSION_READERS = {
@ -34,45 +34,45 @@ const FILE_VERSION_READERS = {
content.match(/^bun\s*(?<version>.*?)$/m)?.groups?.version, content.match(/^bun\s*(?<version>.*?)$/m)?.groups?.version,
".bumrc": (content: string) => content, // https://github.com/owenizedd/bum ".bumrc": (content: string) => content, // https://github.com/owenizedd/bum
".bun-version": (content: string) => content, ".bun-version": (content: string) => content,
}; }
export function readVersionFromFile(file: string): string | undefined { export function readVersionFromFile(file: string): string | undefined {
const cwd = process.env.GITHUB_WORKSPACE; const cwd = process.env.GITHUB_WORKSPACE
if (!cwd) { if (!cwd) {
return; return
} }
if (!file) { if (!file) {
return; return
} }
debug(`Reading version from ${file}`); debug(`Reading version from ${file}`)
const path = resolve(cwd, file); const path = resolve(cwd, file)
const base = basename(file); const base = basename(file)
if (!existsSync(path)) { if (!existsSync(path)) {
warning(`File ${path} not found`); warning(`File ${path} not found`)
return; return
} }
const reader = FILE_VERSION_READERS[base] ?? (() => undefined); const reader = FILE_VERSION_READERS[base] ?? (() => undefined)
let output: string | undefined; let output: string | undefined
try { try {
output = reader(readFileSync(path, "utf8"))?.trim(); output = reader(readFileSync(path, "utf8"))?.trim()
if (!output) { if (!output) {
warning(`Failed to read version from ${file}`); warning(`Failed to read version from ${file}`)
return; return
} }
} catch (error) { } catch (error) {
const { message } = error as Error; const { message } = error as Error
warning(`Failed to read ${file}: ${message}`); warning(`Failed to read ${file}: ${message}`)
} finally { } finally {
if (output) { if (output) {
info(`Obtained version ${output} from ${file}`); info(`Obtained version ${output} from ${file}`)
return output; return output
} }
} }
} }