@open-press/cli 1.0.0 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (175) hide show
  1. package/README.md +11 -12
  2. package/dist/cli.js +298 -79
  3. package/package.json +9 -7
  4. package/template/core/AGENTS.md +0 -130
  5. package/template/core/CHANGELOG.md +0 -218
  6. package/template/core/README.md +0 -43
  7. package/template/core/engine/cli.mjs +0 -96
  8. package/template/core/engine/commands/_shared.mjs +0 -199
  9. package/template/core/engine/commands/deploy.mjs +0 -31
  10. package/template/core/engine/commands/dev.mjs +0 -49
  11. package/template/core/engine/commands/doctor.mjs +0 -229
  12. package/template/core/engine/commands/export.mjs +0 -8
  13. package/template/core/engine/commands/image.mjs +0 -29
  14. package/template/core/engine/commands/inspect.mjs +0 -35
  15. package/template/core/engine/commands/pdf.mjs +0 -26
  16. package/template/core/engine/commands/preview.mjs +0 -26
  17. package/template/core/engine/commands/render.mjs +0 -17
  18. package/template/core/engine/commands/replace.mjs +0 -41
  19. package/template/core/engine/commands/search.mjs +0 -33
  20. package/template/core/engine/commands/skills-sync.mjs +0 -71
  21. package/template/core/engine/commands/typecheck.mjs +0 -67
  22. package/template/core/engine/commands/upgrade.mjs +0 -159
  23. package/template/core/engine/commands/validate.mjs +0 -17
  24. package/template/core/engine/document-export.mjs +0 -15
  25. package/template/core/engine/output/chrome-pdf.d.mts +0 -34
  26. package/template/core/engine/output/chrome-pdf.mjs +0 -450
  27. package/template/core/engine/output/deploy-sync.mjs +0 -15
  28. package/template/core/engine/output/fonts.mjs +0 -62
  29. package/template/core/engine/output/katex-assets.mjs +0 -45
  30. package/template/core/engine/output/page-block.mjs +0 -30
  31. package/template/core/engine/output/pdf-media.mjs +0 -45
  32. package/template/core/engine/output/public-assets.mjs +0 -19
  33. package/template/core/engine/output/static-server.mjs +0 -571
  34. package/template/core/engine/react/caption-numbering.mjs +0 -73
  35. package/template/core/engine/react/comment-endpoint.d.mts +0 -11
  36. package/template/core/engine/react/comment-endpoint.mjs +0 -102
  37. package/template/core/engine/react/comment-marker.mjs +0 -374
  38. package/template/core/engine/react/document-entry.mjs +0 -331
  39. package/template/core/engine/react/document-export.mjs +0 -512
  40. package/template/core/engine/react/http-json.mjs +0 -24
  41. package/template/core/engine/react/mdx-compile.mjs +0 -629
  42. package/template/core/engine/react/measurement-css.mjs +0 -157
  43. package/template/core/engine/react/object-entities.mjs +0 -204
  44. package/template/core/engine/react/pagination/allocator.mjs +0 -167
  45. package/template/core/engine/react/pagination/regions.mjs +0 -81
  46. package/template/core/engine/react/pagination-constants.mjs +0 -3
  47. package/template/core/engine/react/pagination.mjs +0 -9
  48. package/template/core/engine/react/pipeline/allocate.mjs +0 -217
  49. package/template/core/engine/react/pipeline/final-render.mjs +0 -94
  50. package/template/core/engine/react/pipeline/frame-measurement.mjs +0 -306
  51. package/template/core/engine/react/pipeline/press-tree.mjs +0 -135
  52. package/template/core/engine/react/press-tree-inspection.mjs +0 -172
  53. package/template/core/engine/react/project-asset-endpoint.d.mts +0 -10
  54. package/template/core/engine/react/project-asset-endpoint.mjs +0 -361
  55. package/template/core/engine/react/section-css.mjs +0 -56
  56. package/template/core/engine/react/source-edit-endpoint.d.mts +0 -10
  57. package/template/core/engine/react/source-edit-endpoint.mjs +0 -75
  58. package/template/core/engine/react/sources/heading-numbering.mjs +0 -132
  59. package/template/core/engine/react/sources/mdx-resolver.mjs +0 -439
  60. package/template/core/engine/react/style-discovery.mjs +0 -160
  61. package/template/core/engine/runtime/config.d.mts +0 -48
  62. package/template/core/engine/runtime/config.mjs +0 -172
  63. package/template/core/engine/runtime/file-utils.mjs +0 -114
  64. package/template/core/engine/runtime/file-walk.mjs +0 -22
  65. package/template/core/engine/runtime/inspection.mjs +0 -328
  66. package/template/core/engine/runtime/issue-report.mjs +0 -44
  67. package/template/core/engine/runtime/page-geometry.mjs +0 -131
  68. package/template/core/engine/runtime/path-utils.mjs +0 -20
  69. package/template/core/engine/runtime/source-text-tools.d.mts +0 -102
  70. package/template/core/engine/runtime/source-text-tools.mjs +0 -832
  71. package/template/core/engine/runtime/source-workspace.mjs +0 -168
  72. package/template/core/engine/runtime/validation.mjs +0 -183
  73. package/template/core/index.html +0 -13
  74. package/template/core/openpress.config.mjs +0 -8
  75. package/template/core/package.json +0 -89
  76. package/template/core/src/main.tsx +0 -16
  77. package/template/core/src/openpress/app/OpenPressApp.tsx +0 -296
  78. package/template/core/src/openpress/app/OpenPressRuntime.tsx +0 -102
  79. package/template/core/src/openpress/app/WorkspaceGalleryPage.tsx +0 -219
  80. package/template/core/src/openpress/app/index.ts +0 -2
  81. package/template/core/src/openpress/core/Frame.tsx +0 -91
  82. package/template/core/src/openpress/core/FrameContext.tsx +0 -26
  83. package/template/core/src/openpress/core/MdxArea.tsx +0 -34
  84. package/template/core/src/openpress/core/Press.tsx +0 -55
  85. package/template/core/src/openpress/core/Workspace.tsx +0 -36
  86. package/template/core/src/openpress/core/cn.ts +0 -4
  87. package/template/core/src/openpress/core/index.tsx +0 -47
  88. package/template/core/src/openpress/core/primitives.tsx +0 -91
  89. package/template/core/src/openpress/core/types.ts +0 -236
  90. package/template/core/src/openpress/core/useSource.ts +0 -28
  91. package/template/core/src/openpress/document-model/anchorMapModel.ts +0 -27
  92. package/template/core/src/openpress/document-model/documentIndexes.ts +0 -329
  93. package/template/core/src/openpress/document-model/documentTypes.ts +0 -147
  94. package/template/core/src/openpress/document-model/index.ts +0 -7
  95. package/template/core/src/openpress/document-model/objectEntityModel.ts +0 -55
  96. package/template/core/src/openpress/document-model/projectIdentityModel.ts +0 -15
  97. package/template/core/src/openpress/document-model/reactDocumentMetadataModel.ts +0 -27
  98. package/template/core/src/openpress/document-model/workspaceManifestModel.ts +0 -57
  99. package/template/core/src/openpress/manuscript/index.tsx +0 -238
  100. package/template/core/src/openpress/mdx/index.ts +0 -96
  101. package/template/core/src/openpress/numbering/index.ts +0 -294
  102. package/template/core/src/openpress/reader/PageThumbnailsPanel.tsx +0 -168
  103. package/template/core/src/openpress/reader/PublicReaderPage.tsx +0 -267
  104. package/template/core/src/openpress/reader/ReaderNavigationPanel.tsx +0 -123
  105. package/template/core/src/openpress/reader/index.ts +0 -11
  106. package/template/core/src/openpress/reader/pageViewportScaleModel.ts +0 -73
  107. package/template/core/src/openpress/reader/readerPageRegistry.ts +0 -41
  108. package/template/core/src/openpress/reader/readerPageRoute.ts +0 -21
  109. package/template/core/src/openpress/reader/readerScroll.ts +0 -92
  110. package/template/core/src/openpress/reader/readerStateModel.ts +0 -15
  111. package/template/core/src/openpress/reader/readerTypes.ts +0 -4
  112. package/template/core/src/openpress/reader/usePageViewportScale.ts +0 -119
  113. package/template/core/src/openpress/reader/usePanelState.ts +0 -56
  114. package/template/core/src/openpress/reader/useReaderHashSync.ts +0 -61
  115. package/template/core/src/openpress/reader/useReaderKeyboardNav.ts +0 -48
  116. package/template/core/src/openpress/reader/useReaderRuntime.ts +0 -146
  117. package/template/core/src/openpress/reader/useReaderScrollAnchor.ts +0 -64
  118. package/template/core/src/openpress/shared/Panel.tsx +0 -77
  119. package/template/core/src/openpress/shared/frameScheduler.ts +0 -32
  120. package/template/core/src/openpress/shared/index.ts +0 -4
  121. package/template/core/src/openpress/shared/numberUtils.ts +0 -3
  122. package/template/core/src/openpress/shared/runtimeMode.ts +0 -11
  123. package/template/core/src/openpress/workbench/Workbench.tsx +0 -506
  124. package/template/core/src/openpress/workbench/actions/DeploymentControl.tsx +0 -157
  125. package/template/core/src/openpress/workbench/actions/ExportImageControl.tsx +0 -96
  126. package/template/core/src/openpress/workbench/actions/PageZoomControl.tsx +0 -182
  127. package/template/core/src/openpress/workbench/actions/SearchControl.tsx +0 -345
  128. package/template/core/src/openpress/workbench/actions/deploymentStatusModel.ts +0 -112
  129. package/template/core/src/openpress/workbench/actions/index.ts +0 -6
  130. package/template/core/src/openpress/workbench/actions/useDeploymentWorkbench.ts +0 -136
  131. package/template/core/src/openpress/workbench/dialog/WorkbenchDialog.tsx +0 -72
  132. package/template/core/src/openpress/workbench/dialog/index.ts +0 -1
  133. package/template/core/src/openpress/workbench/document/components/DocumentPanel.tsx +0 -127
  134. package/template/core/src/openpress/workbench/document/components/InlineSourceEditorLayer.tsx +0 -207
  135. package/template/core/src/openpress/workbench/document/components/ReaderStage.tsx +0 -9
  136. package/template/core/src/openpress/workbench/document/hooks/useDocumentWorkbenchModel.ts +0 -34
  137. package/template/core/src/openpress/workbench/document/hooks/useInlineDocumentEditor.ts +0 -525
  138. package/template/core/src/openpress/workbench/document/index.ts +0 -10
  139. package/template/core/src/openpress/workbench/index.ts +0 -2
  140. package/template/core/src/openpress/workbench/inspector/InlineInspectorLayer.tsx +0 -459
  141. package/template/core/src/openpress/workbench/inspector/index.ts +0 -5
  142. package/template/core/src/openpress/workbench/inspector/inlineCommentModel.ts +0 -125
  143. package/template/core/src/openpress/workbench/inspector/inspectorGeometryModel.ts +0 -160
  144. package/template/core/src/openpress/workbench/inspector/inspectorModel.ts +0 -408
  145. package/template/core/src/openpress/workbench/inspector/useInspectorComments.ts +0 -254
  146. package/template/core/src/openpress/workbench/mentions/MentionSuggestionList.tsx +0 -41
  147. package/template/core/src/openpress/workbench/mentions/index.ts +0 -2
  148. package/template/core/src/openpress/workbench/mentions/useComposerMentions.ts +0 -185
  149. package/template/core/src/openpress/workbench/panels/Panel.tsx +0 -1
  150. package/template/core/src/openpress/workbench/panels/PendingCommentsPanel.tsx +0 -80
  151. package/template/core/src/openpress/workbench/panels/WorkbenchControlPanel.tsx +0 -29
  152. package/template/core/src/openpress/workbench/panels/index.ts +0 -3
  153. package/template/core/src/openpress/workbench/project/ProjectEntryPanel.tsx +0 -525
  154. package/template/core/src/openpress/workbench/project/ProjectPreviewDialog.tsx +0 -35
  155. package/template/core/src/openpress/workbench/project/index.ts +0 -2
  156. package/template/core/src/openpress/workbench/project/projectPreviewTypes.ts +0 -11
  157. package/template/core/src/openpress/workbench/project/projectSourceModel.ts +0 -24
  158. package/template/core/src/openpress/workbench/shell/WorkbenchShell.tsx +0 -167
  159. package/template/core/src/openpress/workbench/shell/index.ts +0 -1
  160. package/template/core/src/openpress/workbench/workbenchFormatters.ts +0 -120
  161. package/template/core/src/openpress/workbench/workbenchTypes.ts +0 -35
  162. package/template/core/src/styles/openpress/app-shell.css +0 -251
  163. package/template/core/src/styles/openpress/media-workspace.css +0 -230
  164. package/template/core/src/styles/openpress/print-route.css +0 -184
  165. package/template/core/src/styles/openpress/project-preview-panel.css +0 -924
  166. package/template/core/src/styles/openpress/public-viewer.css +0 -688
  167. package/template/core/src/styles/openpress/reader-runtime.css +0 -989
  168. package/template/core/src/styles/openpress/responsive.css +0 -245
  169. package/template/core/src/styles/openpress/workbench-panels.css +0 -707
  170. package/template/core/src/styles/openpress/workbench.css +0 -1255
  171. package/template/core/src/styles/openpress/workspace-gallery.css +0 -300
  172. package/template/core/src/styles/openpress.css +0 -15
  173. package/template/core/src/vite-env.d.ts +0 -9
  174. package/template/core/tsconfig.json +0 -40
  175. package/template/core/vite.config.ts +0 -584
@@ -1,41 +0,0 @@
1
- import { replaceSourceText } from "../runtime/source-text-tools.mjs";
2
-
3
- export async function run({ config, options }) {
4
- const args = replaceArgsFromOptions(options);
5
- if (!args) {
6
- console.error("Usage: node engine/cli.mjs replace [path] <from> <to> [--json] [--apply] [--scope content|all] [--include-code] [--case-sensitive]");
7
- return 2;
8
- }
9
-
10
- const report = await replaceSourceText({
11
- config,
12
- from: args.from,
13
- to: args.to,
14
- scope: options.scope ?? "content",
15
- caseSensitive: options.caseSensitive === true,
16
- includeCode: options.includeCode === true,
17
- apply: options.apply === true,
18
- });
19
-
20
- if (options.json) {
21
- console.log(JSON.stringify(report, null, 2));
22
- return 0;
23
- }
24
-
25
- console.log(`OpenPress replace ${report.applied ? "applied" : "preview"}: "${args.from}" -> "${args.to}" (${report.matchCount} matches in ${report.fileCount} files)`);
26
- if (!report.applied) console.log("No files written. Re-run with --apply to update sources.");
27
- for (const change of report.changes) {
28
- console.log(`${change.path}: ${change.replacements.length} replacements`);
29
- }
30
- return 0;
31
- }
32
-
33
- function replaceArgsFromOptions(options) {
34
- const positional = options.positional ?? [];
35
- const args = positional.length >= 3 ? positional.slice(1) : positional;
36
- if (args.length < 2) return null;
37
- return {
38
- from: args[0],
39
- to: args[1],
40
- };
41
- }
@@ -1,33 +0,0 @@
1
- import { searchSourceText } from "../runtime/source-text-tools.mjs";
2
-
3
- export async function run({ config, options }) {
4
- const query = searchQueryFromOptions(options);
5
- if (!query) {
6
- console.error("Usage: node engine/cli.mjs search [path] <query> [--json] [--scope content|all] [--case-sensitive]");
7
- return 2;
8
- }
9
-
10
- const report = await searchSourceText({
11
- config,
12
- query,
13
- scope: options.scope ?? "content",
14
- caseSensitive: options.caseSensitive === true,
15
- });
16
-
17
- if (options.json) {
18
- console.log(JSON.stringify(report, null, 2));
19
- return 0;
20
- }
21
-
22
- console.log(`OpenPress search: "${query}" (${report.matchCount} matches)`);
23
- for (const match of report.matches) {
24
- console.log(`${match.id} ${match.path}:${match.line}:${match.column} ${match.preview}`);
25
- }
26
- return 0;
27
- }
28
-
29
- function searchQueryFromOptions(options) {
30
- const positional = options.positional ?? [];
31
- if (positional.length > 1) return positional.slice(1).join(" ");
32
- return positional[0] ?? "";
33
- }
@@ -1,71 +0,0 @@
1
- import path from "node:path";
2
- import { existsSync } from "node:fs";
3
- import { readFile } from "node:fs/promises";
4
- import { runCommand } from "./_shared.mjs";
5
-
6
- const DEFAULT_SOURCE = "quan0715/open-press";
7
-
8
- // Refresh installed agent skills against the workspace's lock file.
9
- // Behavior:
10
- // - If skills-lock.json exists, run `npx skills upgrade` (refreshes all
11
- // currently-installed sources to their latest published versions).
12
- // - If skills-lock.json is missing, install the OpenPress framework
13
- // skill bundle (and any user-supplied --source) as a first-time setup.
14
- // - If a --source flag is passed, also add that source on top of any
15
- // existing installations.
16
- //
17
- // Always exits 0 unless the underlying `skills` tool fails.
18
- export async function run({ root, options }) {
19
- const lockPath = path.join(root, "skills-lock.json");
20
- const lockExists = existsSync(lockPath);
21
- const extraSource = options?.source;
22
-
23
- if (options?.dryRun) {
24
- if (lockExists) {
25
- console.log("Command: npx -y skills@latest upgrade");
26
- } else {
27
- console.log(`Command: npx -y skills@latest add ${DEFAULT_SOURCE}`);
28
- }
29
- if (extraSource) {
30
- console.log(`Command: npx -y skills@latest add ${extraSource}`);
31
- }
32
- return 0;
33
- }
34
-
35
- if (lockExists) {
36
- const sources = await readLockSources(lockPath);
37
- if (sources.length === 0) {
38
- console.log("skills-lock.json has no sources; installing framework default…");
39
- const code = await runCommand("npx", ["-y", "skills@latest", "add", DEFAULT_SOURCE], root);
40
- if (code !== 0) return code;
41
- } else {
42
- console.log(`Refreshing ${sources.length} installed source(s)…`);
43
- for (const src of sources) console.log(` ${src}`);
44
- const code = await runCommand("npx", ["-y", "skills@latest", "upgrade"], root);
45
- if (code !== 0) return code;
46
- }
47
- } else {
48
- console.log(`No skills-lock.json; installing framework default: ${DEFAULT_SOURCE}`);
49
- const code = await runCommand("npx", ["-y", "skills@latest", "add", DEFAULT_SOURCE], root);
50
- if (code !== 0) return code;
51
- }
52
-
53
- if (extraSource) {
54
- console.log(`Adding extra source: ${extraSource}`);
55
- const code = await runCommand("npx", ["-y", "skills@latest", "add", extraSource], root);
56
- if (code !== 0) return code;
57
- }
58
-
59
- console.log("✓ Skills synced");
60
- return 0;
61
- }
62
-
63
- async function readLockSources(lockPath) {
64
- try {
65
- const lock = JSON.parse(await readFile(lockPath, "utf8"));
66
- const sources = Array.isArray(lock?.sources) ? lock.sources : [];
67
- return sources.map((s) => s?.source).filter((s) => typeof s === "string");
68
- } catch {
69
- return [];
70
- }
71
- }
@@ -1,67 +0,0 @@
1
- import fs from "node:fs";
2
- import path from "node:path";
3
- import { createRequire } from "node:module";
4
- import { runCommand } from "./_shared.mjs";
5
-
6
- // Run typecheck via the locally installed typescript. The previous
7
- // implementation used `npx tsc`; npm 11 + Node 24 (our CI / release
8
- // pin) changed npx's bin lookup so it no longer walks pnpm's nested
9
- // `.bin/` symlink farm and falls back to fetching the legacy
10
- // `tsc@2.0.4` shim, which crashes.
11
- //
12
- // Resolution order:
13
- // 1. `node <resolved tsc>` via require.resolve(typescript/package.json)
14
- // — works with npm-hoisted layouts and most pnpm installs.
15
- // 2. Walk up node_modules/.bin/tsc — covers downstream npm/yarn.
16
- // 3. Fall back to `pnpm exec tsc` — pnpm knows its own symlink farm
17
- // even when bare require.resolve doesn't, which is what CI hits.
18
- export async function run({ root }) {
19
- const absoluteRoot = path.resolve(root);
20
-
21
- const tscBin = resolveTscBin(absoluteRoot);
22
- if (tscBin) {
23
- return runCommand("node", [tscBin, "--noEmit", "-p", "tsconfig.json"], absoluteRoot);
24
- }
25
-
26
- if (hasCommand("pnpm")) {
27
- return runCommand("pnpm", ["exec", "tsc", "--noEmit", "-p", "tsconfig.json"], absoluteRoot);
28
- }
29
-
30
- console.error("[openpress] typescript is not installed in this workspace.");
31
- console.error("Add it with: npm install --save-dev typescript");
32
- return 1;
33
- }
34
-
35
- function resolveTscBin(absoluteRoot) {
36
- try {
37
- const require = createRequire(path.join(absoluteRoot, "package.json"));
38
- const pkgPath = require.resolve("typescript/package.json");
39
- return path.join(path.dirname(pkgPath), "bin", "tsc");
40
- } catch {
41
- // fall through to .bin probe
42
- }
43
-
44
- let dir = absoluteRoot;
45
- while (true) {
46
- const candidate = path.join(dir, "node_modules", ".bin", "tsc");
47
- if (fs.existsSync(candidate)) return candidate;
48
- const parent = path.dirname(dir);
49
- if (parent === dir) return null;
50
- dir = parent;
51
- }
52
- }
53
-
54
- function hasCommand(name) {
55
- const PATH = process.env.PATH ?? "";
56
- const sep = process.platform === "win32" ? ";" : ":";
57
- const exts = process.platform === "win32"
58
- ? (process.env.PATHEXT ?? ".EXE;.CMD;.BAT").split(";")
59
- : [""];
60
- for (const dir of PATH.split(sep)) {
61
- if (!dir) continue;
62
- for (const ext of exts) {
63
- if (fs.existsSync(path.join(dir, name + ext))) return true;
64
- }
65
- }
66
- return false;
67
- }
@@ -1,159 +0,0 @@
1
- import { existsSync } from "node:fs";
2
- import { mkdir, readFile, writeFile } from "node:fs/promises";
3
- import path from "node:path";
4
- import { diagnose } from "./doctor.mjs";
5
- import { runCommand } from "./_shared.mjs";
6
-
7
- // Migration notes live in the framework repo, not in scaffolded workspaces.
8
- // `npx open-press upgrade` fetches the notes for each pending version and
9
- // caches them under `.openpress/migrations/` so agents can read locally.
10
- const MIGRATION_REMOTE_BASE = "https://raw.githubusercontent.com/quan0715/open-press/main/docs/migrations";
11
- const MIGRATION_CACHE_DIR = path.join(".openpress", "migrations");
12
-
13
- export async function run({ root, options }) {
14
- const dryRun = Boolean(options?.dryRun);
15
- const skipSkills = Boolean(options?.noSkills);
16
- const skipDeps = Boolean(options?.noDeps);
17
- const json = Boolean(options?.json);
18
-
19
- // 1. Fresh diagnose (force re-check, ignore cache).
20
- const before = await diagnose(root, { noCache: true });
21
-
22
- if (!before.stale) {
23
- const message = "open-press is already up to date.";
24
- if (json) {
25
- process.stdout.write(JSON.stringify({ status: "noop", before }, null, 2) + "\n");
26
- } else {
27
- process.stdout.write(`✓ ${message}\n`);
28
- }
29
- return 0;
30
- }
31
-
32
- if (!json) {
33
- process.stdout.write("○ open-press upgrade\n\n");
34
- if (before.coreUpdateAvailable) {
35
- process.stdout.write(
36
- ` @open-press/core: ${before.coreVersion} → ${before.coreLatest}\n`,
37
- );
38
- }
39
- if (before.pendingMigrations.length > 0) {
40
- process.stdout.write(` migration notes: ${before.pendingMigrations.join(", ")}\n`);
41
- }
42
- process.stdout.write("\n");
43
- }
44
-
45
- if (dryRun) {
46
- if (!json) {
47
- process.stdout.write("dry run — nothing changed. The agent should:\n");
48
- process.stdout.write(" 1. read each docs/migrations/<version>.md for document-level changes\n");
49
- process.stdout.write(" 2. apply edits to press/ where needed\n");
50
- process.stdout.write(" 3. re-run: npx open-press upgrade (without --dry-run)\n");
51
- } else {
52
- process.stdout.write(JSON.stringify({ status: "dry-run", before }, null, 2) + "\n");
53
- }
54
- return 0;
55
- }
56
-
57
- // 2. Refresh framework dep (only when workspace declares @open-press/core).
58
- if (!skipDeps && (await hasCoreDep(root))) {
59
- if (!json) process.stdout.write("▸ updating @open-press/core via npm…\n");
60
- const code = runCommand("npm", ["update", "@open-press/core"], root);
61
- if (code !== 0) {
62
- if (!json) process.stdout.write(" ⚠ npm update returned non-zero; continuing\n");
63
- }
64
- }
65
-
66
- // 3. Refresh skills (npx skills upgrade respects skills-lock.json).
67
- if (!skipSkills) {
68
- if (!json) process.stdout.write("▸ refreshing skills via npx skills upgrade…\n");
69
- runCommand("npx", ["-y", "skills@latest", "upgrade"], root);
70
- }
71
-
72
- // 4. Surface migration notes for the agent to read.
73
- const migrationContents = await loadMigrations(root, before.pendingMigrations);
74
-
75
- // 5. Re-diagnose to confirm the move.
76
- const after = await diagnose(root, { noCache: true });
77
-
78
- if (json) {
79
- process.stdout.write(
80
- JSON.stringify(
81
- { status: "applied", before, after, migrationContents: migrationContents.map((m) => m.path) },
82
- null,
83
- 2,
84
- ) + "\n",
85
- );
86
- return 0;
87
- }
88
-
89
- process.stdout.write("\n✓ upgrade applied. Now read these migration notes:\n\n");
90
- if (migrationContents.length === 0) {
91
- process.stdout.write(" (no migration docs in this version range)\n\n");
92
- } else {
93
- for (const m of migrationContents) {
94
- if (m.path) {
95
- process.stdout.write(` ─ ${m.path}${m.fetched ? " (fetched from github)" : ""}\n`);
96
- } else {
97
- process.stdout.write(` ─ ${m.version}.md (not found locally or on github — check the repo manually)\n`);
98
- }
99
- }
100
- process.stdout.write(
101
- "\nAgent: open each file, identify document-level changes, grep press/ for affected patterns, propose edits before applying.\n",
102
- );
103
- }
104
-
105
- process.stdout.write("\nVerify with:\n npm run build\n\n");
106
- return 0;
107
- }
108
-
109
- async function hasCoreDep(root) {
110
- try {
111
- const pkg = JSON.parse(await readFile(path.join(root, "package.json"), "utf8"));
112
- return Boolean(pkg.dependencies?.["@open-press/core"] || pkg.devDependencies?.["@open-press/core"]);
113
- } catch {
114
- return false;
115
- }
116
- }
117
-
118
- async function loadMigrations(root, versions) {
119
- const results = [];
120
- const cacheDir = path.join(root, MIGRATION_CACHE_DIR);
121
- await mkdir(cacheDir, { recursive: true });
122
-
123
- for (const v of versions) {
124
- // Framework repo has docs/migrations/ at root — prefer local if present
125
- // (covers the open-press framework repo itself acting as a workspace).
126
- const localDocsPath = path.join(root, "docs", "migrations", `${v}.md`);
127
- if (existsSync(localDocsPath)) {
128
- results.push({ version: v, path: path.relative(root, localDocsPath), fetched: false });
129
- continue;
130
- }
131
-
132
- // Otherwise fetch from GitHub raw and cache to .openpress/migrations/.
133
- const cachedPath = path.join(cacheDir, `${v}.md`);
134
- if (existsSync(cachedPath)) {
135
- results.push({ version: v, path: path.relative(root, cachedPath), fetched: false });
136
- continue;
137
- }
138
-
139
- const body = await fetchMigration(v);
140
- if (body) {
141
- await writeFile(cachedPath, body, "utf8");
142
- results.push({ version: v, path: path.relative(root, cachedPath), fetched: true });
143
- } else {
144
- results.push({ version: v, path: null, fetched: false });
145
- }
146
- }
147
- return results;
148
- }
149
-
150
- async function fetchMigration(version) {
151
- const url = `${MIGRATION_REMOTE_BASE}/${version}.md`;
152
- try {
153
- const res = await fetch(url, { headers: { Accept: "text/plain" } });
154
- if (!res.ok) return null;
155
- return await res.text();
156
- } catch {
157
- return null;
158
- }
159
- }
@@ -1,17 +0,0 @@
1
- import { validateWorkspace } from "../runtime/validation.mjs";
2
- import { exitCodeForIssueReport } from "../runtime/issue-report.mjs";
3
-
4
- export async function run({ root, options }) {
5
- const report = await validateWorkspace(root);
6
- if (options.json) {
7
- console.log(JSON.stringify(report, null, 2));
8
- return exitCodeForIssueReport(report);
9
- }
10
- if (report.ok) {
11
- console.log("OpenPress validation OK");
12
- console.log(`Checked: ${report.checked.join(", ")}`);
13
- return 0;
14
- }
15
- console.log(report.format());
16
- return 1;
17
- }
@@ -1,15 +0,0 @@
1
- import path from "node:path";
2
- import { fileURLToPath } from "node:url";
3
- import { exportReactDocument } from "./react/document-export.mjs";
4
-
5
- const SELF_DIR = path.dirname(fileURLToPath(import.meta.url));
6
- const ROOT = path.resolve(SELF_DIR, "..");
7
-
8
- export async function exportDocument(root = ROOT) {
9
- const reactResult = await exportReactDocument(root);
10
- if (reactResult) return reactResult;
11
-
12
- throw new Error(
13
- "React/MDX document entry not found. Expected press/index.tsx with a Press default export before exporting.",
14
- );
15
- }
@@ -1,34 +0,0 @@
1
- import type { ChildProcess } from "node:child_process";
2
-
3
- export interface ChromeDevToolsClient {
4
- send(method: string, params?: Record<string, unknown>): Promise<any>;
5
- close(): void;
6
- }
7
-
8
- export interface PrintUrlToPdfOptions {
9
- root: string;
10
- url: string;
11
- outPath: string;
12
- chrome?: string;
13
- waitForReady?: (client: ChromeDevToolsClient) => Promise<unknown>;
14
- printOptions?: Record<string, unknown>;
15
- debuggingPortBase?: number;
16
- debuggingPortRange?: number;
17
- profilePrefix?: string;
18
- }
19
-
20
- export interface EvaluateUrlWithChromeOptions {
21
- root: string;
22
- url: string;
23
- chrome?: string;
24
- evaluate: (client: ChromeDevToolsClient) => Promise<unknown>;
25
- emulatedMedia?: "screen" | "print" | "none";
26
- debuggingPortBase?: number;
27
- debuggingPortRange?: number;
28
- profilePrefix?: string;
29
- }
30
-
31
- export function printUrlToPdf(options: PrintUrlToPdfOptions): Promise<unknown>;
32
- export function evaluateUrlWithChrome(options: EvaluateUrlWithChromeOptions): Promise<unknown>;
33
- export function waitForPrintReady(client: ChromeDevToolsClient): Promise<number>;
34
- export function stopChildProcess(child: ChildProcess): Promise<void>;