xtrm-tools 0.5.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 (333) hide show
  1. package/CHANGELOG.md +504 -0
  2. package/README.md +201 -0
  3. package/cli/dist/index.cjs +57378 -0
  4. package/cli/dist/index.cjs.map +1 -0
  5. package/cli/dist/index.d.cts +2 -0
  6. package/cli/package.json +47 -0
  7. package/config/.env.example +40 -0
  8. package/config/hooks.json +72 -0
  9. package/config/instructions/agents-top.md +30 -0
  10. package/config/instructions/claude-top.md +30 -0
  11. package/config/mcp_servers.json +57 -0
  12. package/config/mcp_servers_optional.json +53 -0
  13. package/config/pi/auth.json.template +14 -0
  14. package/config/pi/extensions/auto-session-name/index.ts +29 -0
  15. package/config/pi/extensions/auto-session-name/package.json +16 -0
  16. package/config/pi/extensions/auto-update/index.ts +71 -0
  17. package/config/pi/extensions/auto-update/package.json +16 -0
  18. package/config/pi/extensions/beads/index.ts +166 -0
  19. package/config/pi/extensions/beads/package.json +16 -0
  20. package/config/pi/extensions/bg-process/index.ts +230 -0
  21. package/config/pi/extensions/bg-process/package.json +16 -0
  22. package/config/pi/extensions/compact-header/index.ts +69 -0
  23. package/config/pi/extensions/compact-header/package.json +16 -0
  24. package/config/pi/extensions/core/adapter.ts +52 -0
  25. package/config/pi/extensions/core/guard-rules.ts +102 -0
  26. package/config/pi/extensions/core/lib.ts +3 -0
  27. package/config/pi/extensions/core/logger.ts +45 -0
  28. package/config/pi/extensions/core/runner.ts +71 -0
  29. package/config/pi/extensions/core/session-state.ts +59 -0
  30. package/config/pi/extensions/custom-footer/index.ts +160 -0
  31. package/config/pi/extensions/custom-footer/package.json +16 -0
  32. package/config/pi/extensions/custom-provider-qwen-cli/index.ts +363 -0
  33. package/config/pi/extensions/custom-provider-qwen-cli/package.json +1 -0
  34. package/config/pi/extensions/git-checkpoint/index.ts +53 -0
  35. package/config/pi/extensions/git-checkpoint/package.json +16 -0
  36. package/config/pi/extensions/minimal-mode/index.ts +201 -0
  37. package/config/pi/extensions/minimal-mode/package.json +16 -0
  38. package/config/pi/extensions/plan-mode/README.md +65 -0
  39. package/config/pi/extensions/plan-mode/index.ts +417 -0
  40. package/config/pi/extensions/plan-mode/package.json +12 -0
  41. package/config/pi/extensions/plan-mode/utils.ts +324 -0
  42. package/config/pi/extensions/quality-gates/index.ts +67 -0
  43. package/config/pi/extensions/quality-gates/package.json +16 -0
  44. package/config/pi/extensions/service-skills/index.ts +108 -0
  45. package/config/pi/extensions/service-skills/package.json +16 -0
  46. package/config/pi/extensions/session-flow/index.ts +131 -0
  47. package/config/pi/extensions/session-flow/package.json +16 -0
  48. package/config/pi/extensions/todo/index.ts +299 -0
  49. package/config/pi/extensions/todo/package.json +16 -0
  50. package/config/pi/extensions/xtrm-loader/index.ts +89 -0
  51. package/config/pi/extensions/xtrm-loader/package.json +16 -0
  52. package/config/pi/install-schema.json +44 -0
  53. package/config/pi/models.json.template +76 -0
  54. package/config/pi/pi-worktrees-settings.json +6 -0
  55. package/config/pi/settings.json.template +16 -0
  56. package/config/settings.json +70 -0
  57. package/hooks/README.md +75 -0
  58. package/hooks/agent_context.py +105 -0
  59. package/hooks/beads-claim-sync.mjs +166 -0
  60. package/hooks/beads-commit-gate.mjs +55 -0
  61. package/hooks/beads-compact-restore.mjs +69 -0
  62. package/hooks/beads-compact-save.mjs +51 -0
  63. package/hooks/beads-edit-gate.mjs +45 -0
  64. package/hooks/beads-gate-core.mjs +215 -0
  65. package/hooks/beads-gate-messages.mjs +87 -0
  66. package/hooks/beads-gate-utils.mjs +185 -0
  67. package/hooks/beads-memory-gate.mjs +61 -0
  68. package/hooks/beads-stop-gate.mjs +32 -0
  69. package/hooks/branch-state.mjs +39 -0
  70. package/hooks/gitnexus/gitnexus-hook.cjs +222 -0
  71. package/hooks/guard-rules.mjs +118 -0
  72. package/hooks/hooks.json +116 -0
  73. package/hooks/main-guard-post-push.mjs +71 -0
  74. package/hooks/main-guard.mjs +119 -0
  75. package/hooks/quality-check.cjs +1286 -0
  76. package/hooks/quality-check.py +345 -0
  77. package/hooks/serena-workflow-reminder.py +74 -0
  78. package/package.json +77 -0
  79. package/project-skills/quality-gates/.claude/hooks/hook-config.json +66 -0
  80. package/project-skills/quality-gates/.claude/hooks/quality-check.cjs +1286 -0
  81. package/project-skills/quality-gates/.claude/hooks/quality-check.py +334 -0
  82. package/project-skills/quality-gates/.claude/settings.json +3 -0
  83. package/project-skills/quality-gates/.claude/skills/using-quality-gates/SKILL.md +254 -0
  84. package/project-skills/quality-gates/README.md +109 -0
  85. package/project-skills/quality-gates/evals/evals.json +181 -0
  86. package/project-skills/quality-gates/workspace/iteration-1/FINAL-EVAL-SUMMARY.md +75 -0
  87. package/project-skills/quality-gates/workspace/iteration-1/edge-case-auto-fix-verification/with_skill/outputs/response.md +59 -0
  88. package/project-skills/quality-gates/workspace/iteration-1/edge-case-mixed-language-project/with_skill/outputs/response.md +60 -0
  89. package/project-skills/quality-gates/workspace/iteration-1/eval-summary.md +105 -0
  90. package/project-skills/quality-gates/workspace/iteration-1/partial-install-python-only/with_skill/outputs/response.md +93 -0
  91. package/project-skills/quality-gates/workspace/iteration-1/python-refactor-request/with_skill/outputs/response.md +104 -0
  92. package/project-skills/quality-gates/workspace/iteration-1/quality-gate-error-fix/with_skill/outputs/response.md +74 -0
  93. package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-general-chat/with_skill/outputs/response.md +18 -0
  94. package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-math-question/with_skill/outputs/response.md +18 -0
  95. package/project-skills/quality-gates/workspace/iteration-1/should-not-trigger-unrelated-coding/with_skill/outputs/response.md +56 -0
  96. package/project-skills/quality-gates/workspace/iteration-1/tdd-guard-blocking-confusion/with_skill/outputs/response.md +67 -0
  97. package/project-skills/quality-gates/workspace/iteration-1/typescript-feature-with-tests/with_skill/outputs/response.md +97 -0
  98. package/project-skills/service-skills-set/.claude/git-hooks/doc_reminder.py +67 -0
  99. package/project-skills/service-skills-set/.claude/git-hooks/skill_staleness.py +194 -0
  100. package/project-skills/service-skills-set/.claude/service-registry.json +4 -0
  101. package/project-skills/service-skills-set/.claude/settings.json +37 -0
  102. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/SKILL.md +433 -0
  103. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/references/script_quality_standards.md +425 -0
  104. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/references/service_skill_system_guide.md +278 -0
  105. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/bootstrap.py +308 -0
  106. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/deep_dive.py +304 -0
  107. package/project-skills/service-skills-set/.claude/skills/creating-service-skills/scripts/scaffolder.py +482 -0
  108. package/project-skills/service-skills-set/.claude/skills/scoping-service-skills/SKILL.md +231 -0
  109. package/project-skills/service-skills-set/.claude/skills/scoping-service-skills/scripts/scope.py +74 -0
  110. package/project-skills/service-skills-set/.claude/skills/updating-service-skills/SKILL.md +136 -0
  111. package/project-skills/service-skills-set/.claude/skills/updating-service-skills/scripts/drift_detector.py +222 -0
  112. package/project-skills/service-skills-set/.claude/skills/using-service-skills/SKILL.md +108 -0
  113. package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/cataloger.py +74 -0
  114. package/project-skills/service-skills-set/.claude/skills/using-service-skills/scripts/skill_activator.py +152 -0
  115. package/project-skills/service-skills-set/README.md +93 -0
  116. package/project-skills/service-skills-set/install-service-skills.py +193 -0
  117. package/project-skills/service-skills-set/service-skills-readme.md +236 -0
  118. package/skills/README.txt +31 -0
  119. package/skills/clean-code/SKILL.md +201 -0
  120. package/skills/creating-service-skills/SKILL.md +433 -0
  121. package/skills/creating-service-skills/references/script_quality_standards.md +425 -0
  122. package/skills/creating-service-skills/references/service_skill_system_guide.md +278 -0
  123. package/skills/creating-service-skills/scripts/bootstrap.py +326 -0
  124. package/skills/creating-service-skills/scripts/deep_dive.py +304 -0
  125. package/skills/creating-service-skills/scripts/scaffolder.py +482 -0
  126. package/skills/delegating/SKILL.md +196 -0
  127. package/skills/delegating/config.yaml +210 -0
  128. package/skills/delegating/references/orchestration-protocols.md +41 -0
  129. package/skills/docker-expert/SKILL.md +409 -0
  130. package/skills/documenting/CHANGELOG.md +23 -0
  131. package/skills/documenting/README.md +148 -0
  132. package/skills/documenting/SKILL.md +113 -0
  133. package/skills/documenting/examples/example_pattern.md +70 -0
  134. package/skills/documenting/examples/example_reference.md +70 -0
  135. package/skills/documenting/examples/example_ssot_analytics.md +64 -0
  136. package/skills/documenting/examples/example_workflow.md +141 -0
  137. package/skills/documenting/references/changelog-format.md +97 -0
  138. package/skills/documenting/references/metadata-schema.md +136 -0
  139. package/skills/documenting/references/taxonomy.md +81 -0
  140. package/skills/documenting/references/versioning-rules.md +78 -0
  141. package/skills/documenting/scripts/bump_version.sh +60 -0
  142. package/skills/documenting/scripts/changelog/__init__.py +0 -0
  143. package/skills/documenting/scripts/changelog/add_entry.py +216 -0
  144. package/skills/documenting/scripts/changelog/bump_release.py +117 -0
  145. package/skills/documenting/scripts/changelog/init_changelog.py +54 -0
  146. package/skills/documenting/scripts/changelog/validate_changelog.py +128 -0
  147. package/skills/documenting/scripts/drift_detector.py +266 -0
  148. package/skills/documenting/scripts/generate_template.py +311 -0
  149. package/skills/documenting/scripts/list_by_category.sh +84 -0
  150. package/skills/documenting/scripts/orchestrator.py +255 -0
  151. package/skills/documenting/scripts/validate_metadata.py +242 -0
  152. package/skills/documenting/templates/CHANGELOG.md.template +13 -0
  153. package/skills/find-skills/SKILL.md +133 -0
  154. package/skills/gitnexus-debugging/SKILL.md +85 -0
  155. package/skills/gitnexus-exploring/SKILL.md +75 -0
  156. package/skills/gitnexus-impact-analysis/SKILL.md +94 -0
  157. package/skills/gitnexus-refactoring/SKILL.md +113 -0
  158. package/skills/hook-development/SKILL.md +797 -0
  159. package/skills/hook-development/examples/load-context.sh +55 -0
  160. package/skills/hook-development/examples/quality-check.js +1168 -0
  161. package/skills/hook-development/examples/validate-bash.sh +43 -0
  162. package/skills/hook-development/examples/validate-write.sh +38 -0
  163. package/skills/hook-development/references/advanced.md +527 -0
  164. package/skills/hook-development/references/migration.md +369 -0
  165. package/skills/hook-development/references/patterns.md +412 -0
  166. package/skills/hook-development/scripts/README.md +164 -0
  167. package/skills/hook-development/scripts/hook-linter.sh +153 -0
  168. package/skills/hook-development/scripts/test-hook.sh +252 -0
  169. package/skills/hook-development/scripts/validate-hook-schema.sh +159 -0
  170. package/skills/obsidian-cli/SKILL.md +106 -0
  171. package/skills/orchestrating-agents/SKILL.md +135 -0
  172. package/skills/orchestrating-agents/config.yaml +45 -0
  173. package/skills/orchestrating-agents/references/agent-context-integration.md +37 -0
  174. package/skills/orchestrating-agents/references/examples.md +45 -0
  175. package/skills/orchestrating-agents/references/handover-protocol.md +31 -0
  176. package/skills/orchestrating-agents/references/workflows.md +42 -0
  177. package/skills/orchestrating-agents/scripts/detect_neighbors.py +23 -0
  178. package/skills/prompt-improving/README.md +162 -0
  179. package/skills/prompt-improving/SKILL.md +74 -0
  180. package/skills/prompt-improving/references/analysis_commands.md +24 -0
  181. package/skills/prompt-improving/references/chain_of_thought.md +24 -0
  182. package/skills/prompt-improving/references/mcp_definitions.md +20 -0
  183. package/skills/prompt-improving/references/multishot.md +23 -0
  184. package/skills/prompt-improving/references/xml_core.md +60 -0
  185. package/skills/python-testing/SKILL.md +815 -0
  186. package/skills/scoping-service-skills/SKILL.md +231 -0
  187. package/skills/scoping-service-skills/scripts/scope.py +74 -0
  188. package/skills/senior-backend/SKILL.md +209 -0
  189. package/skills/senior-backend/references/api_design_patterns.md +103 -0
  190. package/skills/senior-backend/references/backend_security_practices.md +103 -0
  191. package/skills/senior-backend/references/database_optimization_guide.md +103 -0
  192. package/skills/senior-backend/scripts/api_load_tester.py +114 -0
  193. package/skills/senior-backend/scripts/api_scaffolder.py +114 -0
  194. package/skills/senior-backend/scripts/database_migration_tool.py +114 -0
  195. package/skills/senior-data-scientist/SKILL.md +226 -0
  196. package/skills/senior-data-scientist/references/experiment_design_frameworks.md +80 -0
  197. package/skills/senior-data-scientist/references/feature_engineering_patterns.md +80 -0
  198. package/skills/senior-data-scientist/references/statistical_methods_advanced.md +80 -0
  199. package/skills/senior-data-scientist/scripts/experiment_designer.py +100 -0
  200. package/skills/senior-data-scientist/scripts/feature_engineering_pipeline.py +100 -0
  201. package/skills/senior-data-scientist/scripts/model_evaluation_suite.py +100 -0
  202. package/skills/senior-devops/SKILL.md +209 -0
  203. package/skills/senior-devops/references/cicd_pipeline_guide.md +103 -0
  204. package/skills/senior-devops/references/deployment_strategies.md +103 -0
  205. package/skills/senior-devops/references/infrastructure_as_code.md +103 -0
  206. package/skills/senior-devops/scripts/deployment_manager.py +114 -0
  207. package/skills/senior-devops/scripts/pipeline_generator.py +114 -0
  208. package/skills/senior-devops/scripts/terraform_scaffolder.py +114 -0
  209. package/skills/senior-security/SKILL.md +209 -0
  210. package/skills/senior-security/references/cryptography_implementation.md +103 -0
  211. package/skills/senior-security/references/penetration_testing_guide.md +103 -0
  212. package/skills/senior-security/references/security_architecture_patterns.md +103 -0
  213. package/skills/senior-security/scripts/pentest_automator.py +114 -0
  214. package/skills/senior-security/scripts/security_auditor.py +114 -0
  215. package/skills/senior-security/scripts/threat_modeler.py +114 -0
  216. package/skills/skill-creator/LICENSE.txt +202 -0
  217. package/skills/skill-creator/SKILL.md +479 -0
  218. package/skills/skill-creator/agents/analyzer.md +274 -0
  219. package/skills/skill-creator/agents/comparator.md +202 -0
  220. package/skills/skill-creator/agents/grader.md +223 -0
  221. package/skills/skill-creator/assets/eval_review.html +146 -0
  222. package/skills/skill-creator/eval-viewer/generate_review.py +471 -0
  223. package/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  224. package/skills/skill-creator/references/schemas.md +430 -0
  225. package/skills/skill-creator/scripts/__init__.py +0 -0
  226. package/skills/skill-creator/scripts/aggregate_benchmark.py +401 -0
  227. package/skills/skill-creator/scripts/generate_report.py +326 -0
  228. package/skills/skill-creator/scripts/improve_description.py +248 -0
  229. package/skills/skill-creator/scripts/package_skill.py +136 -0
  230. package/skills/skill-creator/scripts/quick_validate.py +103 -0
  231. package/skills/skill-creator/scripts/run_eval.py +310 -0
  232. package/skills/skill-creator/scripts/run_loop.py +332 -0
  233. package/skills/skill-creator/scripts/utils.py +47 -0
  234. package/skills/sync-docs/SKILL.md +132 -0
  235. package/skills/sync-docs/evals/evals.json +89 -0
  236. package/skills/sync-docs/references/doc-structure.md +99 -0
  237. package/skills/sync-docs/references/schema.md +103 -0
  238. package/skills/sync-docs/scripts/changelog/add_entry.py +216 -0
  239. package/skills/sync-docs/scripts/context_gatherer.py +240 -0
  240. package/skills/sync-docs/scripts/doc_structure_analyzer.py +495 -0
  241. package/skills/sync-docs/scripts/drift_detector.py +327 -0
  242. package/skills/sync-docs/scripts/validate_doc.py +365 -0
  243. package/skills/sync-docs/scripts/validate_metadata.py +185 -0
  244. package/skills/sync-docs-workspace/iteration-1/benchmark.json +293 -0
  245. package/skills/sync-docs-workspace/iteration-1/benchmark.md +13 -0
  246. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/eval_metadata.json +27 -0
  247. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/outputs/result.md +210 -0
  248. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/grading.json +28 -0
  249. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/with_skill/run-1/timing.json +1 -0
  250. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/outputs/result.md +101 -0
  251. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/grading.json +28 -0
  252. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/run-1/timing.json +5 -0
  253. package/skills/sync-docs-workspace/iteration-1/eval-doc-audit/without_skill/timing.json +5 -0
  254. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/eval_metadata.json +27 -0
  255. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/outputs/result.md +198 -0
  256. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/grading.json +28 -0
  257. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/with_skill/run-1/timing.json +1 -0
  258. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/outputs/result.md +94 -0
  259. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/grading.json +28 -0
  260. package/skills/sync-docs-workspace/iteration-1/eval-fix-mode/without_skill/run-1/timing.json +1 -0
  261. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/eval_metadata.json +27 -0
  262. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/outputs/result.md +237 -0
  263. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/grading.json +28 -0
  264. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/with_skill/run-1/timing.json +1 -0
  265. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/outputs/result.md +134 -0
  266. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/grading.json +28 -0
  267. package/skills/sync-docs-workspace/iteration-1/eval-sprint-closeout/without_skill/run-1/timing.json +1 -0
  268. package/skills/sync-docs-workspace/iteration-2/benchmark.json +297 -0
  269. package/skills/sync-docs-workspace/iteration-2/benchmark.md +13 -0
  270. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/eval_metadata.json +27 -0
  271. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/outputs/result.md +137 -0
  272. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/grading.json +92 -0
  273. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/with_skill/run-1/timing.json +1 -0
  274. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/outputs/result.md +134 -0
  275. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/grading.json +86 -0
  276. package/skills/sync-docs-workspace/iteration-2/eval-doc-audit/without_skill/run-1/timing.json +1 -0
  277. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/eval_metadata.json +27 -0
  278. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/outputs/result.md +193 -0
  279. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/grading.json +72 -0
  280. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/with_skill/run-1/timing.json +1 -0
  281. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/outputs/result.md +211 -0
  282. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/grading.json +91 -0
  283. package/skills/sync-docs-workspace/iteration-2/eval-fix-mode/without_skill/run-1/timing.json +5 -0
  284. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/eval_metadata.json +27 -0
  285. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/outputs/result.md +182 -0
  286. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/grading.json +95 -0
  287. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/with_skill/run-1/timing.json +1 -0
  288. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/outputs/result.md +222 -0
  289. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/grading.json +88 -0
  290. package/skills/sync-docs-workspace/iteration-2/eval-sprint-closeout/without_skill/run-1/timing.json +5 -0
  291. package/skills/sync-docs-workspace/iteration-3/benchmark.json +298 -0
  292. package/skills/sync-docs-workspace/iteration-3/benchmark.md +13 -0
  293. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/eval_metadata.json +27 -0
  294. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/outputs/result.md +125 -0
  295. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/grading.json +97 -0
  296. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/with_skill/run-1/timing.json +5 -0
  297. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/outputs/result.md +144 -0
  298. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/grading.json +78 -0
  299. package/skills/sync-docs-workspace/iteration-3/eval-doc-audit/without_skill/run-1/timing.json +5 -0
  300. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/eval_metadata.json +27 -0
  301. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/outputs/result.md +104 -0
  302. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/grading.json +91 -0
  303. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/with_skill/run-1/timing.json +5 -0
  304. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/outputs/result.md +79 -0
  305. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/grading.json +82 -0
  306. package/skills/sync-docs-workspace/iteration-3/eval-fix-mode/without_skill/run-1/timing.json +5 -0
  307. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/eval_metadata.json +27 -0
  308. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase1_context.json +302 -0
  309. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase2_drift.txt +33 -0
  310. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase3_analysis.json +114 -0
  311. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase4_fix.txt +118 -0
  312. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/phase5_validate.txt +38 -0
  313. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/outputs/result.md +158 -0
  314. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/grading.json +95 -0
  315. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/with_skill/run-1/timing.json +5 -0
  316. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/outputs/result.md +71 -0
  317. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/grading.json +90 -0
  318. package/skills/sync-docs-workspace/iteration-3/eval-sprint-closeout/without_skill/run-1/timing.json +5 -0
  319. package/skills/test-planning/SKILL.md +208 -0
  320. package/skills/test-planning/evals/evals.json +23 -0
  321. package/skills/updating-service-skills/SKILL.md +136 -0
  322. package/skills/updating-service-skills/scripts/drift_detector.py +222 -0
  323. package/skills/using-TDD/SKILL.md +410 -0
  324. package/skills/using-quality-gates/SKILL.md +254 -0
  325. package/skills/using-serena-lsp/README.md +8 -0
  326. package/skills/using-serena-lsp/REFERENCE.md +194 -0
  327. package/skills/using-serena-lsp/SKILL.md +82 -0
  328. package/skills/using-service-skills/SKILL.md +108 -0
  329. package/skills/using-service-skills/scripts/cataloger.py +74 -0
  330. package/skills/using-service-skills/scripts/skill_activator.py +152 -0
  331. package/skills/using-service-skills/scripts/test_skill_activator.py +58 -0
  332. package/skills/using-xtrm/SKILL.md +245 -0
  333. package/skills/xt-end/SKILL.md +128 -0
@@ -0,0 +1,185 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Validate docs/ markdown metadata compliance.
4
+
5
+ Checks frontmatter schema for docs/*.md files and regenerates INDEX tables.
6
+ Runs as a local sync-docs validator (no external skill dependencies).
7
+ """
8
+
9
+ import sys
10
+ import re
11
+ from pathlib import Path
12
+
13
+ try:
14
+ import yaml
15
+ except ImportError:
16
+ yaml = None
17
+
18
+ REQUIRED_FIELDS = ["title", "scope", "category", "version", "updated"]
19
+ VALID_CATEGORIES = {"reference", "guide", "architecture", "api", "plan", "overview"}
20
+
21
+
22
+ def extract_headings(content: str) -> list[tuple[str, str]]:
23
+ results = []
24
+ lines = content.splitlines()
25
+ i = 0
26
+ while i < len(lines):
27
+ line = lines[i]
28
+ if line.startswith("## ") and not line.startswith("### "):
29
+ heading = line[3:].strip()
30
+ summary = ""
31
+ j = i + 1
32
+ in_code = False
33
+ while j < len(lines):
34
+ text = lines[j].strip()
35
+ if text.startswith("```"):
36
+ in_code = not in_code
37
+ j += 1
38
+ continue
39
+ if not in_code and text and not text.startswith("#") and not text.startswith("|") and not text.startswith("-"):
40
+ summary = text.split(".")[0].strip()[:120]
41
+ break
42
+ j += 1
43
+ results.append((heading, summary))
44
+ i += 1
45
+ return results
46
+
47
+
48
+ def generate_index_table(headings: list[tuple[str, str]]) -> str:
49
+ rows = ["| Section | Summary |", "|---|---|"]
50
+ for heading, summary in headings:
51
+ anchor = heading.lower()
52
+ for ch in "/()":
53
+ anchor = anchor.replace(ch, "")
54
+ anchor = re.sub(r"[\s_]+", "-", anchor)
55
+ anchor = re.sub(r"-+", "-", anchor).strip("-")
56
+ rows.append(f"| [{heading}](#{anchor}) | {summary or '_no summary_'} |")
57
+ return "\n".join(rows) + "\n"
58
+
59
+
60
+ def inject_index(content: str, table: str) -> str:
61
+ header = "<!-- INDEX: auto-generated by validate_metadata.py — do not edit manually -->\n"
62
+ footer = "<!-- END INDEX -->"
63
+ block = f"{header}{table}{footer}"
64
+
65
+ existing = re.search(r"<!-- INDEX:.*?-->.*?<!-- END INDEX -->", content, re.DOTALL)
66
+ if existing:
67
+ return content[: existing.start()] + block + content[existing.end() :]
68
+
69
+ fm_match = re.match(r"^(---\n.*?\n---\n)(.*)", content, re.DOTALL)
70
+ if fm_match:
71
+ return fm_match.group(1) + "\n" + block + "\n" + fm_match.group(2)
72
+
73
+ return block + "\n" + content
74
+
75
+
76
+ def extract_frontmatter(content: str) -> dict:
77
+ match = re.match(r"^---\n(.*?)\n---\n", content, re.DOTALL)
78
+ if not match:
79
+ return {}
80
+
81
+ raw = match.group(1)
82
+ if yaml is not None:
83
+ try:
84
+ return yaml.safe_load(raw) or {}
85
+ except Exception:
86
+ return {}
87
+
88
+ data = {}
89
+ for line in raw.splitlines():
90
+ if ":" in line:
91
+ key, value = line.split(":", 1)
92
+ data[key.strip()] = value.strip().strip('"')
93
+ return data
94
+
95
+
96
+ def validate_semver(value: str) -> bool:
97
+ return bool(re.match(r"^\d+\.\d+\.\d+$", str(value)))
98
+
99
+
100
+ def validate_date(value: str) -> bool:
101
+ return bool(re.match(r"^\d{4}-\d{2}-\d{2}$", str(value)))
102
+
103
+
104
+ def validate_metadata_file(path: Path) -> bool:
105
+ if not path.exists():
106
+ print(f"ERROR: File not found: {path}")
107
+ return False
108
+
109
+ content = path.read_text(encoding="utf-8")
110
+ fm = extract_frontmatter(content)
111
+
112
+ errors = []
113
+ warnings = []
114
+
115
+ if not fm:
116
+ errors.append("Missing or invalid YAML frontmatter")
117
+ else:
118
+ missing = [k for k in REQUIRED_FIELDS if k not in fm]
119
+ if missing:
120
+ errors.append(f"Missing required fields: {', '.join(missing)}")
121
+
122
+ if "category" in fm and fm["category"] not in VALID_CATEGORIES:
123
+ errors.append(
124
+ f"Invalid category '{fm['category']}'. Valid: {', '.join(sorted(VALID_CATEGORIES))}"
125
+ )
126
+
127
+ if "version" in fm and not validate_semver(str(fm["version"])):
128
+ errors.append(f"Invalid version format: {fm['version']} (expected x.y.z)")
129
+
130
+ if "updated" in fm and not validate_date(str(fm["updated"])):
131
+ errors.append(f"Invalid updated format: {fm['updated']} (expected YYYY-MM-DD)")
132
+
133
+ if "source_of_truth_for" in fm and not isinstance(fm["source_of_truth_for"], list):
134
+ warnings.append("source_of_truth_for should be a list")
135
+
136
+ print(f"Validating: {path}")
137
+ if errors:
138
+ print("\n❌ ERRORS:")
139
+ for error in errors:
140
+ print(f" - {error}")
141
+ if warnings:
142
+ print("\n⚠️ WARNINGS:")
143
+ for warning in warnings:
144
+ print(f" - {warning}")
145
+ if not errors and not warnings:
146
+ print("\n✅ VALID: All checks passed!")
147
+
148
+ headings = extract_headings(content)
149
+ if headings:
150
+ table = generate_index_table(headings)
151
+ updated_content = inject_index(content, table)
152
+ if updated_content != content:
153
+ path.write_text(updated_content, encoding="utf-8")
154
+ print(" ✏️ INDEX regenerated.")
155
+
156
+ return not errors
157
+
158
+
159
+ def iter_targets(target: Path) -> list[Path]:
160
+ if target.is_dir():
161
+ return sorted(target.rglob("*.md"))
162
+ return [target]
163
+
164
+
165
+ def main() -> None:
166
+ if len(sys.argv) < 2:
167
+ print("Usage: validate_metadata.py <docs-file-or-directory>")
168
+ sys.exit(1)
169
+
170
+ target = Path(sys.argv[1])
171
+ paths = iter_targets(target)
172
+ if not paths:
173
+ print(f"No markdown files found at: {target}")
174
+ sys.exit(1)
175
+
176
+ all_ok = True
177
+ for path in paths:
178
+ if not validate_metadata_file(path):
179
+ all_ok = False
180
+
181
+ sys.exit(0 if all_ok else 1)
182
+
183
+
184
+ if __name__ == "__main__":
185
+ main()
@@ -0,0 +1,293 @@
1
+ {
2
+ "metadata": {
3
+ "skill_name": "sync-docs",
4
+ "skill_path": "<path/to/skill>",
5
+ "executor_model": "<model-name>",
6
+ "analyzer_model": "<model-name>",
7
+ "timestamp": "2026-03-18T07:43:29Z",
8
+ "evals_run": [
9
+ 1,
10
+ 2,
11
+ 3
12
+ ],
13
+ "runs_per_configuration": 3
14
+ },
15
+ "runs": [
16
+ {
17
+ "eval_id": 3,
18
+ "configuration": "with_skill",
19
+ "run_number": 1,
20
+ "result": {
21
+ "pass_rate": 0.75,
22
+ "passed": 3,
23
+ "failed": 1,
24
+ "total": 4,
25
+ "time_seconds": 0.0,
26
+ "tokens": 0,
27
+ "tool_calls": 0,
28
+ "errors": 0
29
+ },
30
+ "expectations": [
31
+ {
32
+ "text": "Ran doc_structure_analyzer.py and referenced its structured output",
33
+ "passed": true,
34
+ "evidence": "Ran doc_structure_analyzer.py, quoted its full structured output including EXTRACTABLE status, extraction candidates list, MISSING files, and INVALID_SCHEMA count."
35
+ },
36
+ {
37
+ "text": "Named specific README sections with their suggested docs/ destination",
38
+ "passed": true,
39
+ "evidence": "Named: '## Policy System \u2192 docs/policies.md', '## MCP Servers \u2192 docs/mcp-servers.md', pi-extensions.md, plus context about CHANGELOG 6-day gap."
40
+ },
41
+ {
42
+ "text": "Report is actionable \u2014 tells user exactly what to do next, not just observations",
43
+ "passed": true,
44
+ "evidence": "Report includes structured phase output, specific file names, notes CHANGELOG gap with exact dates, and references the 6-day staleness."
45
+ },
46
+ {
47
+ "text": "Did not edit or create any files (audit only)",
48
+ "passed": false,
49
+ "evidence": "Agent ran --fix (created docs/pi-extensions.md, docs/mcp-servers.md, docs/policies.md) despite task being audit-only. Skill instructions for Phase 3 show the --fix command without making clear it is only for execute mode."
50
+ }
51
+ ],
52
+ "notes": []
53
+ },
54
+ {
55
+ "eval_id": 2,
56
+ "configuration": "with_skill",
57
+ "run_number": 1,
58
+ "result": {
59
+ "pass_rate": 0.75,
60
+ "passed": 3,
61
+ "failed": 1,
62
+ "total": 4,
63
+ "time_seconds": 0.0,
64
+ "tokens": 0,
65
+ "tool_calls": 0,
66
+ "errors": 0
67
+ },
68
+ "expectations": [
69
+ {
70
+ "text": "Ran doc_structure_analyzer.py with --fix flag",
71
+ "passed": true,
72
+ "evidence": "Ran `python3 skills/sync-docs/scripts/doc_structure_analyzer.py --fix --bd-remember` and included full output"
73
+ },
74
+ {
75
+ "text": "Ran with --bd-remember or manually ran bd remember with a summary",
76
+ "passed": true,
77
+ "evidence": "bd remember stored with key 'sync-docs-fix-2026-03-18', confirmed stored:true in output JSON"
78
+ },
79
+ {
80
+ "text": "At least one scaffold file was created in docs/",
81
+ "passed": true,
82
+ "evidence": "Created docs/pi-extensions.md, docs/mcp-servers.md, docs/policies.md with valid frontmatter"
83
+ },
84
+ {
85
+ "text": "Ran validate_doc.py on created files to confirm schema",
86
+ "passed": false,
87
+ "evidence": "Report notes 7 INVALID_SCHEMA files exist but does not show validate_doc.py being run explicitly to confirm the 3 new files pass. Only the JSON output showing valid frontmatter is evidence."
88
+ }
89
+ ],
90
+ "notes": []
91
+ },
92
+ {
93
+ "eval_id": 1,
94
+ "configuration": "with_skill",
95
+ "run_number": 1,
96
+ "result": {
97
+ "pass_rate": 1.0,
98
+ "passed": 4,
99
+ "failed": 0,
100
+ "total": 4,
101
+ "time_seconds": 0.0,
102
+ "tokens": 0,
103
+ "tool_calls": 0,
104
+ "errors": 0
105
+ },
106
+ "expectations": [
107
+ {
108
+ "text": "Ran context_gatherer.py and reported bd closed issues or merged PRs from the output",
109
+ "passed": true,
110
+ "evidence": "Ran context_gatherer.py, reported 20 bd closed issues with IDs and titles, 3 merged PRs with SHAs and dates, 15 recent commits"
111
+ },
112
+ {
113
+ "text": "Ran doc_structure_analyzer.py and used its output to identify doc issues",
114
+ "passed": true,
115
+ "evidence": "Ran doc_structure_analyzer.py, referenced MISSING status for docs/pi-extensions.md, hooks.md, mcp-servers.md, policies.md, skills.md and EXTRACTABLE for README"
116
+ },
117
+ {
118
+ "text": "Produced at least one concrete recommendation or action (not just a vague summary)",
119
+ "passed": true,
120
+ "evidence": "Named specific files: docs/pi-extensions.md, docs/hooks.md, docs/mcp-servers.md, docs/policies.md with explicit next steps for each"
121
+ },
122
+ {
123
+ "text": "Used the skill scripts rather than just reading files manually",
124
+ "passed": true,
125
+ "evidence": "Ran 3 scripts (context_gatherer.py, drift_detector.py, doc_structure_analyzer.py) with explicit output included in report"
126
+ }
127
+ ],
128
+ "notes": []
129
+ },
130
+ {
131
+ "eval_id": 3,
132
+ "configuration": "without_skill",
133
+ "run_number": 1,
134
+ "result": {
135
+ "pass_rate": 0.75,
136
+ "passed": 3,
137
+ "failed": 1,
138
+ "total": 4,
139
+ "time_seconds": 72.5,
140
+ "tokens": 21934,
141
+ "tool_calls": 0,
142
+ "errors": 0
143
+ },
144
+ "expectations": [
145
+ {
146
+ "text": "Ran doc_structure_analyzer.py and referenced its structured output",
147
+ "passed": false,
148
+ "evidence": "Did not run doc_structure_analyzer.py. All findings came from manual README.md reads with line numbers."
149
+ },
150
+ {
151
+ "text": "Named specific README sections with their suggested docs/ destination",
152
+ "passed": true,
153
+ "evidence": "Named 6 specific sections with line numbers: Hooks Reference (114-141)\u2192docs/hooks.md, Policy System (66-87)\u2192new docs/policies.md, MCP Servers (143-158)\u2192docs/mcp.md, CLI Commands (89-111)\u2192XTRM-GUIDE.md, Version History (179-188)\u2192remove, Plugin Structure (52-63)\u2192borderline."
154
+ },
155
+ {
156
+ "text": "Report is actionable \u2014 tells user exactly what to do next, not just observations",
157
+ "passed": true,
158
+ "evidence": "Each section has a specific Recommendation: block with exact action (Remove section, Add single link, Create docs/policies.md, etc.). Estimated README would shrink from 193 to 60-70 lines."
159
+ },
160
+ {
161
+ "text": "Did not edit or create any files (audit only)",
162
+ "passed": true,
163
+ "evidence": "Report explicitly states no files were modified. Audit-only as instructed."
164
+ }
165
+ ],
166
+ "notes": []
167
+ },
168
+ {
169
+ "eval_id": 2,
170
+ "configuration": "without_skill",
171
+ "run_number": 1,
172
+ "result": {
173
+ "pass_rate": 1.0,
174
+ "passed": 4,
175
+ "failed": 0,
176
+ "total": 4,
177
+ "time_seconds": 0.0,
178
+ "tokens": 0,
179
+ "tool_calls": 0,
180
+ "errors": 0
181
+ },
182
+ "expectations": [
183
+ {
184
+ "text": "Ran doc_structure_analyzer.py with --fix flag",
185
+ "passed": true,
186
+ "evidence": "Agent found the skill in the repo and ran doc_structure_analyzer.py --fix. However, found no MISSING gaps because with_skill run had already created those files (confounded test)."
187
+ },
188
+ {
189
+ "text": "Ran with --bd-remember or manually ran bd remember with a summary",
190
+ "passed": true,
191
+ "evidence": "Agent ran bd remember with key 'sync-docs-fix-schema-2026-03-18' summarizing the frontmatter additions made to 7 files."
192
+ },
193
+ {
194
+ "text": "At least one scaffold file was created in docs/",
195
+ "passed": true,
196
+ "evidence": "Added YAML frontmatter to 7 existing docs/ files (hooks.md, mcp.md, pre-install-cleanup.md, project-skills.md, skills.md, testing.md, todo.md). Different action than creating scaffolds but valid given scaffolds already existed."
197
+ },
198
+ {
199
+ "text": "Ran validate_doc.py on created files to confirm schema",
200
+ "passed": true,
201
+ "evidence": "Ran validate_doc.py docs/ \u2014 7/7 files passed after frontmatter additions."
202
+ }
203
+ ],
204
+ "notes": []
205
+ },
206
+ {
207
+ "eval_id": 1,
208
+ "configuration": "without_skill",
209
+ "run_number": 1,
210
+ "result": {
211
+ "pass_rate": 0.25,
212
+ "passed": 1,
213
+ "failed": 3,
214
+ "total": 4,
215
+ "time_seconds": 0.0,
216
+ "tokens": 0,
217
+ "tool_calls": 0,
218
+ "errors": 0
219
+ },
220
+ "expectations": [
221
+ {
222
+ "text": "Ran context_gatherer.py and reported bd closed issues or merged PRs from the output",
223
+ "passed": false,
224
+ "evidence": "Did not run context_gatherer.py. Used git log manually. Reported 'No .beads/ DB was found' which is wrong \u2014 .beads/ exists. Missed all 20 closed bd issues."
225
+ },
226
+ {
227
+ "text": "Ran doc_structure_analyzer.py and used its output to identify doc issues",
228
+ "passed": false,
229
+ "evidence": "Did not run doc_structure_analyzer.py. Manually read README.md, package.json, and CHANGELOG.md."
230
+ },
231
+ {
232
+ "text": "Produced at least one concrete recommendation or action (not just a vague summary)",
233
+ "passed": true,
234
+ "evidence": "Found version mismatch (2.3.0 vs 2.4.1 in package.json), identified 7 undocumented branch commits in CHANGELOG, named specific line references."
235
+ },
236
+ {
237
+ "text": "Used the skill scripts rather than just reading files manually",
238
+ "passed": false,
239
+ "evidence": "No skill scripts were used. All findings came from manual git log, file reads, and README inspection."
240
+ }
241
+ ],
242
+ "notes": []
243
+ }
244
+ ],
245
+ "run_summary": {
246
+ "with_skill": {
247
+ "pass_rate": {
248
+ "mean": 0.8333,
249
+ "stddev": 0.1443,
250
+ "min": 0.75,
251
+ "max": 1.0
252
+ },
253
+ "time_seconds": {
254
+ "mean": 0.0,
255
+ "stddev": 0.0,
256
+ "min": 0.0,
257
+ "max": 0.0
258
+ },
259
+ "tokens": {
260
+ "mean": 0.0,
261
+ "stddev": 0.0,
262
+ "min": 0,
263
+ "max": 0
264
+ }
265
+ },
266
+ "without_skill": {
267
+ "pass_rate": {
268
+ "mean": 0.6667,
269
+ "stddev": 0.3819,
270
+ "min": 0.25,
271
+ "max": 1.0
272
+ },
273
+ "time_seconds": {
274
+ "mean": 24.1667,
275
+ "stddev": 41.8579,
276
+ "min": 0.0,
277
+ "max": 72.5
278
+ },
279
+ "tokens": {
280
+ "mean": 7311.3333,
281
+ "stddev": 12663.6008,
282
+ "min": 0,
283
+ "max": 21934
284
+ }
285
+ },
286
+ "delta": {
287
+ "pass_rate": "+0.17",
288
+ "time_seconds": "-24.2",
289
+ "tokens": "-7311"
290
+ }
291
+ },
292
+ "notes": []
293
+ }
@@ -0,0 +1,13 @@
1
+ # Skill Benchmark: sync-docs
2
+
3
+ **Model**: <model-name>
4
+ **Date**: 2026-03-18T07:43:29Z
5
+ **Evals**: 1, 2, 3 (3 runs each per configuration)
6
+
7
+ ## Summary
8
+
9
+ | Metric | With Skill | Without Skill | Delta |
10
+ |--------|------------|---------------|-------|
11
+ | Pass Rate | 83% ± 14% | 67% ± 38% | +0.17 |
12
+ | Time | 0.0s ± 0.0s | 24.2s ± 41.9s | -24.2s |
13
+ | Tokens | 0 ± 0 | 7311 ± 12664 | -7311 |
@@ -0,0 +1,27 @@
1
+ {
2
+ "eval_id": 3,
3
+ "eval_name": "doc-audit",
4
+ "prompt": "Do a doc audit. I think the README has sections that should be in docs/ but I'm not sure which ones.",
5
+ "assertions": [
6
+ {
7
+ "id": "ran-analyzer",
8
+ "description": "Ran doc_structure_analyzer.py and referenced its structured output",
9
+ "check": "result.md cites the analyzer output (EXTRACTABLE, BLOATED, line count, or specific section names from the report)"
10
+ },
11
+ {
12
+ "id": "named-specific-sections",
13
+ "description": "Named specific README sections with their suggested docs/ destination",
14
+ "check": "result.md lists at least 2 specific sections (e.g. '## Policy System → docs/policies.md') not just generic advice"
15
+ },
16
+ {
17
+ "id": "actionable-report",
18
+ "description": "Report is actionable — tells user exactly what to do next, not just observations",
19
+ "check": "result.md includes a prioritized list or clear next steps, not just 'the README could be shorter'"
20
+ },
21
+ {
22
+ "id": "no-edits-made",
23
+ "description": "Did not edit or create any files (audit only)",
24
+ "check": "result.md does not claim to have modified README.md or created docs/ files"
25
+ }
26
+ ]
27
+ }