@ontrails/trails 1.0.0-beta.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 (83) hide show
  1. package/.turbo/turbo-build.log +1 -0
  2. package/.turbo/turbo-lint.log +3 -0
  3. package/.turbo/turbo-typecheck.log +1 -0
  4. package/CHANGELOG.md +12 -0
  5. package/__tests__/examples.test.ts +6 -0
  6. package/bin/trails.ts +3 -0
  7. package/dist/bin/trails.d.ts +3 -0
  8. package/dist/bin/trails.d.ts.map +1 -0
  9. package/dist/bin/trails.js +4 -0
  10. package/dist/bin/trails.js.map +1 -0
  11. package/dist/src/app.d.ts +2 -0
  12. package/dist/src/app.d.ts.map +1 -0
  13. package/dist/src/app.js +11 -0
  14. package/dist/src/app.js.map +1 -0
  15. package/dist/src/clack.d.ts +9 -0
  16. package/dist/src/clack.d.ts.map +1 -0
  17. package/dist/src/clack.js +62 -0
  18. package/dist/src/clack.js.map +1 -0
  19. package/dist/src/cli.d.ts +2 -0
  20. package/dist/src/cli.d.ts.map +1 -0
  21. package/dist/src/cli.js +13 -0
  22. package/dist/src/cli.js.map +1 -0
  23. package/dist/src/trails/add-surface.d.ts +13 -0
  24. package/dist/src/trails/add-surface.d.ts.map +1 -0
  25. package/dist/src/trails/add-surface.js +88 -0
  26. package/dist/src/trails/add-surface.js.map +1 -0
  27. package/dist/src/trails/add-trail.d.ts +11 -0
  28. package/dist/src/trails/add-trail.d.ts.map +1 -0
  29. package/dist/src/trails/add-trail.js +85 -0
  30. package/dist/src/trails/add-trail.js.map +1 -0
  31. package/dist/src/trails/add-verify.d.ts +10 -0
  32. package/dist/src/trails/add-verify.d.ts.map +1 -0
  33. package/dist/src/trails/add-verify.js +67 -0
  34. package/dist/src/trails/add-verify.js.map +1 -0
  35. package/dist/src/trails/create-scaffold.d.ts +15 -0
  36. package/dist/src/trails/create-scaffold.d.ts.map +1 -0
  37. package/dist/src/trails/create-scaffold.js +288 -0
  38. package/dist/src/trails/create-scaffold.js.map +1 -0
  39. package/dist/src/trails/create.d.ts +22 -0
  40. package/dist/src/trails/create.d.ts.map +1 -0
  41. package/dist/src/trails/create.js +121 -0
  42. package/dist/src/trails/create.js.map +1 -0
  43. package/dist/src/trails/guide.d.ts +11 -0
  44. package/dist/src/trails/guide.d.ts.map +1 -0
  45. package/dist/src/trails/guide.js +80 -0
  46. package/dist/src/trails/guide.js.map +1 -0
  47. package/dist/src/trails/load-app.d.ts +4 -0
  48. package/dist/src/trails/load-app.d.ts.map +1 -0
  49. package/dist/src/trails/load-app.js +24 -0
  50. package/dist/src/trails/load-app.js.map +1 -0
  51. package/dist/src/trails/project.d.ts +8 -0
  52. package/dist/src/trails/project.d.ts.map +1 -0
  53. package/dist/src/trails/project.js +43 -0
  54. package/dist/src/trails/project.js.map +1 -0
  55. package/dist/src/trails/survey.d.ts +33 -0
  56. package/dist/src/trails/survey.d.ts.map +1 -0
  57. package/dist/src/trails/survey.js +225 -0
  58. package/dist/src/trails/survey.js.map +1 -0
  59. package/dist/src/trails/warden.d.ts +19 -0
  60. package/dist/src/trails/warden.d.ts.map +1 -0
  61. package/dist/src/trails/warden.js +88 -0
  62. package/dist/src/trails/warden.js.map +1 -0
  63. package/dist/tsconfig.tsbuildinfo +1 -0
  64. package/package.json +28 -0
  65. package/src/__tests__/create.test.ts +349 -0
  66. package/src/__tests__/guide.test.ts +91 -0
  67. package/src/__tests__/load-app.test.ts +15 -0
  68. package/src/__tests__/survey.test.ts +161 -0
  69. package/src/__tests__/warden.test.ts +74 -0
  70. package/src/app.ts +22 -0
  71. package/src/clack.ts +89 -0
  72. package/src/cli.ts +14 -0
  73. package/src/trails/add-surface.ts +119 -0
  74. package/src/trails/add-trail.ts +103 -0
  75. package/src/trails/add-verify.ts +87 -0
  76. package/src/trails/create-scaffold.ts +352 -0
  77. package/src/trails/create.ts +203 -0
  78. package/src/trails/guide.ts +104 -0
  79. package/src/trails/load-app.ts +37 -0
  80. package/src/trails/project.ts +51 -0
  81. package/src/trails/survey.ts +307 -0
  82. package/src/trails/warden.ts +104 -0
  83. package/tsconfig.json +9 -0
@@ -0,0 +1 @@
1
+ $ tsc -b
@@ -0,0 +1,3 @@
1
+ $ oxlint ./src
2
+ Found 0 warnings and 0 errors.
3
+ Finished in 113ms on 18 files with 93 rules using 24 threads.
@@ -0,0 +1 @@
1
+ $ tsc --noEmit
package/CHANGELOG.md ADDED
@@ -0,0 +1,12 @@
1
+ # trails
2
+
3
+ ## 0.1.1-beta.0
4
+
5
+ ### Patch Changes
6
+
7
+ - Updated dependencies
8
+ - @ontrails/core@1.0.0-beta.0
9
+ - @ontrails/cli@1.0.0-beta.0
10
+ - @ontrails/logging@1.0.0-beta.0
11
+ - @ontrails/warden@1.0.0-beta.0
12
+ - @ontrails/schema@1.0.0-beta.0
@@ -0,0 +1,6 @@
1
+ /* oxlint-disable eslint-plugin-jest/require-hook -- testExamples registers tests at module scope */
2
+ import { testExamples } from '@ontrails/testing';
3
+
4
+ import { app } from '../src/app.js';
5
+
6
+ testExamples(app);
package/bin/trails.ts ADDED
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env bun
2
+ /* oxlint-disable eslint-plugin-jest/require-hook -- CLI bin entrypoints execute at module scope */
3
+ import '../src/cli.js';
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env bun
2
+ import '../src/cli.js';
3
+ //# sourceMappingURL=trails.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trails.d.ts","sourceRoot":"","sources":["../../bin/trails.ts"],"names":[],"mappings":";AAEA,OAAO,eAAe,CAAC"}
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env bun
2
+ /* oxlint-disable eslint-plugin-jest/require-hook -- CLI bin entrypoints execute at module scope */
3
+ import '../src/cli.js';
4
+ //# sourceMappingURL=trails.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trails.js","sourceRoot":"","sources":["../../bin/trails.ts"],"names":[],"mappings":";AACA,mGAAmG;AACnG,OAAO,eAAe,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const app: import("@ontrails/core").Topo;
2
+ //# sourceMappingURL=app.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.d.ts","sourceRoot":"","sources":["../../src/app.ts"],"names":[],"mappings":"AAWA,eAAO,MAAM,GAAG,+BAUf,CAAC"}
@@ -0,0 +1,11 @@
1
+ import { topo } from '@ontrails/core';
2
+ import * as addSurface from './trails/add-surface.js';
3
+ import * as addTrail from './trails/add-trail.js';
4
+ import * as addVerify from './trails/add-verify.js';
5
+ import * as create from './trails/create.js';
6
+ import * as createScaffold from './trails/create-scaffold.js';
7
+ import * as guide from './trails/guide.js';
8
+ import * as survey from './trails/survey.js';
9
+ import * as warden from './trails/warden.js';
10
+ export const app = topo('trails', survey, guide, warden, create, createScaffold, addSurface, addVerify, addTrail);
11
+ //# sourceMappingURL=app.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app.js","sourceRoot":"","sources":["../../src/app.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAEtC,OAAO,KAAK,UAAU,MAAM,yBAAyB,CAAC;AACtD,OAAO,KAAK,QAAQ,MAAM,uBAAuB,CAAC;AAClD,OAAO,KAAK,SAAS,MAAM,wBAAwB,CAAC;AACpD,OAAO,KAAK,MAAM,MAAM,oBAAoB,CAAC;AAC7C,OAAO,KAAK,cAAc,MAAM,6BAA6B,CAAC;AAC9D,OAAO,KAAK,KAAK,MAAM,mBAAmB,CAAC;AAC3C,OAAO,KAAK,MAAM,MAAM,oBAAoB,CAAC;AAC7C,OAAO,KAAK,MAAM,MAAM,oBAAoB,CAAC;AAE7C,MAAM,CAAC,MAAM,GAAG,GAAG,IAAI,CACrB,QAAQ,EACR,MAAM,EACN,KAAK,EACL,MAAM,EACN,MAAM,EACN,cAAc,EACd,UAAU,EACV,SAAS,EACT,QAAQ,CACT,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Clack-backed input resolver for the Trails CLI.
3
+ *
4
+ * This stays at the app layer so @ontrails/cli remains prompt-library agnostic.
5
+ */
6
+ import type { InputResolver } from '@ontrails/cli';
7
+ /** Fill missing input by prompting with Clack when interactive. */
8
+ export declare const resolveInputWithClack: InputResolver;
9
+ //# sourceMappingURL=clack.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clack.d.ts","sourceRoot":"","sources":["../../src/clack.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAS,aAAa,EAAuB,MAAM,eAAe,CAAC;AA6D/E,mEAAmE;AACnE,eAAO,MAAM,qBAAqB,EAAE,aAoBnC,CAAC"}
@@ -0,0 +1,62 @@
1
+ /**
2
+ * Clack-backed input resolver for the Trails CLI.
3
+ *
4
+ * This stays at the app layer so @ontrails/cli remains prompt-library agnostic.
5
+ */
6
+ import { isInteractive } from '@ontrails/cli';
7
+ import * as clack from '@clack/prompts';
8
+ /** Check whether a field still needs input. */
9
+ const needsInput = (field, current) => current[field.name] === undefined &&
10
+ field.required &&
11
+ field.default === undefined;
12
+ /** Build Clack options from field options. */
13
+ const toClackOptions = (field) => field.options?.map((option) => ({
14
+ ...(option.hint === undefined ? {} : { hint: option.hint }),
15
+ label: option.label ?? option.value,
16
+ value: option.value,
17
+ })) ?? [];
18
+ /** Normalize cancelled prompts to `undefined`. */
19
+ const cancelable = async (value) => await (clack.isCancel(value) ? undefined : value);
20
+ const fieldResolvers = {
21
+ boolean: async (field) => cancelable(await clack.confirm({
22
+ initialValue: field.default ?? false,
23
+ message: field.label,
24
+ })),
25
+ enum: async (field) => cancelable(await clack.select({
26
+ message: field.label,
27
+ options: toClackOptions(field),
28
+ })),
29
+ multiselect: async (field) => cancelable(await clack.multiselect({
30
+ initialValues: field.default ?? [],
31
+ message: field.label,
32
+ options: toClackOptions(field),
33
+ })),
34
+ number: async (field) => {
35
+ const raw = await clack.text({ message: field.label });
36
+ return clack.isCancel(raw) ? undefined : Number(raw);
37
+ },
38
+ string: async (field) => cancelable(await clack.text({ message: field.label })),
39
+ };
40
+ /** Resolve a single field value with Clack. */
41
+ const resolveField = (field) => {
42
+ const resolver = fieldResolvers[field.type];
43
+ return resolver(field);
44
+ };
45
+ /** Fill missing input by prompting with Clack when interactive. */
46
+ export const resolveInputWithClack = async (fields, provided, options) => {
47
+ if (!isInteractive(options)) {
48
+ return provided;
49
+ }
50
+ const resolved = { ...provided };
51
+ for (const field of fields) {
52
+ if (!needsInput(field, resolved)) {
53
+ continue;
54
+ }
55
+ const value = await resolveField(field);
56
+ if (value !== undefined) {
57
+ resolved[field.name] = value;
58
+ }
59
+ }
60
+ return resolved;
61
+ };
62
+ //# sourceMappingURL=clack.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clack.js","sourceRoot":"","sources":["../../src/clack.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=cli.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../../src/cli.ts"],"names":[],"mappings":""}
@@ -0,0 +1,13 @@
1
+ import { outputModePreset } from '@ontrails/cli';
2
+ import { blaze } from '@ontrails/cli/commander';
3
+ import { app } from './app.js';
4
+ import { resolveInputWithClack } from './clack.js';
5
+ // oxlint-disable-next-line require-hook -- CLI entry point
6
+ blaze(app, {
7
+ description: 'Agent-native, contract-first TypeScript framework',
8
+ name: 'trails',
9
+ presets: [outputModePreset()],
10
+ resolveInput: resolveInputWithClack,
11
+ version: '0.1.0',
12
+ });
13
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../../src/cli.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAC;AAEhD,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAEnD,2DAA2D;AAC3D,KAAK,CAAC,GAAG,EAAE;IACT,WAAW,EAAE,mDAAmD;IAChE,IAAI,EAAE,QAAQ;IACd,OAAO,EAAE,CAAC,gBAAgB,EAAE,CAAC;IAC7B,YAAY,EAAE,qBAAqB;IACnC,OAAO,EAAE,OAAO;CACjB,CAAC,CAAC"}
@@ -0,0 +1,13 @@
1
+ /**
2
+ * `add.surface` trail -- Add a surface to an existing project.
3
+ *
4
+ * Generates the CLI or MCP entry point and updates package.json dependencies.
5
+ */
6
+ export declare const addSurface: import("@ontrails/core").Trail<{
7
+ surface: "cli" | "mcp";
8
+ dir?: string | undefined;
9
+ }, {
10
+ created: string;
11
+ dependency: string;
12
+ }>;
13
+ //# sourceMappingURL=add-surface.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add-surface.d.ts","sourceRoot":"","sources":["../../../src/trails/add-surface.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAwFH,eAAO,MAAM,UAAU;;;;;;EA0BrB,CAAC"}
@@ -0,0 +1,88 @@
1
+ /**
2
+ * `add.surface` trail -- Add a surface to an existing project.
3
+ *
4
+ * Generates the CLI or MCP entry point and updates package.json dependencies.
5
+ */
6
+ import { existsSync, mkdirSync } from 'node:fs';
7
+ import { basename, dirname, join, resolve } from 'node:path';
8
+ import { Result, trail } from '@ontrails/core';
9
+ import { z } from 'zod';
10
+ import { findTopoPath } from './project.js';
11
+ const generateCliEntry = (appImportPath) => `import { blaze } from '@ontrails/cli/commander';
12
+
13
+ import { app } from '${appImportPath}';
14
+
15
+ blaze(app);
16
+ `;
17
+ const generateMcpEntry = (appImportPath) => `import { blaze } from '@ontrails/mcp';
18
+
19
+ import { app } from '${appImportPath}';
20
+
21
+ await blaze(app);
22
+ `;
23
+ /** Resolve the entry file for a surface. */
24
+ const getEntryFile = (surface) => surface === 'cli' ? 'src/cli.ts' : 'src/mcp.ts';
25
+ // ---------------------------------------------------------------------------
26
+ // Trail definition
27
+ // ---------------------------------------------------------------------------
28
+ /** Patch deps and optionally bin in a parsed package.json. */
29
+ const patchPkgDeps = (pkg, surface, cwd) => {
30
+ const depName = surface === 'cli' ? '@ontrails/cli' : '@ontrails/mcp';
31
+ const deps = (pkg['dependencies'] ?? {});
32
+ deps[depName] = 'workspace:*';
33
+ if (surface === 'cli') {
34
+ deps['commander'] = '^14.0.0';
35
+ pkg['bin'] = {
36
+ [pkg['name'] ?? basename(cwd)]: './src/cli.ts',
37
+ };
38
+ }
39
+ pkg['dependencies'] = Object.fromEntries(Object.entries(deps).toSorted(([a], [b]) => a.localeCompare(b)));
40
+ return depName;
41
+ };
42
+ /** Update package.json with surface dependency and CLI bin if needed. */
43
+ const updatePkgJsonForSurface = async (cwd, surface) => {
44
+ const pkgPath = join(cwd, 'package.json');
45
+ if (!existsSync(pkgPath)) {
46
+ return surface === 'cli' ? '@ontrails/cli' : '@ontrails/mcp';
47
+ }
48
+ const pkg = (await Bun.file(pkgPath).json());
49
+ const depName = patchPkgDeps(pkg, surface, cwd);
50
+ await Bun.write(pkgPath, `${JSON.stringify(pkg, null, 2)}\n`);
51
+ return depName;
52
+ };
53
+ /** Create the entry file for a surface and return the relative path. */
54
+ const writeSurfaceEntry = async (cwd, surface) => {
55
+ const entryFile = getEntryFile(surface);
56
+ const fullEntryPath = join(cwd, entryFile);
57
+ const appImport = (await findTopoPath(cwd)) ?? './app.js';
58
+ const content = surface === 'cli'
59
+ ? generateCliEntry(appImport)
60
+ : generateMcpEntry(appImport);
61
+ mkdirSync(dirname(fullEntryPath), { recursive: true });
62
+ await Bun.write(fullEntryPath, content);
63
+ return entryFile;
64
+ };
65
+ export const addSurface = trail('add.surface', {
66
+ description: 'Add a surface to an existing project',
67
+ implementation: async (input) => {
68
+ const cwd = resolve(input.dir ?? '.');
69
+ const { surface } = input;
70
+ const entryFile = getEntryFile(surface);
71
+ if (existsSync(join(cwd, entryFile))) {
72
+ return Result.err(new Error(`${surface.toUpperCase()} is already blazed. Nothing to do.`));
73
+ }
74
+ return Result.ok({
75
+ created: await writeSurfaceEntry(cwd, surface),
76
+ dependency: await updatePkgJsonForSurface(cwd, surface),
77
+ });
78
+ },
79
+ input: z.object({
80
+ dir: z.string().optional().describe('Project directory'),
81
+ surface: z.enum(['cli', 'mcp']).describe('Surface to add'),
82
+ }),
83
+ output: z.object({
84
+ created: z.string(),
85
+ dependency: z.string(),
86
+ }),
87
+ });
88
+ //# sourceMappingURL=add-surface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add-surface.js","sourceRoot":"","sources":["../../../src/trails/add-surface.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ /**
2
+ * `add.trail` trail -- Scaffold a new trail file with tests.
3
+ */
4
+ export declare const addTrail: import("@ontrails/core").Trail<{
5
+ destructive: boolean;
6
+ id: string;
7
+ readOnly: boolean;
8
+ }, {
9
+ created: string[];
10
+ }>;
11
+ //# sourceMappingURL=add-trail.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add-trail.d.ts","sourceRoot":"","sources":["../../../src/trails/add-trail.ts"],"names":[],"mappings":"AAAA;;GAEG;AAuEH,eAAO,MAAM,QAAQ;;;;;;EA6BnB,CAAC"}
@@ -0,0 +1,85 @@
1
+ /**
2
+ * `add.trail` trail -- Scaffold a new trail file with tests.
3
+ */
4
+ import { mkdirSync } from 'node:fs';
5
+ import { dirname, join, resolve } from 'node:path';
6
+ import { Result, trail } from '@ontrails/core';
7
+ import { z } from 'zod';
8
+ // ---------------------------------------------------------------------------
9
+ // Helpers
10
+ // ---------------------------------------------------------------------------
11
+ const generateTrailFile = (id, readOnly, destructive) => {
12
+ const markers = [];
13
+ if (readOnly) {
14
+ markers.push(' readOnly: true,');
15
+ }
16
+ if (destructive) {
17
+ markers.push(' destructive: true,');
18
+ }
19
+ const markerBlock = markers.length > 0 ? `\n${markers.join('\n')}` : '';
20
+ return `import { Result, trail } from '@ontrails/core';
21
+ import { z } from 'zod';
22
+
23
+ export const ${id.replaceAll('.', '_')} = trail('${id}', {
24
+ description: 'TODO: describe this trail',
25
+ examples: [
26
+ {
27
+ input: {},
28
+ name: 'TODO: add example',
29
+ },
30
+ ],
31
+ implementation: async (input) => {
32
+ return Result.ok({ message: 'TODO' });
33
+ },
34
+ input: z.object({}),${markerBlock}
35
+ output: z.object({ message: z.string() }),
36
+ });
37
+ `;
38
+ };
39
+ const generateTestFile = (id) => {
40
+ const moduleName = id.replaceAll('.', '-');
41
+ const trailName = id.replaceAll('.', '_');
42
+ return `import { testTrail } from '@ontrails/testing';
43
+ import { ${trailName} } from '../src/trails/${moduleName}.js';
44
+
45
+ testTrail(${trailName}, [
46
+ { description: 'basic test', input: {}, expectOk: true },
47
+ ]);
48
+ `;
49
+ };
50
+ // ---------------------------------------------------------------------------
51
+ // Trail definition
52
+ // ---------------------------------------------------------------------------
53
+ /** Write a file, creating parent directories as needed. */
54
+ const writeWithDirs = async (filePath, content) => {
55
+ mkdirSync(dirname(filePath), { recursive: true });
56
+ await Bun.write(filePath, content);
57
+ };
58
+ export const addTrail = trail('add.trail', {
59
+ description: 'Scaffold a new trail with tests and examples',
60
+ implementation: async (input, ctx) => {
61
+ const { id } = input;
62
+ const moduleName = id.replaceAll('.', '-');
63
+ const cwd = resolve(ctx.cwd ?? '.');
64
+ const files = new Map([
65
+ [
66
+ `src/trails/${moduleName}.ts`,
67
+ generateTrailFile(id, input.readOnly, input.destructive),
68
+ ],
69
+ [`__tests__/${moduleName}.test.ts`, generateTestFile(id)],
70
+ ]);
71
+ for (const [relativePath, content] of files) {
72
+ await writeWithDirs(join(cwd, relativePath), content);
73
+ }
74
+ return Result.ok({ created: [...files.keys()] });
75
+ },
76
+ input: z.object({
77
+ destructive: z.boolean().default(false).describe('Destructive trail'),
78
+ id: z.string().describe('Trail ID (e.g., entity.update)'),
79
+ readOnly: z.boolean().default(false).describe('Read-only trail'),
80
+ }),
81
+ output: z.object({
82
+ created: z.array(z.string()),
83
+ }),
84
+ });
85
+ //# sourceMappingURL=add-trail.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add-trail.js","sourceRoot":"","sources":["../../../src/trails/add-trail.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEnD,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,8EAA8E;AAC9E,UAAU;AACV,8EAA8E;AAE9E,MAAM,iBAAiB,GAAG,CACxB,EAAU,EACV,QAAiB,EACjB,WAAoB,EACZ,EAAE;IACV,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACpC,CAAC;IACD,IAAI,WAAW,EAAE,CAAC;QAChB,OAAO,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IACvC,CAAC;IACD,MAAM,WAAW,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IAExE,OAAO;;;eAGM,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,aAAa,EAAE;;;;;;;;;;;wBAW7B,WAAW;;;CAGlC,CAAC;AACF,CAAC,CAAC;AAEF,MAAM,gBAAgB,GAAG,CAAC,EAAU,EAAU,EAAE;IAC9C,MAAM,UAAU,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IAC3C,MAAM,SAAS,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IAC1C,OAAO;WACE,SAAS,0BAA0B,UAAU;;YAE5C,SAAS;;;CAGpB,CAAC;AACF,CAAC,CAAC;AAEF,8EAA8E;AAC9E,mBAAmB;AACnB,8EAA8E;AAE9E,2DAA2D;AAC3D,MAAM,aAAa,GAAG,KAAK,EACzB,QAAgB,EAChB,OAAe,EACA,EAAE;IACjB,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAClD,MAAM,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;AACrC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAG,KAAK,CAAC,WAAW,EAAE;IACzC,WAAW,EAAE,8CAA8C;IAC3D,cAAc,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QACnC,MAAM,EAAE,EAAE,EAAE,GAAG,KAAK,CAAC;QACrB,MAAM,UAAU,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAC3C,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;QAEpC,MAAM,KAAK,GAAG,IAAI,GAAG,CAAiB;YACpC;gBACE,cAAc,UAAU,KAAK;gBAC7B,iBAAiB,CAAC,EAAE,EAAE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,WAAW,CAAC;aACzD;YACD,CAAC,aAAa,UAAU,UAAU,EAAE,gBAAgB,CAAC,EAAE,CAAC,CAAC;SAC1D,CAAC,CAAC;QAEH,KAAK,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,IAAI,KAAK,EAAE,CAAC;YAC5C,MAAM,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,EAAE,OAAO,CAAC,CAAC;QACxD,CAAC;QAED,OAAO,MAAM,CAAC,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC;IACnD,CAAC;IACD,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC;QACd,WAAW,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,mBAAmB,CAAC;QACrE,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,gCAAgC,CAAC;QACzD,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,iBAAiB,CAAC;KACjE,CAAC;IACF,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC;QACf,OAAO,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;KAC7B,CAAC;CACH,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * `add.verify` trail -- Add testing + warden setup to a project.
3
+ */
4
+ export declare const addVerify: import("@ontrails/core").Trail<{
5
+ name: string;
6
+ dir?: string | undefined;
7
+ }, {
8
+ created: string[];
9
+ }>;
10
+ //# sourceMappingURL=add-verify.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add-verify.d.ts","sourceRoot":"","sources":["../../../src/trails/add-verify.ts"],"names":[],"mappings":"AAAA;;GAEG;AAsDH,eAAO,MAAM,SAAS;;;;;EA8BpB,CAAC"}
@@ -0,0 +1,67 @@
1
+ /**
2
+ * `add.verify` trail -- Add testing + warden setup to a project.
3
+ */
4
+ import { existsSync, mkdirSync } from 'node:fs';
5
+ import { dirname, join, resolve } from 'node:path';
6
+ import { Result, trail } from '@ontrails/core';
7
+ import { z } from 'zod';
8
+ // ---------------------------------------------------------------------------
9
+ // Content generators
10
+ // ---------------------------------------------------------------------------
11
+ const generateTestFile = () => `import { testAll } from '@ontrails/testing';
12
+ import { app } from '../src/app.js';
13
+
14
+ testAll(app);
15
+ `;
16
+ const generateLefthookYml = () => `pre-push:
17
+ commands:
18
+ warden:
19
+ run: bunx trails warden --exit-code
20
+ `;
21
+ /** Add testing and warden devDependencies to package.json when present. */
22
+ const patchVerifyDeps = (pkg) => {
23
+ const devDeps = (pkg['devDependencies'] ?? {});
24
+ devDeps['@ontrails/testing'] = 'workspace:*';
25
+ devDeps['@ontrails/warden'] = 'workspace:*';
26
+ devDeps['lefthook'] = '^2.1.1';
27
+ pkg['devDependencies'] = Object.fromEntries(Object.entries(devDeps).toSorted(([a], [b]) => a.localeCompare(b)));
28
+ };
29
+ /** Update package.json in the target project with verify dependencies. */
30
+ const updatePackageJsonForVerify = async (projectDir) => {
31
+ const pkgPath = join(projectDir, 'package.json');
32
+ if (!existsSync(pkgPath)) {
33
+ return;
34
+ }
35
+ const pkg = (await Bun.file(pkgPath).json());
36
+ patchVerifyDeps(pkg);
37
+ await Bun.write(pkgPath, `${JSON.stringify(pkg, null, 2)}\n`);
38
+ };
39
+ // ---------------------------------------------------------------------------
40
+ // Trail definition
41
+ // ---------------------------------------------------------------------------
42
+ export const addVerify = trail('add.verify', {
43
+ description: 'Add testing and warden verification',
44
+ implementation: async (input) => {
45
+ const projectDir = resolve(input.dir ?? '.', input.name);
46
+ const files = [];
47
+ const writeFile = async (relativePath, content) => {
48
+ const fullPath = join(projectDir, relativePath);
49
+ mkdirSync(dirname(fullPath), { recursive: true });
50
+ await Bun.write(fullPath, content);
51
+ files.push(relativePath);
52
+ };
53
+ await writeFile('__tests__/examples.test.ts', generateTestFile());
54
+ await writeFile('lefthook.yml', generateLefthookYml());
55
+ await updatePackageJsonForVerify(projectDir);
56
+ return Result.ok({ created: files });
57
+ },
58
+ input: z.object({
59
+ dir: z.string().optional().describe('Parent directory'),
60
+ name: z.string().describe('Project name'),
61
+ }),
62
+ markers: { internal: true },
63
+ output: z.object({
64
+ created: z.array(z.string()),
65
+ }),
66
+ });
67
+ //# sourceMappingURL=add-verify.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add-verify.js","sourceRoot":"","sources":["../../../src/trails/add-verify.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * `create.scaffold` trail -- Creates base project structure.
3
+ *
4
+ * Generates package.json, tsconfig, app.ts, starter trails, and .trails/ directory.
5
+ */
6
+ export declare const createScaffold: import("@ontrails/core").Trail<{
7
+ name: string;
8
+ starter: "empty" | "entity" | "hello";
9
+ dir?: string | undefined;
10
+ }, {
11
+ created: string[];
12
+ dir: string;
13
+ name: string;
14
+ }>;
15
+ //# sourceMappingURL=create-scaffold.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-scaffold.d.ts","sourceRoot":"","sources":["../../../src/trails/create-scaffold.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AA8TH,eAAO,MAAM,cAAc;;;;;;;;EA6BzB,CAAC"}