open-wiki-spec 0.2.4 → 0.3.1

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 (252) hide show
  1. package/CHANGELOG.md +59 -0
  2. package/README.md +50 -3
  3. package/dist/cli/commands/apply.d.ts.map +1 -1
  4. package/dist/cli/commands/apply.js +96 -4
  5. package/dist/cli/commands/apply.js.map +1 -1
  6. package/dist/cli/commands/archive.d.ts.map +1 -1
  7. package/dist/cli/commands/archive.js +19 -5
  8. package/dist/cli/commands/archive.js.map +1 -1
  9. package/dist/cli/commands/bulk-archive.d.ts +15 -0
  10. package/dist/cli/commands/bulk-archive.d.ts.map +1 -0
  11. package/dist/cli/commands/bulk-archive.js +97 -0
  12. package/dist/cli/commands/bulk-archive.js.map +1 -0
  13. package/dist/cli/commands/continue.d.ts.map +1 -1
  14. package/dist/cli/commands/continue.js +15 -2
  15. package/dist/cli/commands/continue.js.map +1 -1
  16. package/dist/cli/commands/error-handler.d.ts +1 -5
  17. package/dist/cli/commands/error-handler.d.ts.map +1 -1
  18. package/dist/cli/commands/error-handler.js +48 -3
  19. package/dist/cli/commands/error-handler.js.map +1 -1
  20. package/dist/cli/commands/init.d.ts +0 -3
  21. package/dist/cli/commands/init.d.ts.map +1 -1
  22. package/dist/cli/commands/init.js +22 -4
  23. package/dist/cli/commands/init.js.map +1 -1
  24. package/dist/cli/commands/list.d.ts +2 -17
  25. package/dist/cli/commands/list.d.ts.map +1 -1
  26. package/dist/cli/commands/list.js +15 -3
  27. package/dist/cli/commands/list.js.map +1 -1
  28. package/dist/cli/commands/migrate.d.ts.map +1 -1
  29. package/dist/cli/commands/migrate.js +6 -9
  30. package/dist/cli/commands/migrate.js.map +1 -1
  31. package/dist/cli/commands/propose.d.ts.map +1 -1
  32. package/dist/cli/commands/propose.js +46 -6
  33. package/dist/cli/commands/propose.js.map +1 -1
  34. package/dist/cli/commands/query.d.ts.map +1 -1
  35. package/dist/cli/commands/query.js +99 -4
  36. package/dist/cli/commands/query.js.map +1 -1
  37. package/dist/cli/commands/retrieve.d.ts +7 -0
  38. package/dist/cli/commands/retrieve.d.ts.map +1 -0
  39. package/dist/cli/commands/retrieve.js +70 -0
  40. package/dist/cli/commands/retrieve.js.map +1 -0
  41. package/dist/cli/commands/revert.d.ts +18 -0
  42. package/dist/cli/commands/revert.d.ts.map +1 -0
  43. package/dist/cli/commands/revert.js +109 -0
  44. package/dist/cli/commands/revert.js.map +1 -0
  45. package/dist/cli/commands/status.d.ts +2 -19
  46. package/dist/cli/commands/status.d.ts.map +1 -1
  47. package/dist/cli/commands/status.js +42 -3
  48. package/dist/cli/commands/status.js.map +1 -1
  49. package/dist/cli/commands/verify.d.ts.map +1 -1
  50. package/dist/cli/commands/verify.js +12 -1
  51. package/dist/cli/commands/verify.js.map +1 -1
  52. package/dist/cli/index.d.ts.map +1 -1
  53. package/dist/cli/index.js +68 -2
  54. package/dist/cli/index.js.map +1 -1
  55. package/dist/cli/init/init-engine.d.ts.map +1 -1
  56. package/dist/cli/init/init-engine.js +19 -6
  57. package/dist/cli/init/init-engine.js.map +1 -1
  58. package/dist/cli/init/meta-files.d.ts +2 -1
  59. package/dist/cli/init/meta-files.d.ts.map +1 -1
  60. package/dist/cli/init/meta-files.js +167 -8
  61. package/dist/cli/init/meta-files.js.map +1 -1
  62. package/dist/cli/init/skill-generator.d.ts +3 -0
  63. package/dist/cli/init/skill-generator.d.ts.map +1 -1
  64. package/dist/cli/init/skill-generator.js +184 -3
  65. package/dist/cli/init/skill-generator.js.map +1 -1
  66. package/dist/cli/json-envelope.d.ts +15 -0
  67. package/dist/cli/json-envelope.d.ts.map +1 -0
  68. package/dist/cli/json-envelope.js +86 -0
  69. package/dist/cli/json-envelope.js.map +1 -0
  70. package/dist/cli/schema-check.d.ts +27 -0
  71. package/dist/cli/schema-check.d.ts.map +1 -0
  72. package/dist/cli/schema-check.js +33 -0
  73. package/dist/cli/schema-check.js.map +1 -0
  74. package/dist/cli/vault-discovery.d.ts.map +1 -1
  75. package/dist/cli/vault-discovery.js +16 -2
  76. package/dist/cli/vault-discovery.js.map +1 -1
  77. package/dist/core/embedding/cache.d.ts +12 -3
  78. package/dist/core/embedding/cache.d.ts.map +1 -1
  79. package/dist/core/embedding/cache.js +42 -5
  80. package/dist/core/embedding/cache.js.map +1 -1
  81. package/dist/core/embedding/embedder.d.ts +5 -1
  82. package/dist/core/embedding/embedder.d.ts.map +1 -1
  83. package/dist/core/embedding/embedder.js +78 -7
  84. package/dist/core/embedding/embedder.js.map +1 -1
  85. package/dist/core/index/build.d.ts.map +1 -1
  86. package/dist/core/index/build.js +54 -6
  87. package/dist/core/index/build.js.map +1 -1
  88. package/dist/core/index/resolve.d.ts.map +1 -1
  89. package/dist/core/index/resolve.js +27 -12
  90. package/dist/core/index/resolve.js.map +1 -1
  91. package/dist/core/index/scan.d.ts +10 -1
  92. package/dist/core/index/scan.d.ts.map +1 -1
  93. package/dist/core/index/scan.js +59 -10
  94. package/dist/core/index/scan.js.map +1 -1
  95. package/dist/core/index/schema-version.d.ts +28 -0
  96. package/dist/core/index/schema-version.d.ts.map +1 -1
  97. package/dist/core/index/schema-version.js +47 -0
  98. package/dist/core/index/schema-version.js.map +1 -1
  99. package/dist/core/migrate/change-converter.d.ts.map +1 -1
  100. package/dist/core/migrate/change-converter.js +52 -5
  101. package/dist/core/migrate/change-converter.js.map +1 -1
  102. package/dist/core/migrate/migrate.d.ts.map +1 -1
  103. package/dist/core/migrate/migrate.js +115 -1
  104. package/dist/core/migrate/migrate.js.map +1 -1
  105. package/dist/core/migrate/spec-converter.js +5 -0
  106. package/dist/core/migrate/spec-converter.js.map +1 -1
  107. package/dist/core/migrate/types.d.ts +9 -0
  108. package/dist/core/migrate/types.d.ts.map +1 -1
  109. package/dist/core/parser/frontmatter-parser.d.ts +0 -6
  110. package/dist/core/parser/frontmatter-parser.d.ts.map +1 -1
  111. package/dist/core/parser/frontmatter-parser.js +59 -2
  112. package/dist/core/parser/frontmatter-parser.js.map +1 -1
  113. package/dist/core/parser/requirement-parser.js +4 -0
  114. package/dist/core/parser/requirement-parser.js.map +1 -1
  115. package/dist/core/parser/task-parser.d.ts.map +1 -1
  116. package/dist/core/parser/task-parser.js +19 -0
  117. package/dist/core/parser/task-parser.js.map +1 -1
  118. package/dist/core/parser/wikilink-parser.d.ts.map +1 -1
  119. package/dist/core/parser/wikilink-parser.js +21 -5
  120. package/dist/core/parser/wikilink-parser.js.map +1 -1
  121. package/dist/core/retrieval/classify.d.ts +11 -4
  122. package/dist/core/retrieval/classify.d.ts.map +1 -1
  123. package/dist/core/retrieval/classify.js +76 -14
  124. package/dist/core/retrieval/classify.js.map +1 -1
  125. package/dist/core/retrieval/lexical.d.ts.map +1 -1
  126. package/dist/core/retrieval/lexical.js +31 -12
  127. package/dist/core/retrieval/lexical.js.map +1 -1
  128. package/dist/core/retrieval/retrieve.d.ts.map +1 -1
  129. package/dist/core/retrieval/retrieve.js +45 -5
  130. package/dist/core/retrieval/retrieve.js.map +1 -1
  131. package/dist/core/retrieval/scoring.d.ts.map +1 -1
  132. package/dist/core/retrieval/scoring.js +37 -12
  133. package/dist/core/retrieval/scoring.js.map +1 -1
  134. package/dist/core/schema/change.schema.d.ts.map +1 -1
  135. package/dist/core/schema/change.schema.js +6 -1
  136. package/dist/core/schema/change.schema.js.map +1 -1
  137. package/dist/core/schema/feature.schema.d.ts +1 -1
  138. package/dist/core/schema/feature.schema.d.ts.map +1 -1
  139. package/dist/core/schema/feature.schema.js +1 -0
  140. package/dist/core/schema/feature.schema.js.map +1 -1
  141. package/dist/core/schema/frontmatter.d.ts +15 -0
  142. package/dist/core/schema/frontmatter.d.ts.map +1 -1
  143. package/dist/core/schema/index.d.ts +15 -0
  144. package/dist/core/schema/index.d.ts.map +1 -1
  145. package/dist/core/schema/query.schema.d.ts +15 -0
  146. package/dist/core/schema/query.schema.d.ts.map +1 -1
  147. package/dist/core/schema/query.schema.js +5 -0
  148. package/dist/core/schema/query.schema.js.map +1 -1
  149. package/dist/core/schema/templates.d.ts +0 -4
  150. package/dist/core/schema/templates.d.ts.map +1 -1
  151. package/dist/core/schema/templates.js +25 -7
  152. package/dist/core/schema/templates.js.map +1 -1
  153. package/dist/core/sequencing/analyze.d.ts.map +1 -1
  154. package/dist/core/sequencing/analyze.js +3 -1
  155. package/dist/core/sequencing/analyze.js.map +1 -1
  156. package/dist/core/sequencing/priority-queue.d.ts +9 -3
  157. package/dist/core/sequencing/priority-queue.d.ts.map +1 -1
  158. package/dist/core/sequencing/priority-queue.js +10 -4
  159. package/dist/core/sequencing/priority-queue.js.map +1 -1
  160. package/dist/core/sequencing/stale-detector.d.ts.map +1 -1
  161. package/dist/core/sequencing/stale-detector.js +5 -0
  162. package/dist/core/sequencing/stale-detector.js.map +1 -1
  163. package/dist/core/workflow/apply/apply.d.ts.map +1 -1
  164. package/dist/core/workflow/apply/apply.js +429 -25
  165. package/dist/core/workflow/apply/apply.js.map +1 -1
  166. package/dist/core/workflow/apply/delta-parser.d.ts.map +1 -1
  167. package/dist/core/workflow/apply/delta-parser.js +43 -9
  168. package/dist/core/workflow/apply/delta-parser.js.map +1 -1
  169. package/dist/core/workflow/apply/feature-updater.d.ts.map +1 -1
  170. package/dist/core/workflow/apply/feature-updater.js +27 -11
  171. package/dist/core/workflow/apply/feature-updater.js.map +1 -1
  172. package/dist/core/workflow/apply/types.d.ts +9 -0
  173. package/dist/core/workflow/apply/types.d.ts.map +1 -1
  174. package/dist/core/workflow/continue/continue.d.ts +18 -0
  175. package/dist/core/workflow/continue/continue.d.ts.map +1 -1
  176. package/dist/core/workflow/continue/continue.js +134 -15
  177. package/dist/core/workflow/continue/continue.js.map +1 -1
  178. package/dist/core/workflow/continue/next-action.d.ts.map +1 -1
  179. package/dist/core/workflow/continue/next-action.js +16 -3
  180. package/dist/core/workflow/continue/next-action.js.map +1 -1
  181. package/dist/core/workflow/continue/types.d.ts +12 -0
  182. package/dist/core/workflow/continue/types.d.ts.map +1 -1
  183. package/dist/core/workflow/propose/note-creator.d.ts +2 -2
  184. package/dist/core/workflow/propose/note-creator.d.ts.map +1 -1
  185. package/dist/core/workflow/propose/note-creator.js +89 -12
  186. package/dist/core/workflow/propose/note-creator.js.map +1 -1
  187. package/dist/core/workflow/propose/propose.d.ts.map +1 -1
  188. package/dist/core/workflow/propose/propose.js +189 -47
  189. package/dist/core/workflow/propose/propose.js.map +1 -1
  190. package/dist/core/workflow/propose/query-normalizer.d.ts.map +1 -1
  191. package/dist/core/workflow/propose/query-normalizer.js +37 -5
  192. package/dist/core/workflow/propose/query-normalizer.js.map +1 -1
  193. package/dist/core/workflow/propose/types.d.ts +15 -0
  194. package/dist/core/workflow/propose/types.d.ts.map +1 -1
  195. package/dist/core/workflow/propose/types.js +6 -1
  196. package/dist/core/workflow/propose/types.js.map +1 -1
  197. package/dist/core/workflow/query/query-note-creator.js +4 -0
  198. package/dist/core/workflow/query/query-note-creator.js.map +1 -1
  199. package/dist/core/workflow/verify/coherence.d.ts +10 -0
  200. package/dist/core/workflow/verify/coherence.d.ts.map +1 -1
  201. package/dist/core/workflow/verify/coherence.js +91 -4
  202. package/dist/core/workflow/verify/coherence.js.map +1 -1
  203. package/dist/core/workflow/verify/completeness.d.ts +1 -1
  204. package/dist/core/workflow/verify/completeness.d.ts.map +1 -1
  205. package/dist/core/workflow/verify/completeness.js +53 -10
  206. package/dist/core/workflow/verify/completeness.js.map +1 -1
  207. package/dist/core/workflow/verify/correctness.d.ts +1 -1
  208. package/dist/core/workflow/verify/correctness.d.ts.map +1 -1
  209. package/dist/core/workflow/verify/correctness.js +95 -14
  210. package/dist/core/workflow/verify/correctness.js.map +1 -1
  211. package/dist/core/workflow/verify/vault-integrity.d.ts +11 -0
  212. package/dist/core/workflow/verify/vault-integrity.d.ts.map +1 -1
  213. package/dist/core/workflow/verify/vault-integrity.js +80 -3
  214. package/dist/core/workflow/verify/vault-integrity.js.map +1 -1
  215. package/dist/core/workflow/verify/verify.d.ts +0 -5
  216. package/dist/core/workflow/verify/verify.d.ts.map +1 -1
  217. package/dist/core/workflow/verify/verify.js +54 -3
  218. package/dist/core/workflow/verify/verify.js.map +1 -1
  219. package/dist/index.d.ts +13 -0
  220. package/dist/index.d.ts.map +1 -1
  221. package/dist/index.js +11 -0
  222. package/dist/index.js.map +1 -1
  223. package/dist/types/cli-contracts.d.ts +78 -0
  224. package/dist/types/cli-contracts.d.ts.map +1 -0
  225. package/dist/types/cli-contracts.js +2 -0
  226. package/dist/types/cli-contracts.js.map +1 -0
  227. package/dist/types/error-codes.d.ts +25 -0
  228. package/dist/types/error-codes.d.ts.map +1 -0
  229. package/dist/types/error-codes.js +27 -0
  230. package/dist/types/error-codes.js.map +1 -0
  231. package/dist/types/frontmatter.d.ts +9 -2
  232. package/dist/types/frontmatter.d.ts.map +1 -1
  233. package/dist/types/next-action.d.ts +21 -0
  234. package/dist/types/next-action.d.ts.map +1 -1
  235. package/dist/types/retrieval.d.ts +17 -0
  236. package/dist/types/retrieval.d.ts.map +1 -1
  237. package/dist/types/verify.d.ts +58 -1
  238. package/dist/types/verify.d.ts.map +1 -1
  239. package/dist/types/verify.js +58 -1
  240. package/dist/types/verify.js.map +1 -1
  241. package/dist/utils/conventions.d.ts +9 -0
  242. package/dist/utils/conventions.d.ts.map +1 -0
  243. package/dist/utils/conventions.js +22 -0
  244. package/dist/utils/conventions.js.map +1 -0
  245. package/dist/utils/id-generator.d.ts.map +1 -1
  246. package/dist/utils/id-generator.js +8 -0
  247. package/dist/utils/id-generator.js.map +1 -1
  248. package/dist/utils/normalize.d.ts +7 -4
  249. package/dist/utils/normalize.d.ts.map +1 -1
  250. package/dist/utils/normalize.js +43 -6
  251. package/dist/utils/normalize.js.map +1 -1
  252. package/package.json +3 -2
@@ -2,13 +2,22 @@
2
2
  * Scaffolding functions for creating new notes with proper structure.
3
3
  * Used by init and workflow commands.
4
4
  */
5
+ /**
6
+ * Escape a value for inclusion in a YAML double-quoted string.
7
+ * Handles backslashes and embedded double quotes to prevent injection.
8
+ */
9
+ function escapeYamlString(value) {
10
+ return value.replace(/\\/g, '\\\\').replace(/"/g, '\\"');
11
+ }
5
12
  export function scaffoldFeature(id, title, systemRef) {
13
+ const safeId = escapeYamlString(id);
14
+ const safeSystemRef = escapeYamlString(systemRef);
6
15
  return `---
7
16
  type: feature
8
- id: ${id}
17
+ id: ${safeId}
9
18
  status: active
10
19
  systems:
11
- - "[[${systemRef}]]"
20
+ - "[[${safeSystemRef}]]"
12
21
  sources: []
13
22
  decisions: []
14
23
  changes: []
@@ -43,21 +52,30 @@ The system SHALL <normative statement>.
43
52
  - WHEN <condition>
44
53
  - THEN <expected outcome>
45
54
 
55
+ ## Change Log
56
+
57
+ | Date | Change | Summary |
58
+ |------|--------|---------|
59
+
46
60
  ## Related Notes
47
61
  `;
48
62
  }
49
63
  export function scaffoldChange(id, title, featureRef, systemRef, createdAt) {
64
+ const safeFeatureRef = escapeYamlString(featureRef);
65
+ const safeSystemRef = escapeYamlString(systemRef);
66
+ const safeCreatedAt = escapeYamlString(createdAt);
67
+ const safeId = escapeYamlString(id);
50
68
  return `---
51
69
  type: change
52
- id: ${id}
70
+ id: ${safeId}
53
71
  status: proposed
54
- created_at: "${createdAt}"
55
- feature: "[[${featureRef}]]"
72
+ created_at: "${safeCreatedAt}"
73
+ feature: "[[${safeFeatureRef}]]"
56
74
  depends_on: []
57
75
  touches:
58
- - "[[${featureRef}]]"
76
+ - "[[${safeFeatureRef}]]"
59
77
  systems:
60
- - "[[${systemRef}]]"
78
+ - "[[${safeSystemRef}]]"
61
79
  sources: []
62
80
  decisions: []
63
81
  tags:
@@ -1 +1 @@
1
- {"version":3,"file":"templates.js","sourceRoot":"","sources":["../../../src/core/schema/templates.ts"],"names":[],"mappings":"AAEA;;;GAGG;AAEH,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,KAAa,EAAE,SAAiB;IAC1E,OAAO;;MAEH,EAAE;;;SAGC,SAAS;;;;;;;;aAQL,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4BjB,CAAC;AACF,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,EAAU,EACV,KAAa,EACb,UAAkB,EAClB,SAAiB,EACjB,SAAiB;IAEjB,OAAO;;MAEH,EAAE;;eAEO,SAAS;cACV,UAAU;;;SAGf,UAAU;;SAEV,SAAS;;;;;;;YAON,KAAK;;;;;;;oCAOmB,UAAU;;;;;;;;;;;;;;;;;;;;;;;;CAwB7C,CAAC;AACF,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAU,EAAE,KAAa;IACtD,OAAO;;MAEH,EAAE;;;;;;YAMI,KAAK;;;;;;;;;;;;;;;;;;;CAmBhB,CAAC;AACF,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAU,EAAE,KAAa;IACxD,OAAO;;MAEH,EAAE;;;;;;;;cAQM,KAAK;;;;;;;;;;;;;;;;;;;CAmBlB,CAAC;AACF,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAU,EAAE,KAAa;IACtD,OAAO;;MAEH,EAAE;;;;;;;YAOI,KAAK;;;;;;;;;;;CAWhB,CAAC;AACF,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,EAAU,EAAE,KAAa;IACrD,OAAO;;MAEH,EAAE;;;;;;WAMG,KAAK;;;;;;;;;;;;;;;CAef,CAAC;AACF,CAAC;AAED,yDAAyD;AACzD,MAAM,CAAC,MAAM,iBAAiB,GAAoD;IAChF,OAAO,EAAE,eAAe;IACxB,MAAM,EAAE,cAAc;IACtB,MAAM,EAAE,cAAc;IACtB,QAAQ,EAAE,gBAAgB;IAC1B,MAAM,EAAE,cAAc;IACtB,KAAK,EAAE,aAAa;CACrB,CAAC"}
1
+ {"version":3,"file":"templates.js","sourceRoot":"","sources":["../../../src/core/schema/templates.ts"],"names":[],"mappings":"AAEA;;;GAGG;AAEH;;;GAGG;AACH,SAAS,gBAAgB,CAAC,KAAa;IACrC,OAAO,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;AAC3D,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,KAAa,EAAE,SAAiB;IAC1E,MAAM,MAAM,GAAG,gBAAgB,CAAC,EAAE,CAAC,CAAC;IACpC,MAAM,aAAa,GAAG,gBAAgB,CAAC,SAAS,CAAC,CAAC;IAClD,OAAO;;MAEH,MAAM;;;SAGH,aAAa;;;;;;;;aAQT,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAiCjB,CAAC;AACF,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,EAAU,EACV,KAAa,EACb,UAAkB,EAClB,SAAiB,EACjB,SAAiB;IAEjB,MAAM,cAAc,GAAG,gBAAgB,CAAC,UAAU,CAAC,CAAC;IACpD,MAAM,aAAa,GAAG,gBAAgB,CAAC,SAAS,CAAC,CAAC;IAClD,MAAM,aAAa,GAAG,gBAAgB,CAAC,SAAS,CAAC,CAAC;IAClD,MAAM,MAAM,GAAG,gBAAgB,CAAC,EAAE,CAAC,CAAC;IACpC,OAAO;;MAEH,MAAM;;eAEG,aAAa;cACd,cAAc;;;SAGnB,cAAc;;SAEd,aAAa;;;;;;;YAOV,KAAK;;;;;;;oCAOmB,UAAU;;;;;;;;;;;;;;;;;;;;;;;;CAwB7C,CAAC;AACF,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAU,EAAE,KAAa;IACtD,OAAO;;MAEH,EAAE;;;;;;YAMI,KAAK;;;;;;;;;;;;;;;;;;;CAmBhB,CAAC;AACF,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAU,EAAE,KAAa;IACxD,OAAO;;MAEH,EAAE;;;;;;;;cAQM,KAAK;;;;;;;;;;;;;;;;;;;CAmBlB,CAAC;AACF,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAU,EAAE,KAAa;IACtD,OAAO;;MAEH,EAAE;;;;;;;YAOI,KAAK;;;;;;;;;;;CAWhB,CAAC;AACF,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,EAAU,EAAE,KAAa;IACrD,OAAO;;MAEH,EAAE;;;;;;WAMG,KAAK;;;;;;;;;;;;;;;CAef,CAAC;AACF,CAAC;AAED,yDAAyD;AACzD,MAAM,CAAC,MAAM,iBAAiB,GAAoD;IAChF,OAAO,EAAE,eAAe;IACxB,MAAM,EAAE,cAAc;IACtB,MAAM,EAAE,cAAc;IACtB,QAAQ,EAAE,gBAAgB;IAC1B,MAAM,EAAE,cAAc;IACtB,KAAK,EAAE,aAAa;CACrB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"analyze.d.ts","sourceRoot":"","sources":["../../../src/core/sequencing/analyze.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,KAAK,EACV,gBAAgB,EAIjB,MAAM,2BAA2B,CAAC;AACnC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AASlE;;;GAGG;AACH,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,GAC9B,gBAAgB,CAgGlB;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,gBAAgB,GAAG,iBAAiB,CAMjF"}
1
+ {"version":3,"file":"analyze.d.ts","sourceRoot":"","sources":["../../../src/core/sequencing/analyze.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,KAAK,EACV,gBAAgB,EAIjB,MAAM,2BAA2B,CAAC;AACnC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AASlE;;;GAGG;AACH,wBAAgB,iBAAiB,CAC/B,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,GAC9B,gBAAgB,CAkGlB;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,gBAAgB,GAAG,iBAAiB,CAMjF"}
@@ -42,11 +42,13 @@ export function analyzeSequencing(index) {
42
42
  }
43
43
  // 6. Compute overall status (worst severity)
44
44
  // Precedence: conflict_critical > blocked > conflict_candidate > needs_review > parallel_safe
45
+ // Dependency cycles escalate to `blocked` (highest severity below
46
+ // requirement_conflicts) because a cycle makes any progression impossible.
45
47
  let overallStatus = 'parallel_safe';
46
48
  if (requirement_conflicts.length > 0) {
47
49
  overallStatus = 'conflict_critical';
48
50
  }
49
- else if (pairwise_severities.some((s) => s.severity === 'blocked')) {
51
+ else if (cycles.length > 0 || pairwise_severities.some((s) => s.severity === 'blocked')) {
50
52
  overallStatus = 'blocked';
51
53
  }
52
54
  else if (pairwise_severities.some((s) => s.severity === 'conflict_candidate')) {
@@ -1 +1 @@
1
- {"version":3,"file":"analyze.js","sourceRoot":"","sources":["../../../src/core/sequencing/analyze.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"analyze.js","sourceRoot":"","sources":["../../../src/core/sequencing/analyze.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,12 @@
1
1
  /**
2
- * Simple priority queue using a sorted array with a custom comparator.
2
+ * Simple priority queue using a deferred-sort array with a custom comparator.
3
3
  * Used for deterministic tiebreaking in topological sort: (created_at, change_id).
4
+ *
5
+ * Sort is deferred until `drainAll()` because the only consumer uses
6
+ * snapshot semantics — it drains everything at the current depth before
7
+ * calling push() again. Sorting on every push would make the whole topo
8
+ * sort O(V² log V) per depth level, blowing up on large (1000+) change
9
+ * graphs. Deferring collapses it to O(V log V) amortized.
4
10
  */
5
11
  export declare class PriorityQueue<T> {
6
12
  private items;
@@ -10,8 +16,8 @@ export declare class PriorityQueue<T> {
10
16
  get isEmpty(): boolean;
11
17
  get size(): number;
12
18
  /**
13
- * Snapshot semantics: removes and returns ALL items currently in the queue.
14
- * Items added after this call are NOT included.
19
+ * Snapshot semantics: removes and returns ALL items currently in the queue,
20
+ * sorted by the comparator. Items added after this call are NOT included.
15
21
  */
16
22
  drainAll(): T[];
17
23
  }
@@ -1 +1 @@
1
- {"version":3,"file":"priority-queue.d.ts","sourceRoot":"","sources":["../../../src/core/sequencing/priority-queue.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,qBAAa,aAAa,CAAC,CAAC;IAC1B,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,SAAS,CAAyB;gBAE9B,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,MAAM;IAI7C,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI;IAKnB,IAAI,OAAO,IAAI,OAAO,CAErB;IAED,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED;;;OAGG;IACH,QAAQ,IAAI,CAAC,EAAE;CAKhB"}
1
+ {"version":3,"file":"priority-queue.d.ts","sourceRoot":"","sources":["../../../src/core/sequencing/priority-queue.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AACH,qBAAa,aAAa,CAAC,CAAC;IAC1B,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,SAAS,CAAyB;gBAE9B,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,MAAM;IAI7C,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI;IAInB,IAAI,OAAO,IAAI,OAAO,CAErB;IAED,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED;;;OAGG;IACH,QAAQ,IAAI,CAAC,EAAE;CAMhB"}
@@ -1,6 +1,12 @@
1
1
  /**
2
- * Simple priority queue using a sorted array with a custom comparator.
2
+ * Simple priority queue using a deferred-sort array with a custom comparator.
3
3
  * Used for deterministic tiebreaking in topological sort: (created_at, change_id).
4
+ *
5
+ * Sort is deferred until `drainAll()` because the only consumer uses
6
+ * snapshot semantics — it drains everything at the current depth before
7
+ * calling push() again. Sorting on every push would make the whole topo
8
+ * sort O(V² log V) per depth level, blowing up on large (1000+) change
9
+ * graphs. Deferring collapses it to O(V log V) amortized.
4
10
  */
5
11
  export class PriorityQueue {
6
12
  items = [];
@@ -10,7 +16,6 @@ export class PriorityQueue {
10
16
  }
11
17
  push(item) {
12
18
  this.items.push(item);
13
- this.items.sort(this.compareFn);
14
19
  }
15
20
  get isEmpty() {
16
21
  return this.items.length === 0;
@@ -19,12 +24,13 @@ export class PriorityQueue {
19
24
  return this.items.length;
20
25
  }
21
26
  /**
22
- * Snapshot semantics: removes and returns ALL items currently in the queue.
23
- * Items added after this call are NOT included.
27
+ * Snapshot semantics: removes and returns ALL items currently in the queue,
28
+ * sorted by the comparator. Items added after this call are NOT included.
24
29
  */
25
30
  drainAll() {
26
31
  const snapshot = this.items;
27
32
  this.items = [];
33
+ snapshot.sort(this.compareFn);
28
34
  return snapshot;
29
35
  }
30
36
  }
@@ -1 +1 @@
1
- {"version":3,"file":"priority-queue.js","sourceRoot":"","sources":["../../../src/core/sequencing/priority-queue.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,MAAM,OAAO,aAAa;IAChB,KAAK,GAAQ,EAAE,CAAC;IAChB,SAAS,CAAyB;IAE1C,YAAY,SAAiC;QAC3C,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC7B,CAAC;IAED,IAAI,CAAC,IAAO;QACV,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAClC,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAC3B,CAAC;IAED;;;OAGG;IACH,QAAQ;QACN,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC;QAC5B,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF"}
1
+ {"version":3,"file":"priority-queue.js","sourceRoot":"","sources":["../../../src/core/sequencing/priority-queue.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AACH,MAAM,OAAO,aAAa;IAChB,KAAK,GAAQ,EAAE,CAAC;IAChB,SAAS,CAAyB;IAE1C,YAAY,SAAiC;QAC3C,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC7B,CAAC;IAED,IAAI,CAAC,IAAO;QACV,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAC3B,CAAC;IAED;;;OAGG;IACH,QAAQ;QACN,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC;QAC5B,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC9B,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"stale-detector.d.ts","sourceRoot":"","sources":["../../../src/core/sequencing/stale-detector.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAEhE;;;;GAIG;AACH,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,WAAW,EACnB,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,GAC9B,cAAc,EAAE,CA8ClB"}
1
+ {"version":3,"file":"stale-detector.d.ts","sourceRoot":"","sources":["../../../src/core/sequencing/stale-detector.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAEhE;;;;GAIG;AACH,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,WAAW,EACnB,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,WAAW,CAAC,GAC9B,cAAc,EAAE,CAmDlB"}
@@ -12,6 +12,11 @@ export function checkBaseFingerprints(change, index) {
12
12
  // Missing fingerprint: verify will report separately
13
13
  if (entry.base_fingerprint === null)
14
14
  continue;
15
+ // Special migration marker: "migrated" means the base fingerprint
16
+ // was not available at migration time. Skip stale detection so
17
+ // migrated vaults don't emit false positive warnings.
18
+ if (entry.base_fingerprint === 'migrated')
19
+ continue;
15
20
  const featureRecord = index.get(entry.target_note_id);
16
21
  // Broken reference: reported by verify
17
22
  if (!featureRecord)
@@ -1 +1 @@
1
- {"version":3,"file":"stale-detector.js","sourceRoot":"","sources":["../../../src/core/sequencing/stale-detector.ts"],"names":[],"mappings":"AAGA;;;;GAIG;AACH,MAAM,UAAU,qBAAqB,CACnC,MAAmB,EACnB,KAA+B;IAE/B,MAAM,YAAY,GAAqB,EAAE,CAAC;IAE1C,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,aAAa,EAAE,CAAC;QACzC,+BAA+B;QAC/B,IAAI,KAAK,CAAC,EAAE,KAAK,OAAO;YAAE,SAAS;QAEnC,qDAAqD;QACrD,IAAI,KAAK,CAAC,gBAAgB,KAAK,IAAI;YAAE,SAAS;QAE9C,MAAM,aAAa,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;QACtD,uCAAuC;QACvC,IAAI,CAAC,aAAa;YAAE,SAAS;QAE7B,2DAA2D;QAC3D,MAAM,MAAM,GAAG,GAAG,KAAK,CAAC,cAAc,KAAK,KAAK,CAAC,WAAW,EAAE,CAAC;QAC/D,MAAM,UAAU,GAAG,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,MAAM,CAAC,CAAC;QAE5E,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,uCAAuC;YACvC,IAAI,KAAK,CAAC,EAAE,KAAK,UAAU,IAAI,KAAK,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;gBACtD,YAAY,CAAC,IAAI,CAAC;oBAChB,SAAS,EAAE,MAAM,CAAC,EAAE;oBACpB,WAAW,EAAE,KAAK;oBAClB,aAAa,EAAE,KAAK,CAAC,gBAAgB;oBACrC,WAAW,EAAE,SAAS;oBACtB,UAAU,EAAE,KAAK,CAAC,cAAc;oBAChC,eAAe,EAAE,MAAM;iBACxB,CAAC,CAAC;YACL,CAAC;YACD,SAAS;QACX,CAAC;QAED,IAAI,UAAU,CAAC,YAAY,KAAK,KAAK,CAAC,gBAAgB,EAAE,CAAC;YACvD,YAAY,CAAC,IAAI,CAAC;gBAChB,SAAS,EAAE,MAAM,CAAC,EAAE;gBACpB,WAAW,EAAE,KAAK;gBAClB,aAAa,EAAE,KAAK,CAAC,gBAAgB;gBACrC,WAAW,EAAE,UAAU,CAAC,YAAY;gBACpC,UAAU,EAAE,KAAK,CAAC,cAAc;gBAChC,eAAe,EAAE,MAAM;aACxB,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO,YAAY,CAAC;AACtB,CAAC"}
1
+ {"version":3,"file":"stale-detector.js","sourceRoot":"","sources":["../../../src/core/sequencing/stale-detector.ts"],"names":[],"mappings":"AAGA;;;;GAIG;AACH,MAAM,UAAU,qBAAqB,CACnC,MAAmB,EACnB,KAA+B;IAE/B,MAAM,YAAY,GAAqB,EAAE,CAAC;IAE1C,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,aAAa,EAAE,CAAC;QACzC,+BAA+B;QAC/B,IAAI,KAAK,CAAC,EAAE,KAAK,OAAO;YAAE,SAAS;QAEnC,qDAAqD;QACrD,IAAI,KAAK,CAAC,gBAAgB,KAAK,IAAI;YAAE,SAAS;QAE9C,kEAAkE;QAClE,+DAA+D;QAC/D,sDAAsD;QACtD,IAAI,KAAK,CAAC,gBAAgB,KAAK,UAAU;YAAE,SAAS;QAEpD,MAAM,aAAa,GAAG,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;QACtD,uCAAuC;QACvC,IAAI,CAAC,aAAa;YAAE,SAAS;QAE7B,2DAA2D;QAC3D,MAAM,MAAM,GAAG,GAAG,KAAK,CAAC,cAAc,KAAK,KAAK,CAAC,WAAW,EAAE,CAAC;QAC/D,MAAM,UAAU,GAAG,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,MAAM,CAAC,CAAC;QAE5E,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,uCAAuC;YACvC,IAAI,KAAK,CAAC,EAAE,KAAK,UAAU,IAAI,KAAK,CAAC,EAAE,KAAK,SAAS,EAAE,CAAC;gBACtD,YAAY,CAAC,IAAI,CAAC;oBAChB,SAAS,EAAE,MAAM,CAAC,EAAE;oBACpB,WAAW,EAAE,KAAK;oBAClB,aAAa,EAAE,KAAK,CAAC,gBAAgB;oBACrC,WAAW,EAAE,SAAS;oBACtB,UAAU,EAAE,KAAK,CAAC,cAAc;oBAChC,eAAe,EAAE,MAAM;iBACxB,CAAC,CAAC;YACL,CAAC;YACD,SAAS;QACX,CAAC;QAED,IAAI,UAAU,CAAC,YAAY,KAAK,KAAK,CAAC,gBAAgB,EAAE,CAAC;YACvD,YAAY,CAAC,IAAI,CAAC;gBAChB,SAAS,EAAE,MAAM,CAAC,EAAE;gBACpB,WAAW,EAAE,KAAK;gBAClB,aAAa,EAAE,KAAK,CAAC,gBAAgB;gBACrC,WAAW,EAAE,UAAU,CAAC,YAAY;gBACpC,UAAU,EAAE,KAAK,CAAC,cAAc;gBAChC,eAAe,EAAE,MAAM;aACxB,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO,YAAY,CAAC;AACtB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"apply.d.ts","sourceRoot":"","sources":["../../../../src/core/workflow/apply/apply.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,YAAY,EACZ,WAAW,EACX,SAAS,EAOT,cAAc,EACd,aAAa,EACd,MAAM,YAAY,CAAC;AACpB,OAAO,KAAK,EAAE,UAAU,EAAe,MAAM,gCAAgC,CAAC;AA2G9E;;;;;;;;GAQG;AACH,wBAAgB,WAAW,CACzB,OAAO,EAAE,YAAY,EACrB,KAAK,EAAE,UAAU,EACjB,IAAI,EAAE,SAAS,GACd,WAAW,CAuZb;AAED;;GAEG;AACH,wBAAgB,aAAa,CAC3B,OAAO,EAAE,cAAc,EACvB,KAAK,EAAE,UAAU,EACjB,IAAI,EAAE,SAAS,GACd,aAAa,CA0Cf"}
1
+ {"version":3,"file":"apply.d.ts","sourceRoot":"","sources":["../../../../src/core/workflow/apply/apply.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,YAAY,EACZ,WAAW,EACX,SAAS,EAOT,cAAc,EACd,aAAa,EACd,MAAM,YAAY,CAAC;AACpB,OAAO,KAAK,EAAE,UAAU,EAAe,MAAM,gCAAgC,CAAC;AAgL9E;;;;;;;;GAQG;AACH,wBAAgB,WAAW,CACzB,OAAO,EAAE,YAAY,EACrB,KAAK,EAAE,UAAU,EACjB,IAAI,EAAE,SAAS,GACd,WAAW,CAgoBb;AAED;;GAEG;AACH,wBAAgB,aAAa,CAC3B,OAAO,EAAE,cAAc,EACvB,KAAK,EAAE,UAAU,EACjB,IAAI,EAAE,SAAS,GACd,aAAa,CA0Cf"}