mirror of
https://fastgit.cc/https://github.com/anomalyco/opencode
synced 2026-04-20 21:00:29 +08:00
refactor(release): polish Effect publish scripts
Use Effect.ensuring to restore temporary package manifests on failure and tidy the opencode packager with a small parallel hash helper so the stacked Effect rewrite reads cleaner without changing behavior.
This commit is contained in:
@@ -14,6 +14,9 @@ const published = (name: string, version: string) =>
|
||||
Effect.map((result) => result.exitCode === 0),
|
||||
)
|
||||
|
||||
const sha256 = (path: string) =>
|
||||
Effect.promise(() => $`sha256sum ${path} | cut -d' ' -f1`.text()).pipe(Effect.map((text) => text.trim()))
|
||||
|
||||
const publishPackage = (dir: string, name: string, version: string) =>
|
||||
Effect.gen(function* () {
|
||||
if (yield* published(name, version)) {
|
||||
@@ -92,18 +95,12 @@ const program = Effect.gen(function* () {
|
||||
|
||||
if (Script.preview) return
|
||||
|
||||
const arm64Sha = (yield* Effect.promise(() =>
|
||||
$`sha256sum ./dist/opencode-linux-arm64.tar.gz | cut -d' ' -f1`.text(),
|
||||
)).trim()
|
||||
const x64Sha = (yield* Effect.promise(() =>
|
||||
$`sha256sum ./dist/opencode-linux-x64.tar.gz | cut -d' ' -f1`.text(),
|
||||
)).trim()
|
||||
const macX64Sha = (yield* Effect.promise(() =>
|
||||
$`sha256sum ./dist/opencode-darwin-x64.zip | cut -d' ' -f1`.text(),
|
||||
)).trim()
|
||||
const macArm64Sha = (yield* Effect.promise(() =>
|
||||
$`sha256sum ./dist/opencode-darwin-arm64.zip | cut -d' ' -f1`.text(),
|
||||
)).trim()
|
||||
const [arm64Sha, x64Sha, macX64Sha, macArm64Sha] = yield* Effect.all([
|
||||
sha256("./dist/opencode-linux-arm64.tar.gz"),
|
||||
sha256("./dist/opencode-linux-x64.tar.gz"),
|
||||
sha256("./dist/opencode-darwin-x64.zip"),
|
||||
sha256("./dist/opencode-darwin-arm64.zip"),
|
||||
])
|
||||
const [pkgver, subver = ""] = Script.version.split(/(-.*)/, 2)
|
||||
|
||||
const binaryPkgbuild = [
|
||||
|
||||
@@ -14,15 +14,47 @@ type PackageJson = {
|
||||
exports: Record<string, string>
|
||||
}
|
||||
|
||||
const packageJson = (value: unknown) => {
|
||||
if (
|
||||
typeof value === "object" &&
|
||||
value !== null &&
|
||||
"name" in value &&
|
||||
typeof value.name === "string" &&
|
||||
"version" in value &&
|
||||
typeof value.version === "string" &&
|
||||
"exports" in value &&
|
||||
typeof value.exports === "object" &&
|
||||
value.exports !== null
|
||||
) {
|
||||
return {
|
||||
name: value.name,
|
||||
version: value.version,
|
||||
exports: Object.fromEntries(
|
||||
Object.entries(value.exports).filter((entry): entry is [string, string] => typeof entry[1] === "string"),
|
||||
),
|
||||
}
|
||||
}
|
||||
throw new Error("invalid plugin package manifest")
|
||||
}
|
||||
|
||||
const published = (name: string, version: string) =>
|
||||
Effect.promise(() => $`npm view ${name}@${version} version`.nothrow()).pipe(
|
||||
Effect.map((result) => result.exitCode === 0),
|
||||
)
|
||||
|
||||
const withPackageJson = (
|
||||
pkg: PackageJson,
|
||||
next: { name: string; version: string; exports: Record<string, { import: string; types: string }> },
|
||||
) =>
|
||||
Effect.promise(() => Bun.write("package.json", JSON.stringify(next, null, 2))).pipe(
|
||||
Effect.zipRight(Effect.promise(() => $`bun pm pack && npm publish *.tgz --tag ${Script.channel} --access public`)),
|
||||
Effect.ensuring(Effect.promise(() => Bun.write("package.json", JSON.stringify(pkg, null, 2)))),
|
||||
)
|
||||
|
||||
const program = Effect.gen(function* () {
|
||||
yield* Effect.promise(() => $`bun tsc`)
|
||||
|
||||
const pkg = (yield* Effect.promise(() => import("../package.json").then((m) => m.default))) as PackageJson
|
||||
const pkg = packageJson(yield* Effect.promise(() => import("../package.json").then((m) => m.default)))
|
||||
if (yield* published(pkg.name, pkg.version)) {
|
||||
console.log(`already published ${pkg.name}@${pkg.version}`)
|
||||
return
|
||||
@@ -38,9 +70,7 @@ const program = Effect.gen(function* () {
|
||||
),
|
||||
}
|
||||
|
||||
yield* Effect.promise(() => Bun.write("package.json", JSON.stringify(next, null, 2)))
|
||||
yield* Effect.promise(() => $`bun pm pack && npm publish *.tgz --tag ${Script.channel} --access public`)
|
||||
yield* Effect.promise(() => Bun.write("package.json", JSON.stringify(pkg, null, 2)))
|
||||
yield* withPackageJson(pkg, next)
|
||||
})
|
||||
|
||||
await Effect.runPromise(program)
|
||||
|
||||
@@ -34,6 +34,13 @@ const published = (name: string, version: string) =>
|
||||
Effect.map((result) => result.exitCode === 0),
|
||||
)
|
||||
|
||||
const withPackageJson = (pkg: ReturnType<typeof packageJson>, next: ReturnType<typeof packageJson>) =>
|
||||
Effect.promise(() => Bun.write("package.json", JSON.stringify(next, null, 2))).pipe(
|
||||
Effect.zipRight(Effect.promise(() => $`bun pm pack`)),
|
||||
Effect.zipRight(Effect.promise(() => $`npm publish *.tgz --tag ${Script.channel} --access public`)),
|
||||
Effect.ensuring(Effect.promise(() => Bun.write("package.json", JSON.stringify(pkg, null, 2)))),
|
||||
)
|
||||
|
||||
function transformExports(exports: Record<string, unknown>) {
|
||||
return Object.fromEntries(
|
||||
Object.entries(exports).map(([key, value]) => {
|
||||
@@ -59,10 +66,7 @@ const program = Effect.gen(function* () {
|
||||
exports: transformExports(pkg.exports),
|
||||
}
|
||||
|
||||
yield* Effect.promise(() => Bun.write("package.json", JSON.stringify(next, null, 2)))
|
||||
yield* Effect.promise(() => $`bun pm pack`)
|
||||
yield* Effect.promise(() => $`npm publish *.tgz --tag ${Script.channel} --access public`)
|
||||
yield* Effect.promise(() => Bun.write("package.json", JSON.stringify(pkg, null, 2)))
|
||||
yield* withPackageJson(pkg, next)
|
||||
})
|
||||
|
||||
await Effect.runPromise(program)
|
||||
|
||||
Reference in New Issue
Block a user