@holdpoint/yaml-core 0.1.0-alpha.0 → 0.1.0-alpha.10

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.
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ # MIT License
2
+
3
+ Copyright (c) 2024 Sentinel
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/dist/index.d.ts CHANGED
@@ -24,264 +24,76 @@ declare function generateYaml(config: HoldpointConfig): string;
24
24
  */
25
25
  declare function matchesWhen(when: string | undefined, changedFiles: string[], userPatterns?: Record<string, string>): boolean;
26
26
 
27
- declare const HookEventSchema: z.ZodEnum<["before_done"]>;
27
+ declare const HookEventSchema: z.ZodEnum<{
28
+ before_done: "before_done";
29
+ }>;
28
30
  declare const ConditionDefSchema: z.ZodObject<{
29
31
  id: z.ZodString;
30
- operator: z.ZodEnum<["file_exists", "file_contains", "env_var_set", "shell_returns_0"]>;
32
+ operator: z.ZodEnum<{
33
+ file_exists: "file_exists";
34
+ file_contains: "file_contains";
35
+ env_var_set: "env_var_set";
36
+ shell_returns_0: "shell_returns_0";
37
+ }>;
31
38
  path: z.ZodOptional<z.ZodString>;
32
39
  contains: z.ZodOptional<z.ZodString>;
33
40
  envVar: z.ZodOptional<z.ZodString>;
34
41
  cmd: z.ZodOptional<z.ZodString>;
35
- }, "strip", z.ZodTypeAny, {
36
- id: string;
37
- operator: "file_exists" | "file_contains" | "env_var_set" | "shell_returns_0";
38
- path?: string | undefined;
39
- contains?: string | undefined;
40
- envVar?: string | undefined;
41
- cmd?: string | undefined;
42
- }, {
43
- id: string;
44
- operator: "file_exists" | "file_contains" | "env_var_set" | "shell_returns_0";
45
- path?: string | undefined;
46
- contains?: string | undefined;
47
- envVar?: string | undefined;
48
- cmd?: string | undefined;
49
- }>;
50
- declare const CheckDefSchema: z.ZodEffects<z.ZodEffects<z.ZodObject<{
42
+ }, z.core.$strip>;
43
+ declare const CheckDefSchema: z.ZodPreprocess<z.ZodObject<{
51
44
  id: z.ZodString;
52
45
  label: z.ZodString;
53
- on: z.ZodOptional<z.ZodEnum<["before_done"]>>;
46
+ on: z.ZodOptional<z.ZodEnum<{
47
+ before_done: "before_done";
48
+ }>>;
54
49
  when: z.ZodOptional<z.ZodString>;
55
50
  cmd: z.ZodOptional<z.ZodString>;
56
51
  prompt: z.ZodOptional<z.ZodString>;
57
52
  conditionId: z.ZodOptional<z.ZodString>;
58
- }, "strip", z.ZodTypeAny, {
59
- id: string;
60
- label: string;
61
- cmd?: string | undefined;
62
- on?: "before_done" | undefined;
63
- when?: string | undefined;
64
- prompt?: string | undefined;
65
- conditionId?: string | undefined;
66
- }, {
67
- id: string;
68
- label: string;
69
- cmd?: string | undefined;
70
- on?: "before_done" | undefined;
71
- when?: string | undefined;
72
- prompt?: string | undefined;
73
- conditionId?: string | undefined;
74
- }>, {
75
- id: string;
76
- label: string;
77
- cmd?: string | undefined;
78
- on?: "before_done" | undefined;
79
- when?: string | undefined;
80
- prompt?: string | undefined;
81
- conditionId?: string | undefined;
82
- }, {
83
- id: string;
84
- label: string;
85
- cmd?: string | undefined;
86
- on?: "before_done" | undefined;
87
- when?: string | undefined;
88
- prompt?: string | undefined;
89
- conditionId?: string | undefined;
90
- }>, {
91
- id: string;
92
- label: string;
93
- cmd?: string | undefined;
94
- on?: "before_done" | undefined;
95
- when?: string | undefined;
96
- prompt?: string | undefined;
97
- conditionId?: string | undefined;
98
- }, unknown>;
99
- declare const HoldpointConfigSchema: z.ZodEffects<z.ZodEffects<z.ZodObject<{
53
+ }, z.core.$strip>>;
54
+ declare const HoldpointConfigSchema: z.ZodPreprocess<z.ZodObject<{
100
55
  version: z.ZodDefault<z.ZodNumber>;
101
56
  context: z.ZodDefault<z.ZodObject<{
102
57
  guides: z.ZodDefault<z.ZodRecord<z.ZodString, z.ZodString>>;
103
- }, "strip", z.ZodTypeAny, {
104
- guides: Record<string, string>;
105
- }, {
106
- guides?: Record<string, string> | undefined;
107
- }>>;
58
+ }, z.core.$strip>>;
108
59
  conditions: z.ZodDefault<z.ZodArray<z.ZodObject<{
109
60
  id: z.ZodString;
110
- operator: z.ZodEnum<["file_exists", "file_contains", "env_var_set", "shell_returns_0"]>;
61
+ operator: z.ZodEnum<{
62
+ file_exists: "file_exists";
63
+ file_contains: "file_contains";
64
+ env_var_set: "env_var_set";
65
+ shell_returns_0: "shell_returns_0";
66
+ }>;
111
67
  path: z.ZodOptional<z.ZodString>;
112
68
  contains: z.ZodOptional<z.ZodString>;
113
69
  envVar: z.ZodOptional<z.ZodString>;
114
70
  cmd: z.ZodOptional<z.ZodString>;
115
- }, "strip", z.ZodTypeAny, {
116
- id: string;
117
- operator: "file_exists" | "file_contains" | "env_var_set" | "shell_returns_0";
118
- path?: string | undefined;
119
- contains?: string | undefined;
120
- envVar?: string | undefined;
121
- cmd?: string | undefined;
122
- }, {
123
- id: string;
124
- operator: "file_exists" | "file_contains" | "env_var_set" | "shell_returns_0";
125
- path?: string | undefined;
126
- contains?: string | undefined;
127
- envVar?: string | undefined;
128
- cmd?: string | undefined;
129
- }>, "many">>;
130
- checks: z.ZodDefault<z.ZodArray<z.ZodEffects<z.ZodEffects<z.ZodObject<{
71
+ }, z.core.$strip>>>;
72
+ checks: z.ZodDefault<z.ZodArray<z.ZodPreprocess<z.ZodObject<{
131
73
  id: z.ZodString;
132
74
  label: z.ZodString;
133
- on: z.ZodOptional<z.ZodEnum<["before_done"]>>;
75
+ on: z.ZodOptional<z.ZodEnum<{
76
+ before_done: "before_done";
77
+ }>>;
134
78
  when: z.ZodOptional<z.ZodString>;
135
79
  cmd: z.ZodOptional<z.ZodString>;
136
80
  prompt: z.ZodOptional<z.ZodString>;
137
81
  conditionId: z.ZodOptional<z.ZodString>;
138
- }, "strip", z.ZodTypeAny, {
139
- id: string;
140
- label: string;
141
- cmd?: string | undefined;
142
- on?: "before_done" | undefined;
143
- when?: string | undefined;
144
- prompt?: string | undefined;
145
- conditionId?: string | undefined;
146
- }, {
147
- id: string;
148
- label: string;
149
- cmd?: string | undefined;
150
- on?: "before_done" | undefined;
151
- when?: string | undefined;
152
- prompt?: string | undefined;
153
- conditionId?: string | undefined;
154
- }>, {
155
- id: string;
156
- label: string;
157
- cmd?: string | undefined;
158
- on?: "before_done" | undefined;
159
- when?: string | undefined;
160
- prompt?: string | undefined;
161
- conditionId?: string | undefined;
162
- }, {
163
- id: string;
164
- label: string;
165
- cmd?: string | undefined;
166
- on?: "before_done" | undefined;
167
- when?: string | undefined;
168
- prompt?: string | undefined;
169
- conditionId?: string | undefined;
170
- }>, {
171
- id: string;
172
- label: string;
173
- cmd?: string | undefined;
174
- on?: "before_done" | undefined;
175
- when?: string | undefined;
176
- prompt?: string | undefined;
177
- conditionId?: string | undefined;
178
- }, unknown>, "many">>;
82
+ }, z.core.$strip>>>>;
179
83
  patterns: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodString>>;
180
- session_context_files: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
181
- }, "strip", z.ZodTypeAny, {
182
- checks: {
183
- id: string;
184
- label: string;
185
- cmd?: string | undefined;
186
- on?: "before_done" | undefined;
187
- when?: string | undefined;
188
- prompt?: string | undefined;
189
- conditionId?: string | undefined;
190
- }[];
191
- version: number;
192
- context: {
193
- guides: Record<string, string>;
194
- };
195
- conditions: {
196
- id: string;
197
- operator: "file_exists" | "file_contains" | "env_var_set" | "shell_returns_0";
198
- path?: string | undefined;
199
- contains?: string | undefined;
200
- envVar?: string | undefined;
201
- cmd?: string | undefined;
202
- }[];
203
- patterns?: Record<string, string> | undefined;
204
- session_context_files?: string[] | undefined;
205
- }, {
206
- checks?: unknown[] | undefined;
207
- version?: number | undefined;
208
- context?: {
209
- guides?: Record<string, string> | undefined;
210
- } | undefined;
211
- conditions?: {
212
- id: string;
213
- operator: "file_exists" | "file_contains" | "env_var_set" | "shell_returns_0";
214
- path?: string | undefined;
215
- contains?: string | undefined;
216
- envVar?: string | undefined;
217
- cmd?: string | undefined;
218
- }[] | undefined;
219
- patterns?: Record<string, string> | undefined;
220
- session_context_files?: string[] | undefined;
221
- }>, {
222
- checks: {
223
- id: string;
224
- label: string;
225
- cmd?: string | undefined;
226
- on?: "before_done" | undefined;
227
- when?: string | undefined;
228
- prompt?: string | undefined;
229
- conditionId?: string | undefined;
230
- }[];
231
- version: number;
232
- context: {
233
- guides: Record<string, string>;
234
- };
235
- conditions: {
236
- id: string;
237
- operator: "file_exists" | "file_contains" | "env_var_set" | "shell_returns_0";
238
- path?: string | undefined;
239
- contains?: string | undefined;
240
- envVar?: string | undefined;
241
- cmd?: string | undefined;
242
- }[];
243
- patterns?: Record<string, string> | undefined;
244
- session_context_files?: string[] | undefined;
245
- }, {
246
- checks?: unknown[] | undefined;
247
- version?: number | undefined;
248
- context?: {
249
- guides?: Record<string, string> | undefined;
250
- } | undefined;
251
- conditions?: {
252
- id: string;
253
- operator: "file_exists" | "file_contains" | "env_var_set" | "shell_returns_0";
254
- path?: string | undefined;
255
- contains?: string | undefined;
256
- envVar?: string | undefined;
257
- cmd?: string | undefined;
258
- }[] | undefined;
259
- patterns?: Record<string, string> | undefined;
260
- session_context_files?: string[] | undefined;
261
- }>, {
262
- checks: {
263
- id: string;
264
- label: string;
265
- cmd?: string | undefined;
266
- on?: "before_done" | undefined;
267
- when?: string | undefined;
268
- prompt?: string | undefined;
269
- conditionId?: string | undefined;
270
- }[];
271
- version: number;
272
- context: {
273
- guides: Record<string, string>;
274
- };
275
- conditions: {
276
- id: string;
277
- operator: "file_exists" | "file_contains" | "env_var_set" | "shell_returns_0";
278
- path?: string | undefined;
279
- contains?: string | undefined;
280
- envVar?: string | undefined;
281
- cmd?: string | undefined;
282
- }[];
283
- patterns?: Record<string, string> | undefined;
284
- session_context_files?: string[] | undefined;
285
- }, unknown>;
84
+ session_context_files: z.ZodOptional<z.ZodArray<z.ZodString>>;
85
+ engines: z.ZodOptional<z.ZodObject<{
86
+ claude: z.ZodOptional<z.ZodObject<{
87
+ stop_command: z.ZodOptional<z.ZodString>;
88
+ live_command: z.ZodOptional<z.ZodString>;
89
+ }, z.core.$strip>>;
90
+ codex: z.ZodOptional<z.ZodObject<{
91
+ stop_command: z.ZodOptional<z.ZodString>;
92
+ }, z.core.$strip>>;
93
+ copilot: z.ZodOptional<z.ZodObject<{
94
+ check_command: z.ZodOptional<z.ZodString>;
95
+ }, z.core.$strip>>;
96
+ }, z.core.$strip>>;
97
+ }, z.core.$strip>>;
286
98
 
287
99
  export { CheckDefSchema, ConditionDefSchema, HoldpointConfigSchema, HookEventSchema, generateYaml, matchesWhen, parseHoldpointYaml, validateConfig };
package/dist/index.js CHANGED
@@ -76,7 +76,7 @@ var CheckDefSchema = z.preprocess(
76
76
  })
77
77
  );
78
78
  var HoldpointContextSchema = z.object({
79
- guides: z.record(z.string()).default({})
79
+ guides: z.record(z.string(), z.string()).default({})
80
80
  });
81
81
  var BUILTIN_SCOPES = /* @__PURE__ */ new Set([
82
82
  "frontend",
@@ -96,6 +96,14 @@ var BUILTIN_SCOPES = /* @__PURE__ */ new Set([
96
96
  "docs",
97
97
  "structural"
98
98
  ]);
99
+ var EnginesConfigSchema = z.object({
100
+ claude: z.object({
101
+ stop_command: z.string().optional(),
102
+ live_command: z.string().optional()
103
+ }).optional(),
104
+ codex: z.object({ stop_command: z.string().optional() }).optional(),
105
+ copilot: z.object({ check_command: z.string().optional() }).optional()
106
+ }).optional();
99
107
  var HoldpointConfigSchema = z.preprocess(
100
108
  migrateLegacyConfig,
101
109
  z.object({
@@ -103,8 +111,9 @@ var HoldpointConfigSchema = z.preprocess(
103
111
  context: HoldpointContextSchema.default({ guides: {} }),
104
112
  conditions: z.array(ConditionDefSchema).default([]),
105
113
  checks: z.array(CheckDefSchema).default([]),
106
- patterns: z.record(z.string()).optional(),
107
- session_context_files: z.array(z.string()).optional()
114
+ patterns: z.record(z.string(), z.string()).optional(),
115
+ session_context_files: z.array(z.string()).optional(),
116
+ engines: EnginesConfigSchema
108
117
  }).superRefine((data, ctx) => {
109
118
  if (!data.patterns) return;
110
119
  for (const [key, value] of Object.entries(data.patterns)) {
@@ -133,7 +142,7 @@ function parseHoldpointYaml(text) {
133
142
  const raw = yaml.load(text);
134
143
  const result = HoldpointConfigSchema.safeParse(raw);
135
144
  if (!result.success) {
136
- const messages = result.error.errors.map((e) => `${e.path.join(".")}: ${e.message}`).join("\n");
145
+ const messages = result.error.issues.map((e) => `${e.path.join(".")}: ${e.message}`).join("\n");
137
146
  throw new Error(`Invalid checks.yaml:
138
147
  ${messages}`);
139
148
  }
@@ -146,7 +155,7 @@ function validateConfig(config) {
146
155
  }
147
156
  return {
148
157
  valid: false,
149
- errors: result.error.errors.map((e) => ({
158
+ errors: result.error.issues.map((e) => ({
150
159
  path: e.path.join("."),
151
160
  message: e.message
152
161
  }))
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/parser.ts","../src/schema.ts"],"sourcesContent":["import * as yaml from \"js-yaml\";\nimport type { HoldpointConfig, ValidationResult } from \"@holdpoint/types\";\nimport { HoldpointConfigSchema } from \"./schema.js\";\n\n/**\n * Parse a checks.yaml text into a HoldpointConfig.\n * Throws on invalid YAML or schema violations.\n */\nexport function parseHoldpointYaml(text: string): HoldpointConfig {\n const raw = yaml.load(text);\n const result = HoldpointConfigSchema.safeParse(raw);\n if (!result.success) {\n const messages = result.error.errors.map((e) => `${e.path.join(\".\")}: ${e.message}`).join(\"\\n\");\n throw new Error(`Invalid checks.yaml:\\n${messages}`);\n }\n return result.data as HoldpointConfig;\n}\n\n/**\n * Validate a parsed HoldpointConfig, returning structured errors.\n */\nexport function validateConfig(config: HoldpointConfig): ValidationResult {\n const result = HoldpointConfigSchema.safeParse(config);\n if (result.success) {\n return { valid: true, errors: [] };\n }\n return {\n valid: false,\n errors: result.error.errors.map((e) => ({\n path: e.path.join(\".\"),\n message: e.message,\n })),\n };\n}\n\n/**\n * Serialize a HoldpointConfig back to YAML text.\n */\nexport function generateYaml(config: HoldpointConfig): string {\n return yaml.dump(config, {\n indent: 2,\n lineWidth: 120,\n quotingType: '\"',\n forceQuotes: false,\n noRefs: true,\n });\n}\n","import { z } from \"zod\";\n\n// ─── Zod schemas ─────────────────────────────────────────────────────────────\n\nexport const HookEventSchema = z.enum([\"before_done\"]);\n\nexport const ConditionOperatorSchema = z.enum([\n \"file_exists\",\n \"file_contains\",\n \"env_var_set\",\n \"shell_returns_0\",\n]);\n\nexport const ConditionDefSchema = z.object({\n id: z.string().min(1),\n operator: ConditionOperatorSchema,\n path: z.string().optional(),\n contains: z.string().optional(),\n envVar: z.string().optional(),\n cmd: z.string().optional(),\n});\n\n/**\n * Per-item migration: handles legacy `trigger: { type, pattern }` → on/when\n * and legacy `manual:` field → `prompt:`.\n */\nfunction migrateLegacyCheckDef(raw: unknown): unknown {\n if (raw == null || typeof raw !== \"object\") return raw;\n const obj = raw as Record<string, unknown>;\n const result: Record<string, unknown> = { ...obj };\n\n // migrate trigger: { type, pattern } → on/when\n if (\"trigger\" in result && !(\"on\" in result) && !(\"when\" in result)) {\n const { trigger } = result;\n delete result.trigger;\n const t = trigger as Record<string, unknown>;\n if (t.type !== \"always\") {\n result.when = t.type === \"custom\" ? t.pattern : t.type;\n }\n }\n\n // migrate manual: → prompt:\n if (\"manual\" in result && !(\"prompt\" in result)) {\n result.prompt = result.manual;\n delete result.manual;\n }\n\n return result;\n}\n\n/**\n * Top-level migration: collapses ALL legacy array names into `checks:`.\n * Handles: deterministic, manual, task, prompt (any combination).\n * Existing `checks:` entries are preserved and come first.\n */\nfunction migrateLegacyConfig(raw: unknown): unknown {\n if (raw == null || typeof raw !== \"object\") return raw;\n const obj = raw as Record<string, unknown>;\n const result: Record<string, unknown> = { ...obj };\n\n const toArray = (key: string) => (Array.isArray(result[key]) ? (result[key] as unknown[]) : []);\n\n const merged = [\n ...toArray(\"checks\"),\n ...toArray(\"task\"),\n ...toArray(\"prompt\"),\n ...toArray(\"deterministic\"),\n ...toArray(\"manual\"),\n ].map(migrateLegacyCheckDef);\n\n if (\n \"checks\" in result ||\n \"task\" in result ||\n \"prompt\" in result ||\n \"deterministic\" in result ||\n \"manual\" in result\n ) {\n result.checks = merged;\n delete result.task;\n delete result.prompt;\n delete result.deterministic;\n delete result.manual;\n }\n\n return result;\n}\n\nexport const CheckDefSchema = z.preprocess(\n migrateLegacyCheckDef,\n z\n .object({\n id: z.string().min(1),\n label: z.string().min(1),\n on: HookEventSchema.optional(),\n when: z.string().optional(),\n cmd: z.string().optional(),\n prompt: z.string().optional(),\n conditionId: z.string().optional(),\n })\n .refine((c) => c.cmd !== undefined || c.prompt !== undefined, {\n message: \"A check must have either cmd (task) or prompt (agent instruction)\",\n }),\n);\n\nexport const HoldpointContextSchema = z.object({\n guides: z.record(z.string()).default({}),\n});\n\n/** Built-in scope names that cannot be overridden by user-defined patterns. */\nconst BUILTIN_SCOPES = new Set([\n \"frontend\",\n \"backend\",\n \"socket\",\n \"visual\",\n \"python\",\n \"go\",\n \"rust\",\n \"java\",\n \"ruby\",\n \"database\",\n \"prisma\",\n \"testing\",\n \"infra\",\n \"ci\",\n \"docs\",\n \"structural\",\n]);\n\nexport const HoldpointConfigSchema = z.preprocess(\n migrateLegacyConfig,\n z\n .object({\n version: z.number().int().positive().default(1),\n context: HoldpointContextSchema.default({ guides: {} }),\n conditions: z.array(ConditionDefSchema).default([]),\n checks: z.array(CheckDefSchema).default([]),\n patterns: z.record(z.string()).optional(),\n session_context_files: z.array(z.string()).optional(),\n })\n .superRefine((data, ctx) => {\n if (!data.patterns) return;\n for (const [key, value] of Object.entries(data.patterns)) {\n if (BUILTIN_SCOPES.has(key)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `'${key}' is a built-in scope name and cannot be redefined in patterns`,\n path: [\"patterns\", key],\n });\n }\n try {\n new RegExp(value);\n } catch {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `Invalid regex in patterns.${key}: '${value}'`,\n path: [\"patterns\", key],\n });\n }\n }\n }),\n);\n"],"mappings":";;;;;AAAA,YAAY,UAAU;;;ACAtB,SAAS,SAAS;AAIX,IAAM,kBAAkB,EAAE,KAAK,CAAC,aAAa,CAAC;AAE9C,IAAM,0BAA0B,EAAE,KAAK;AAAA,EAC5C;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,CAAC;AAEM,IAAM,qBAAqB,EAAE,OAAO;AAAA,EACzC,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC;AAAA,EACpB,UAAU;AAAA,EACV,MAAM,EAAE,OAAO,EAAE,SAAS;AAAA,EAC1B,UAAU,EAAE,OAAO,EAAE,SAAS;AAAA,EAC9B,QAAQ,EAAE,OAAO,EAAE,SAAS;AAAA,EAC5B,KAAK,EAAE,OAAO,EAAE,SAAS;AAC3B,CAAC;AAMD,SAAS,sBAAsB,KAAuB;AACpD,MAAI,OAAO,QAAQ,OAAO,QAAQ,SAAU,QAAO;AACnD,QAAM,MAAM;AACZ,QAAM,SAAkC,EAAE,GAAG,IAAI;AAGjD,MAAI,aAAa,UAAU,EAAE,QAAQ,WAAW,EAAE,UAAU,SAAS;AACnE,UAAM,EAAE,QAAQ,IAAI;AACpB,WAAO,OAAO;AACd,UAAM,IAAI;AACV,QAAI,EAAE,SAAS,UAAU;AACvB,aAAO,OAAO,EAAE,SAAS,WAAW,EAAE,UAAU,EAAE;AAAA,IACpD;AAAA,EACF;AAGA,MAAI,YAAY,UAAU,EAAE,YAAY,SAAS;AAC/C,WAAO,SAAS,OAAO;AACvB,WAAO,OAAO;AAAA,EAChB;AAEA,SAAO;AACT;AAOA,SAAS,oBAAoB,KAAuB;AAClD,MAAI,OAAO,QAAQ,OAAO,QAAQ,SAAU,QAAO;AACnD,QAAM,MAAM;AACZ,QAAM,SAAkC,EAAE,GAAG,IAAI;AAEjD,QAAM,UAAU,CAAC,QAAiB,MAAM,QAAQ,OAAO,GAAG,CAAC,IAAK,OAAO,GAAG,IAAkB,CAAC;AAE7F,QAAM,SAAS;AAAA,IACb,GAAG,QAAQ,QAAQ;AAAA,IACnB,GAAG,QAAQ,MAAM;AAAA,IACjB,GAAG,QAAQ,QAAQ;AAAA,IACnB,GAAG,QAAQ,eAAe;AAAA,IAC1B,GAAG,QAAQ,QAAQ;AAAA,EACrB,EAAE,IAAI,qBAAqB;AAE3B,MACE,YAAY,UACZ,UAAU,UACV,YAAY,UACZ,mBAAmB,UACnB,YAAY,QACZ;AACA,WAAO,SAAS;AAChB,WAAO,OAAO;AACd,WAAO,OAAO;AACd,WAAO,OAAO;AACd,WAAO,OAAO;AAAA,EAChB;AAEA,SAAO;AACT;AAEO,IAAM,iBAAiB,EAAE;AAAA,EAC9B;AAAA,EACA,EACG,OAAO;AAAA,IACN,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC;AAAA,IACpB,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC;AAAA,IACvB,IAAI,gBAAgB,SAAS;AAAA,IAC7B,MAAM,EAAE,OAAO,EAAE,SAAS;AAAA,IAC1B,KAAK,EAAE,OAAO,EAAE,SAAS;AAAA,IACzB,QAAQ,EAAE,OAAO,EAAE,SAAS;AAAA,IAC5B,aAAa,EAAE,OAAO,EAAE,SAAS;AAAA,EACnC,CAAC,EACA,OAAO,CAAC,MAAM,EAAE,QAAQ,UAAa,EAAE,WAAW,QAAW;AAAA,IAC5D,SAAS;AAAA,EACX,CAAC;AACL;AAEO,IAAM,yBAAyB,EAAE,OAAO;AAAA,EAC7C,QAAQ,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,QAAQ,CAAC,CAAC;AACzC,CAAC;AAGD,IAAM,iBAAiB,oBAAI,IAAI;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,CAAC;AAEM,IAAM,wBAAwB,EAAE;AAAA,EACrC;AAAA,EACA,EACG,OAAO;AAAA,IACN,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,CAAC;AAAA,IAC9C,SAAS,uBAAuB,QAAQ,EAAE,QAAQ,CAAC,EAAE,CAAC;AAAA,IACtD,YAAY,EAAE,MAAM,kBAAkB,EAAE,QAAQ,CAAC,CAAC;AAAA,IAClD,QAAQ,EAAE,MAAM,cAAc,EAAE,QAAQ,CAAC,CAAC;AAAA,IAC1C,UAAU,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA,IACxC,uBAAuB,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,SAAS;AAAA,EACtD,CAAC,EACA,YAAY,CAAC,MAAM,QAAQ;AAC1B,QAAI,CAAC,KAAK,SAAU;AACpB,eAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,KAAK,QAAQ,GAAG;AACxD,UAAI,eAAe,IAAI,GAAG,GAAG;AAC3B,YAAI,SAAS;AAAA,UACX,MAAM,EAAE,aAAa;AAAA,UACrB,SAAS,IAAI,GAAG;AAAA,UAChB,MAAM,CAAC,YAAY,GAAG;AAAA,QACxB,CAAC;AAAA,MACH;AACA,UAAI;AACF,YAAI,OAAO,KAAK;AAAA,MAClB,QAAQ;AACN,YAAI,SAAS;AAAA,UACX,MAAM,EAAE,aAAa;AAAA,UACrB,SAAS,6BAA6B,GAAG,MAAM,KAAK;AAAA,UACpD,MAAM,CAAC,YAAY,GAAG;AAAA,QACxB,CAAC;AAAA,MACH;AAAA,IACF;AAAA,EACF,CAAC;AACL;;;ADxJO,SAAS,mBAAmB,MAA+B;AAChE,QAAM,MAAW,UAAK,IAAI;AAC1B,QAAM,SAAS,sBAAsB,UAAU,GAAG;AAClD,MAAI,CAAC,OAAO,SAAS;AACnB,UAAM,WAAW,OAAO,MAAM,OAAO,IAAI,CAAC,MAAM,GAAG,EAAE,KAAK,KAAK,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE,KAAK,IAAI;AAC9F,UAAM,IAAI,MAAM;AAAA,EAAyB,QAAQ,EAAE;AAAA,EACrD;AACA,SAAO,OAAO;AAChB;AAKO,SAAS,eAAe,QAA2C;AACxE,QAAM,SAAS,sBAAsB,UAAU,MAAM;AACrD,MAAI,OAAO,SAAS;AAClB,WAAO,EAAE,OAAO,MAAM,QAAQ,CAAC,EAAE;AAAA,EACnC;AACA,SAAO;AAAA,IACL,OAAO;AAAA,IACP,QAAQ,OAAO,MAAM,OAAO,IAAI,CAAC,OAAO;AAAA,MACtC,MAAM,EAAE,KAAK,KAAK,GAAG;AAAA,MACrB,SAAS,EAAE;AAAA,IACb,EAAE;AAAA,EACJ;AACF;AAKO,SAAS,aAAa,QAAiC;AAC5D,SAAY,UAAK,QAAQ;AAAA,IACvB,QAAQ;AAAA,IACR,WAAW;AAAA,IACX,aAAa;AAAA,IACb,aAAa;AAAA,IACb,QAAQ;AAAA,EACV,CAAC;AACH;","names":[]}
1
+ {"version":3,"sources":["../src/parser.ts","../src/schema.ts"],"sourcesContent":["import * as yaml from \"js-yaml\";\nimport type { HoldpointConfig, ValidationResult } from \"@holdpoint/types\";\nimport { HoldpointConfigSchema } from \"./schema.js\";\n\n/**\n * Parse a checks.yaml text into a HoldpointConfig.\n * Throws on invalid YAML or schema violations.\n */\nexport function parseHoldpointYaml(text: string): HoldpointConfig {\n const raw = yaml.load(text);\n const result = HoldpointConfigSchema.safeParse(raw);\n if (!result.success) {\n const messages = result.error.issues.map((e) => `${e.path.join(\".\")}: ${e.message}`).join(\"\\n\");\n throw new Error(`Invalid checks.yaml:\\n${messages}`);\n }\n return result.data as HoldpointConfig;\n}\n\n/**\n * Validate a parsed HoldpointConfig, returning structured errors.\n */\nexport function validateConfig(config: HoldpointConfig): ValidationResult {\n const result = HoldpointConfigSchema.safeParse(config);\n if (result.success) {\n return { valid: true, errors: [] };\n }\n return {\n valid: false,\n errors: result.error.issues.map((e) => ({\n path: e.path.join(\".\"),\n message: e.message,\n })),\n };\n}\n\n/**\n * Serialize a HoldpointConfig back to YAML text.\n */\nexport function generateYaml(config: HoldpointConfig): string {\n return yaml.dump(config, {\n indent: 2,\n lineWidth: 120,\n quotingType: '\"',\n forceQuotes: false,\n noRefs: true,\n });\n}\n","import { z } from \"zod\";\n\n// ─── Zod schemas ─────────────────────────────────────────────────────────────\n\nexport const HookEventSchema = z.enum([\"before_done\"]);\n\nexport const ConditionOperatorSchema = z.enum([\n \"file_exists\",\n \"file_contains\",\n \"env_var_set\",\n \"shell_returns_0\",\n]);\n\nexport const ConditionDefSchema = z.object({\n id: z.string().min(1),\n operator: ConditionOperatorSchema,\n path: z.string().optional(),\n contains: z.string().optional(),\n envVar: z.string().optional(),\n cmd: z.string().optional(),\n});\n\n/**\n * Per-item migration: handles legacy `trigger: { type, pattern }` → on/when\n * and legacy `manual:` field → `prompt:`.\n */\nfunction migrateLegacyCheckDef(raw: unknown): unknown {\n if (raw == null || typeof raw !== \"object\") return raw;\n const obj = raw as Record<string, unknown>;\n const result: Record<string, unknown> = { ...obj };\n\n // migrate trigger: { type, pattern } → on/when\n if (\"trigger\" in result && !(\"on\" in result) && !(\"when\" in result)) {\n const { trigger } = result;\n delete result.trigger;\n const t = trigger as Record<string, unknown>;\n if (t.type !== \"always\") {\n result.when = t.type === \"custom\" ? t.pattern : t.type;\n }\n }\n\n // migrate manual: → prompt:\n if (\"manual\" in result && !(\"prompt\" in result)) {\n result.prompt = result.manual;\n delete result.manual;\n }\n\n return result;\n}\n\n/**\n * Top-level migration: collapses ALL legacy array names into `checks:`.\n * Handles: deterministic, manual, task, prompt (any combination).\n * Existing `checks:` entries are preserved and come first.\n */\nfunction migrateLegacyConfig(raw: unknown): unknown {\n if (raw == null || typeof raw !== \"object\") return raw;\n const obj = raw as Record<string, unknown>;\n const result: Record<string, unknown> = { ...obj };\n\n const toArray = (key: string) => (Array.isArray(result[key]) ? (result[key] as unknown[]) : []);\n\n const merged = [\n ...toArray(\"checks\"),\n ...toArray(\"task\"),\n ...toArray(\"prompt\"),\n ...toArray(\"deterministic\"),\n ...toArray(\"manual\"),\n ].map(migrateLegacyCheckDef);\n\n if (\n \"checks\" in result ||\n \"task\" in result ||\n \"prompt\" in result ||\n \"deterministic\" in result ||\n \"manual\" in result\n ) {\n result.checks = merged;\n delete result.task;\n delete result.prompt;\n delete result.deterministic;\n delete result.manual;\n }\n\n return result;\n}\n\nexport const CheckDefSchema = z.preprocess(\n migrateLegacyCheckDef,\n z\n .object({\n id: z.string().min(1),\n label: z.string().min(1),\n on: HookEventSchema.optional(),\n when: z.string().optional(),\n cmd: z.string().optional(),\n prompt: z.string().optional(),\n conditionId: z.string().optional(),\n })\n .refine((c) => c.cmd !== undefined || c.prompt !== undefined, {\n message: \"A check must have either cmd (task) or prompt (agent instruction)\",\n }),\n);\n\nexport const HoldpointContextSchema = z.object({\n guides: z.record(z.string(), z.string()).default({}),\n});\n\n/** Built-in scope names that cannot be overridden by user-defined patterns. */\nconst BUILTIN_SCOPES = new Set([\n \"frontend\",\n \"backend\",\n \"socket\",\n \"visual\",\n \"python\",\n \"go\",\n \"rust\",\n \"java\",\n \"ruby\",\n \"database\",\n \"prisma\",\n \"testing\",\n \"infra\",\n \"ci\",\n \"docs\",\n \"structural\",\n]);\n\nconst EnginesConfigSchema = z\n .object({\n claude: z\n .object({\n stop_command: z.string().optional(),\n live_command: z.string().optional(),\n })\n .optional(),\n codex: z.object({ stop_command: z.string().optional() }).optional(),\n copilot: z.object({ check_command: z.string().optional() }).optional(),\n })\n .optional();\n\nexport const HoldpointConfigSchema = z.preprocess(\n migrateLegacyConfig,\n z\n .object({\n version: z.number().int().positive().default(1),\n context: HoldpointContextSchema.default({ guides: {} }),\n conditions: z.array(ConditionDefSchema).default([]),\n checks: z.array(CheckDefSchema).default([]),\n patterns: z.record(z.string(), z.string()).optional(),\n session_context_files: z.array(z.string()).optional(),\n engines: EnginesConfigSchema,\n })\n .superRefine((data, ctx) => {\n if (!data.patterns) return;\n for (const [key, value] of Object.entries(data.patterns)) {\n if (BUILTIN_SCOPES.has(key)) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `'${key}' is a built-in scope name and cannot be redefined in patterns`,\n path: [\"patterns\", key],\n });\n }\n try {\n new RegExp(value);\n } catch {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `Invalid regex in patterns.${key}: '${value}'`,\n path: [\"patterns\", key],\n });\n }\n }\n }),\n);\n"],"mappings":"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","names":[]}
package/package.json CHANGED
@@ -1,9 +1,8 @@
1
1
  {
2
2
  "name": "@holdpoint/yaml-core",
3
- "version": "0.1.0-alpha.0",
3
+ "version": "0.1.0-alpha.10",
4
4
  "publishConfig": {
5
- "access": "public",
6
- "tag": "alpha"
5
+ "access": "public"
7
6
  },
8
7
  "description": "Shared checks.yaml parser, validator, trigger matcher and runner",
9
8
  "homepage": "https://holdpoint.dev",
@@ -46,24 +45,24 @@
46
45
  "README.md",
47
46
  "LICENSE"
48
47
  ],
49
- "scripts": {
50
- "build": "tsup",
51
- "typecheck": "tsc --noEmit",
52
- "test": "vitest run",
53
- "test:watch": "vitest",
54
- "clean": "rm -rf dist *.tsbuildinfo"
55
- },
56
48
  "dependencies": {
57
- "@holdpoint/types": "workspace:*",
58
49
  "js-yaml": "^4.1.0",
59
50
  "minimatch": "^10.0.1",
60
- "zod": "^3.24.1"
51
+ "zod": "^4.4.3",
52
+ "@holdpoint/types": "0.1.0-alpha.9"
61
53
  },
62
54
  "devDependencies": {
63
55
  "@types/js-yaml": "^4.0.9",
64
- "@types/node": "^22.10.2",
56
+ "@types/node": "^25.9.1",
65
57
  "tsup": "^8.3.5",
66
- "typescript": "^5.7.2",
67
- "vitest": "^2.1.8"
58
+ "typescript": "^6.0.3",
59
+ "vitest": "^4.1.7"
60
+ },
61
+ "scripts": {
62
+ "build": "tsup",
63
+ "typecheck": "tsc --noEmit",
64
+ "test": "vitest run",
65
+ "test:watch": "vitest",
66
+ "clean": "rm -rf dist *.tsbuildinfo"
68
67
  }
69
- }
68
+ }