regen.mde 0.2.2 → 0.8.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 (56) hide show
  1. package/LICENSE +16 -16
  2. package/README.md +409 -295
  3. package/bin/build-corpus-editor.js +83 -81
  4. package/bin/build-corpus.js +41 -41
  5. package/bin/postinstall.js +259 -187
  6. package/bin/regen-mdeditor-install.js +27 -27
  7. package/bin/regen-mdeditor-uninstall.js +19 -19
  8. package/bin/validate-katex.js +93 -93
  9. package/desktop/BuildCorpusEditor/BuildCorpusBridge.cs +493 -270
  10. package/desktop/BuildCorpusEditor/BuildCorpusEditor.csproj +22 -22
  11. package/desktop/BuildCorpusEditor/EditorForm.cs +853 -540
  12. package/desktop/BuildCorpusEditor/Program.cs +85 -81
  13. package/desktop/BuildCorpusEditor/app.manifest +16 -16
  14. package/dist/release/regen-mde-0.8.0-win-x64.zip +0 -0
  15. package/dist/windows-editor/BuildCorpusEditor.dll +0 -0
  16. package/dist/windows-editor/BuildCorpusEditor.exe +0 -0
  17. package/dist/windows-editor/BuildCorpusEditor.pdb +0 -0
  18. package/dist/windows-editor/BuildCorpusEditor.runtimeconfig.json +1 -1
  19. package/dist/windows-editor/wwwroot/assets/index-C_VxJk4k.js +375 -0
  20. package/dist/windows-editor/wwwroot/assets/index-Wt9zSjIw.css +1 -0
  21. package/dist/windows-editor/wwwroot/index.html +22 -22
  22. package/editor-web/index.html +21 -21
  23. package/editor-web/src/main.jsx +1044 -399
  24. package/editor-web/src/styles.css +846 -602
  25. package/editor-web/vite.config.js +13 -13
  26. package/examples/build-corpus.config.example.json +21 -21
  27. package/installer/install-regen-mde.ps1 +214 -175
  28. package/installer/regen-mde.nsi +81 -81
  29. package/package.json +10 -6
  30. package/pyproject.toml +4 -3
  31. package/requirements.txt +5 -4
  32. package/scripts/build-windows-editor.ps1 +47 -47
  33. package/scripts/package-windows-editor.ps1 +90 -90
  34. package/scripts/release-dual.mjs +105 -0
  35. package/scripts/run-corpus.ps1 +28 -28
  36. package/scripts/run-editor-implementation-plane.ps1 +226 -203
  37. package/scripts/run-required-tests.ps1 +98 -98
  38. package/scripts/run-smoke.ps1 +28 -28
  39. package/src/build_corpus/__init__.py +1 -1
  40. package/src/build_corpus/docx_exporter.py +1055 -798
  41. package/src/build_corpus/equations.py +1345 -0
  42. package/src/build_corpus/exporter.py +1488 -1195
  43. package/src/build_corpus/frontmatter.py +302 -0
  44. package/src/build_corpus/ppt_exporter.py +543 -532
  45. package/src/build_corpus/templates/__init__.py +1 -1
  46. package/src/build_corpus/validate_assets.py +46 -46
  47. package/tools/audit_corpus.py +203 -203
  48. package/tools/collect_microsoft_word_templates.py +228 -228
  49. package/tools/collect_online_docx_corpus.py +272 -272
  50. package/tools/collect_online_pptx_corpus.py +252 -252
  51. package/tools/compare_pptx_inputs_outputs.py +87 -87
  52. package/tools/roundtrip_docx_corpus.py +171 -171
  53. package/dist/release/regen.mde-0.2.2-win-x64-setup.exe +0 -0
  54. package/dist/release/regen.mde-0.2.2-win-x64.zip +0 -0
  55. package/dist/windows-editor/wwwroot/assets/index-DjJ6xmhy.js +0 -326
  56. package/dist/windows-editor/wwwroot/assets/index-_dwMNNsm.css +0 -1
@@ -1,81 +1,83 @@
1
- #!/usr/bin/env node
2
- const path = require("node:path");
3
- const { spawn } = require("node:child_process");
4
- const fs = require("node:fs");
5
-
6
- const root = path.resolve(__dirname, "..");
7
- const callerCwd = process.cwd();
8
- const candidates = [
9
- path.join(root, "dist", "windows-editor", "BuildCorpusEditor.exe"),
10
- path.join(root, "desktop", "BuildCorpusEditor", "bin", "Release", "net8.0-windows", "win-x64", "BuildCorpusEditor.exe"),
11
- ];
12
- const exe = candidates.find((candidate) => fs.existsSync(candidate)) || candidates[0];
13
- const args = process.argv.slice(2);
14
-
15
- if (args.includes("--help") || args.includes("-h")) {
16
- console.log(`regen.mde
17
-
18
- Usage:
19
- regen.mde [document.md|document.docx] [options]
20
- regen.mdeditor [document.md|document.docx] [options]
21
- regen-mdeditor [document.md|document.docx] [options]
22
- build-corpus-editor [document.md|document.docx] [options]
23
-
24
- Options:
25
- --foreground, --visible Show the editor as an attached foreground process.
26
- --background Launch hidden/offscreen for smoke checks.
27
- --self-test Verify the editor bridge can open the document.
28
- --document-self-test Open, edit, save Markdown, export Word, and reconvert.
29
- --smoke-ui Run the hidden UI smoke test.
30
- --out <dir> Output directory for document self-test.
31
- --help, -h Show this help.
32
- `);
33
- process.exit(0);
34
- }
35
-
36
- const visible = args.includes("--foreground") || args.includes("--visible");
37
- const background = args.includes("--background") || args.includes("--smoke-ui");
38
- const launchArgs = normalizeLaunchArgs(args.filter((arg) => arg !== "--foreground" && arg !== "--visible"));
39
-
40
- const child = spawn(exe, launchArgs, {
41
- cwd: root,
42
- stdio: "inherit",
43
- windowsHide: background,
44
- detached: background && !visible,
45
- env: {
46
- ...process.env,
47
- BUILD_CORPUS_ROOT: root,
48
- },
49
- });
50
-
51
- child.on("error", (error) => {
52
- console.error(`Build Corpus Editor executable not found: ${exe}`);
53
- console.error("Build it with: npm run editor:windows");
54
- console.error(error.message);
55
- process.exit(1);
56
- });
57
-
58
- child.on("exit", (code) => process.exit(code ?? 0));
59
-
60
- function normalizeLaunchArgs(rawArgs) {
61
- const normalized = [];
62
- for (let index = 0; index < rawArgs.length; index += 1) {
63
- const arg = rawArgs[index];
64
- if (arg === "--out" && index < rawArgs.length - 1) {
65
- normalized.push(arg, resolveFromCaller(rawArgs[index + 1]));
66
- index += 1;
67
- continue;
68
- }
69
- if (index === 0 && !arg.startsWith("--")) {
70
- normalized.push(resolveFromCaller(arg));
71
- continue;
72
- }
73
- normalized.push(arg);
74
- }
75
- return normalized;
76
- }
77
-
78
- function resolveFromCaller(value) {
79
- if (!value || path.isAbsolute(value)) return value;
80
- return path.resolve(callerCwd, value);
81
- }
1
+ #!/usr/bin/env node
2
+ const path = require("node:path");
3
+ const { spawn } = require("node:child_process");
4
+ const fs = require("node:fs");
5
+
6
+ const root = path.resolve(__dirname, "..");
7
+ const callerCwd = process.cwd();
8
+ const candidates = [
9
+ path.join(root, "BuildCorpusEditor.exe"),
10
+ path.join(root, "dist", "windows-editor", "BuildCorpusEditor.exe"),
11
+ path.join(root, "desktop", "BuildCorpusEditor", "bin", "Release", "net8.0-windows", "win-x64", "BuildCorpusEditor.exe"),
12
+ ];
13
+ const exe = candidates.find((candidate) => fs.existsSync(candidate)) || candidates[0];
14
+ const args = process.argv.slice(2);
15
+
16
+ if (args.includes("--help") || args.includes("-h")) {
17
+ console.log(`regen-mde
18
+
19
+ Usage:
20
+ regen-mde [document.md|document.docx] [options]
21
+ mdeditor [document.md|document.docx] [options]
22
+ regen-mdeditor [document.md|document.docx] [options]
23
+ regen-mdeditor [document.md|document.docx] [options]
24
+ build-corpus-editor [document.md|document.docx] [options]
25
+
26
+ Options:
27
+ --foreground, --visible Show the editor as an attached foreground process.
28
+ --background Launch hidden/offscreen for smoke checks.
29
+ --self-test Verify the editor bridge can open the document.
30
+ --document-self-test Open, edit, save Markdown, export Word, and reconvert.
31
+ --smoke-ui Run the hidden UI smoke test.
32
+ --out <dir> Output directory for document self-test.
33
+ --help, -h Show this help.
34
+ `);
35
+ process.exit(0);
36
+ }
37
+
38
+ const visible = args.includes("--foreground") || args.includes("--visible");
39
+ const background = args.includes("--background") || args.includes("--smoke-ui");
40
+ const launchArgs = normalizeLaunchArgs(args.filter((arg) => arg !== "--foreground" && arg !== "--visible"));
41
+
42
+ const child = spawn(exe, launchArgs, {
43
+ cwd: root,
44
+ stdio: "inherit",
45
+ windowsHide: background,
46
+ detached: background && !visible,
47
+ env: {
48
+ ...process.env,
49
+ BUILD_CORPUS_ROOT: root,
50
+ },
51
+ });
52
+
53
+ child.on("error", (error) => {
54
+ console.error(`Build Corpus Editor executable not found: ${exe}`);
55
+ console.error("Build it with: npm run editor:windows");
56
+ console.error(error.message);
57
+ process.exit(1);
58
+ });
59
+
60
+ child.on("exit", (code) => process.exit(code ?? 0));
61
+
62
+ function normalizeLaunchArgs(rawArgs) {
63
+ const normalized = [];
64
+ for (let index = 0; index < rawArgs.length; index += 1) {
65
+ const arg = rawArgs[index];
66
+ if (arg === "--out" && index < rawArgs.length - 1) {
67
+ normalized.push(arg, resolveFromCaller(rawArgs[index + 1]));
68
+ index += 1;
69
+ continue;
70
+ }
71
+ if (index === 0 && !arg.startsWith("--")) {
72
+ normalized.push(resolveFromCaller(arg));
73
+ continue;
74
+ }
75
+ normalized.push(arg);
76
+ }
77
+ return normalized;
78
+ }
79
+
80
+ function resolveFromCaller(value) {
81
+ if (!value || path.isAbsolute(value)) return value;
82
+ return path.resolve(callerCwd, value);
83
+ }
@@ -1,41 +1,41 @@
1
- #!/usr/bin/env node
2
- const { spawnSync } = require("node:child_process");
3
- const path = require("node:path");
4
-
5
- const root = path.resolve(__dirname, "..");
6
- const candidates = process.platform === "win32" ? ["py", "python"] : ["python3", "python"];
7
- const env = { ...process.env };
8
- env.PYTHONPATH = env.PYTHONPATH ? `${path.join(root, "src")}${path.delimiter}${env.PYTHONPATH}` : path.join(root, "src");
9
- const args = process.argv.slice(2);
10
-
11
- if (args[0] === "editor") {
12
- const editor = path.join(root, "bin", "build-corpus-editor.js");
13
- const result = spawnSync(process.execPath, [editor, ...args.slice(1)], {
14
- stdio: "inherit",
15
- cwd: root,
16
- env: { ...env, BUILD_CORPUS_ROOT: root },
17
- });
18
- process.exit(result.status ?? 1);
19
- }
20
-
21
- if (process.platform === "win32" && args.includes("--uninstall-windows")) {
22
- const result = spawnSync(process.execPath, [path.join(root, "bin", "postinstall.js"), "--uninstall"], {
23
- stdio: "inherit",
24
- cwd: root,
25
- env,
26
- });
27
- process.exit(result.status ?? 1);
28
- }
29
-
30
- let result = null;
31
- for (const candidate of candidates) {
32
- const args = candidate === "py"
33
- ? ["-3", "-m", "build_corpus.exporter", ...process.argv.slice(2)]
34
- : ["-m", "build_corpus.exporter", ...process.argv.slice(2)];
35
- result = spawnSync(candidate, args, { stdio: "inherit", cwd: root, env });
36
- if (result.error && result.error.code === "ENOENT") continue;
37
- process.exit(result.status ?? 1);
38
- }
39
-
40
- console.error("Build Corpus requires Python 3.10+ on PATH.");
41
- process.exit(1);
1
+ #!/usr/bin/env node
2
+ const { spawnSync } = require("node:child_process");
3
+ const path = require("node:path");
4
+
5
+ const root = path.resolve(__dirname, "..");
6
+ const candidates = process.platform === "win32" ? ["py", "python"] : ["python3", "python"];
7
+ const env = { ...process.env };
8
+ env.PYTHONPATH = env.PYTHONPATH ? `${path.join(root, "src")}${path.delimiter}${env.PYTHONPATH}` : path.join(root, "src");
9
+ const args = process.argv.slice(2);
10
+
11
+ if (args[0] === "editor") {
12
+ const editor = path.join(root, "bin", "build-corpus-editor.js");
13
+ const result = spawnSync(process.execPath, [editor, ...args.slice(1)], {
14
+ stdio: "inherit",
15
+ cwd: root,
16
+ env: { ...env, BUILD_CORPUS_ROOT: root },
17
+ });
18
+ process.exit(result.status ?? 1);
19
+ }
20
+
21
+ if (process.platform === "win32" && args.includes("--uninstall-windows")) {
22
+ const result = spawnSync(process.execPath, [path.join(root, "bin", "postinstall.js"), "--uninstall"], {
23
+ stdio: "inherit",
24
+ cwd: root,
25
+ env,
26
+ });
27
+ process.exit(result.status ?? 1);
28
+ }
29
+
30
+ let result = null;
31
+ for (const candidate of candidates) {
32
+ const args = candidate === "py"
33
+ ? ["-3", "-m", "build_corpus.exporter", ...process.argv.slice(2)]
34
+ : ["-m", "build_corpus.exporter", ...process.argv.slice(2)];
35
+ result = spawnSync(candidate, args, { stdio: "inherit", cwd: root, env });
36
+ if (result.error && result.error.code === "ENOENT") continue;
37
+ process.exit(result.status ?? 1);
38
+ }
39
+
40
+ console.error("Build Corpus requires Python 3.10+ on PATH.");
41
+ process.exit(1);