Commit 63671e3
authored
fix: writers emit tags as JSON array frontmatter (skill/command/subagent) (#202)
Mirrors the round-trip bug #200 caught for rule_writer: the DB reader for
skills, commands, and sub-agents deserialises the `tags` column via
`serde_json::from_str` (see `db/schema.rs:1727`, `:1860`, `:2009`), but
the three corresponding writers silently dropped the `tags` field from
frontmatter entirely. No live bug today — no scanner re-ingests these
primitives — but once scanners do (and given the asymmetry #200 closed,
that direction is likely), disk round-trip would either lose tags or, if
someone shipped a comma-joined stopgap, silently corrupt them.
Fixes:
- skill_writer::generate_skill_markdown emits `tags: <json>` when non-empty
- command_writer::generate_command_markdown emits `tags: <json>` when non-empty
- subagent_writer::generate_subagent_markdown emits `tags: <json>` when non-empty
Each writer gains two tests: one pinning the JSON-array shape, one pinning
the empty-vec skip path. Full `cargo test --lib` passes.
Not touched: `paths`, `allowed_tools`, `tools`, `skills`, `disallowed_tools`
in the same writers still use comma-joined form. They have the same latent
shape but are out of scope for this PR (would expand the diff; can land
separately once their scanners exist and decide on a canonical form).
Co-authored-by: Scot Campbell <prefrontalsys@users.noreply.github.com>1 parent 4b2a0fb commit 63671e3
3 files changed
Lines changed: 93 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
41 | 41 | | |
42 | 42 | | |
43 | 43 | | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
44 | 50 | | |
45 | 51 | | |
46 | 52 | | |
| |||
267 | 273 | | |
268 | 274 | | |
269 | 275 | | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
270 | 301 | | |
271 | 302 | | |
272 | 303 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
68 | 68 | | |
69 | 69 | | |
70 | 70 | | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
71 | 77 | | |
72 | 78 | | |
73 | 79 | | |
| |||
271 | 277 | | |
272 | 278 | | |
273 | 279 | | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
274 | 305 | | |
275 | 306 | | |
276 | 307 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
78 | 78 | | |
79 | 79 | | |
80 | 80 | | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
81 | 87 | | |
82 | 88 | | |
83 | 89 | | |
| |||
320 | 326 | | |
321 | 327 | | |
322 | 328 | | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
323 | 354 | | |
324 | 355 | | |
325 | 356 | | |
| |||
0 commit comments