Dax Raad 6 ore în urmă
părinte
comite
940f971ca0
1 a modificat fișierele cu 28 adăugiri și 66 ștergeri
  1. 28 66
      script/publish.ts

+ 28 - 66
script/publish.ts

@@ -6,6 +6,9 @@ import { fileURLToPath } from "url"
 
 console.log("=== publishing ===\n")
 
+const dir = fileURLToPath(new URL("..", import.meta.url))
+process.chdir(dir)
+
 const tag = `v${Script.version}`
 
 const pkgjsons = await Array.fromAsync(
@@ -14,64 +17,29 @@ const pkgjsons = await Array.fromAsync(
   }),
 ).then((arr) => arr.filter((x) => !x.includes("node_modules") && !x.includes("dist")))
 
-const extensionToml = fileURLToPath(new URL("../packages/extensions/zed/extension.toml", import.meta.url))
-const publishPackageJsons = ["packages/plugin/package.json", "packages/sdk/js/package.json"]
-
-async function hasChanges() {
-  return (await $`git diff --quiet && git diff --cached --quiet`.nothrow()).exitCode !== 0
-}
-
-async function hasPublishPackageJsonChanges() {
-  if ((await $`git diff --quiet -- ${publishPackageJsons}`.nothrow()).exitCode !== 0) return true
-  return (await $`git diff --cached --quiet -- ${publishPackageJsons}`.nothrow()).exitCode !== 0
-}
-
-async function logPublishPackageJsonChanges() {
-  await $`git status --short -- ${publishPackageJsons}`
-  await $`git diff -- ${publishPackageJsons}`
-  await $`git diff --cached -- ${publishPackageJsons}`
-}
-
-async function releaseTagExists() {
-  return (await $`git rev-parse -q --verify refs/tags/${tag}`.nothrow()).exitCode === 0
-}
-
-async function prepareReleaseFiles() {
-  for (const file of pkgjsons) {
-    let pkg = await Bun.file(file).text()
-    pkg = pkg.replaceAll(/"version": "[^"]+"/g, `"version": "${Script.version}"`)
-    console.log("updated:", file)
-    await Bun.file(file).write(pkg)
-  }
-
-  let toml = await Bun.file(extensionToml).text()
-  toml = toml.replace(/^version = "[^"]+"/m, `version = "${Script.version}"`)
-  toml = toml.replaceAll(/releases\/download\/v[^/]+\//g, `releases/download/v${Script.version}/`)
-  console.log("updated:", extensionToml)
-  await Bun.file(extensionToml).write(toml)
-
-  await $`bun install`
-  await $`./packages/sdk/js/script/build.ts`
-}
-
 if (Script.release && !Script.preview) {
   await $`git fetch origin --tags`
   await $`git switch --detach`
 }
 
-await prepareReleaseFiles()
-
-if (Script.release && !Script.preview) {
-  if (await releaseTagExists()) {
-    console.log(`release tag ${tag} already exists, skipping tag creation`)
-  } else {
-    await $`git commit -am "release: ${tag}"`
-    await $`git tag ${tag}`
-    await $`git push origin refs/tags/${tag} --no-verify`
-    await new Promise((resolve) => setTimeout(resolve, 5_000))
-  }
+for (const file of pkgjsons) {
+  let pkg = await Bun.file(file).text()
+  pkg = pkg.replaceAll(/"version": "[^"]+"/g, `"version": "${Script.version}"`)
+  console.log("updated:", file)
+  await Bun.file(file).write(pkg)
 }
 
+const extensionToml = fileURLToPath(new URL("../packages/extensions/zed/extension.toml", import.meta.url))
+let toml = await Bun.file(extensionToml).text()
+toml = toml.replace(/^version = "[^"]+"/m, `version = "${Script.version}"`)
+toml = toml.replaceAll(/releases\/download\/v[^/]+\//g, `releases/download/v${Script.version}/`)
+console.log("updated:", extensionToml)
+await Bun.file(extensionToml).write(toml)
+
+await $`bun install`
+await import(`../packages/sdk/js/script/build.ts`)
+process.chdir(dir)
+
 console.log("\n=== cli ===\n")
 await import(`../packages/opencode/script/publish.ts`)
 
@@ -87,25 +55,19 @@ if (Script.release) {
 }
 
 if (Script.release && !Script.preview) {
+  process.chdir(dir)
+  await $`git commit -am "release: ${tag}"`
+  const releaseCommit = (await $`git rev-parse HEAD`.text()).trim()
+  await $`git tag -d ${tag}`.nothrow()
+  await $`git tag ${tag}`
+  await $`git push origin refs/tags/${tag} --force-with-lease --no-verify`
+  await new Promise((resolve) => setTimeout(resolve, 5_000))
   await $`git fetch origin`
-  if (await hasPublishPackageJsonChanges()) {
-    console.error("publish scripts left package.json changes before syncing dev")
-    await logPublishPackageJsonChanges()
-    throw new Error("packages/plugin/package.json or packages/sdk/js/package.json changed during publish")
-  }
   await $`git checkout -B dev origin/dev`
-  await prepareReleaseFiles()
-  if (await hasChanges()) {
-    await $`git commit -am "sync release versions for v${Script.version}"`
-    await $`git push origin HEAD:dev --no-verify`
-  } else {
-    console.log(`dev already synced for ${tag}`)
-  }
+  await $`git cherry-pick ${releaseCommit}`
+  await $`git push origin HEAD:dev --no-verify`
 }
 
 if (Script.release) {
   await $`gh release edit ${tag} --draft=false --repo ${process.env.GH_REPO}`
 }
-
-const dir = fileURLToPath(new URL("..", import.meta.url))
-process.chdir(dir)