@utilarium/dreadcabinet 0.0.16-dev.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 (128) hide show
  1. package/.nvmrc +2 -0
  2. package/LICENSE +190 -0
  3. package/README.md +95 -0
  4. package/dist/configure.d.ts +5 -0
  5. package/dist/configure.js +44 -0
  6. package/dist/configure.js.map +1 -0
  7. package/dist/constants.d.ts +36 -0
  8. package/dist/constants.js +53 -0
  9. package/dist/constants.js.map +1 -0
  10. package/dist/defaults.d.ts +2 -0
  11. package/dist/defaults.js +32 -0
  12. package/dist/defaults.js.map +1 -0
  13. package/dist/dreadcabinet.cjs +1793 -0
  14. package/dist/dreadcabinet.cjs.map +1 -0
  15. package/dist/dreadcabinet.d.ts +131 -0
  16. package/dist/dreadcabinet.js +111 -0
  17. package/dist/dreadcabinet.js.map +1 -0
  18. package/dist/error/ArgumentError.d.ts +5 -0
  19. package/dist/error/ArgumentError.js +26 -0
  20. package/dist/error/ArgumentError.js.map +1 -0
  21. package/dist/input/input.d.ts +7 -0
  22. package/dist/input/input.js +13 -0
  23. package/dist/input/input.js.map +1 -0
  24. package/dist/input/process.d.ts +5 -0
  25. package/dist/input/process.js +36 -0
  26. package/dist/input/process.js.map +1 -0
  27. package/dist/input/structured.d.ts +15 -0
  28. package/dist/input/structured.js +324 -0
  29. package/dist/input/structured.js.map +1 -0
  30. package/dist/input/unstructured.d.ts +2 -0
  31. package/dist/input/unstructured.js +45 -0
  32. package/dist/input/unstructured.js.map +1 -0
  33. package/dist/logger.d.ts +2 -0
  34. package/dist/logger.js +19 -0
  35. package/dist/logger.js.map +1 -0
  36. package/dist/operate.d.ts +2 -0
  37. package/dist/operate.js +27 -0
  38. package/dist/operate.js.map +1 -0
  39. package/dist/output.d.ts +7 -0
  40. package/dist/output.js +99 -0
  41. package/dist/output.js.map +1 -0
  42. package/dist/read.d.ts +4 -0
  43. package/dist/read.js +30 -0
  44. package/dist/read.js.map +1 -0
  45. package/dist/util/dates.d.ts +60 -0
  46. package/dist/util/dates.js +699 -0
  47. package/dist/util/dates.js.map +1 -0
  48. package/dist/util/storage.d.ts +33 -0
  49. package/dist/util/storage.js +140 -0
  50. package/dist/util/storage.js.map +1 -0
  51. package/dist/validate.d.ts +4 -0
  52. package/dist/validate.js +134 -0
  53. package/dist/validate.js.map +1 -0
  54. package/guide/architecture.md +60 -0
  55. package/guide/configuration.md +132 -0
  56. package/guide/development.md +110 -0
  57. package/guide/index.md +62 -0
  58. package/guide/usage.md +166 -0
  59. package/output/kodrdriv/250703-0645-commit-message.md +21 -0
  60. package/output/kodrdriv/250703-0653-commit-message.md +1 -0
  61. package/output/kodrdriv/250703-0654-commit-message.md +1 -0
  62. package/output/kodrdriv/250703-0655-release-notes.md +51 -0
  63. package/output/kodrdriv/250703-0700-commit-message.md +1 -0
  64. package/output/kodrdriv/250703-0700-release-notes.md +8 -0
  65. package/output/kodrdriv/250703-0706-commit-message.md +1 -0
  66. package/output/kodrdriv/250703-0706-release-notes.md +11 -0
  67. package/output/kodrdriv/250703-0717-commit-message.md +1 -0
  68. package/output/kodrdriv/250703-0719-commit-message.md +1 -0
  69. package/output/kodrdriv/250703-0719-release-notes.md +17 -0
  70. package/output/kodrdriv/250703-0730-commit-message.md +1 -0
  71. package/output/kodrdriv/250703-0730-release-notes.md +11 -0
  72. package/output/kodrdriv/250703-1510-commit-message.md +1 -0
  73. package/output/kodrdriv/250710-0805-commit-message.md +3 -0
  74. package/output/kodrdriv/250710-0815-commit-message.md +1 -0
  75. package/output/kodrdriv/250710-0815-release-notes.md +39 -0
  76. package/output/kodrdriv/260107-2021-commit-message.md +37 -0
  77. package/output/kodrdriv/260108-0432-commit-message.md +6 -0
  78. package/output/kodrdriv/260108-0435-commit-message.md +3 -0
  79. package/output/kodrdriv/260108-0436-commit-message.md +4 -0
  80. package/output/kodrdriv/260108-0439-release-notes.md +63 -0
  81. package/output/kodrdriv/260108-0543-commit-message.md +19 -0
  82. package/output/kodrdriv/260108-0550-commit-message.md +3 -0
  83. package/output/kodrdriv/260108-0550-release-notes.md +19 -0
  84. package/output/kodrdriv/260108-0600-commit-message.md +3 -0
  85. package/output/kodrdriv/260110-0717-commit-message.md +4 -0
  86. package/output/kodrdriv/260110-1152-commit-message.md +1 -0
  87. package/output/kodrdriv/260110-1850-commit-message.md +1 -0
  88. package/output/kodrdriv/260110-1852-release-notes.md +33 -0
  89. package/output/kodrdriv/260112-2257-commit-message.md +5 -0
  90. package/output/kodrdriv/260112-2317-commit-message.md +1 -0
  91. package/output/kodrdriv/260112-2318-release-notes.md +42 -0
  92. package/output/kodrdriv/260113-0053-commit-message.md +1 -0
  93. package/output/kodrdriv/260113-0054-commit-message.md +1 -0
  94. package/output/kodrdriv/260113-0054-release-notes.md +49 -0
  95. package/output/kodrdriv/260130-1132-commit-message.md +1 -0
  96. package/output/kodrdriv/260130-1135-commit-message.md +1 -0
  97. package/output/kodrdriv/260130-1335-commit-message.md +10 -0
  98. package/output/kodrdriv/RELEASE_NOTES.md +47 -0
  99. package/output/kodrdriv/RELEASE_TITLE.md +1 -0
  100. package/output/kodrdriv/agentic-reflection-commit-2026-01-08T04-21-54-623Z.md +372 -0
  101. package/output/kodrdriv/agentic-reflection-commit-2026-01-08T12-32-36-513Z.md +55 -0
  102. package/output/kodrdriv/agentic-reflection-commit-2026-01-08T12-35-58-580Z.md +105 -0
  103. package/output/kodrdriv/agentic-reflection-commit-2026-01-08T12-36-05-658Z.md +53 -0
  104. package/output/kodrdriv/agentic-reflection-commit-2026-01-08T13-43-55-498Z.md +178 -0
  105. package/output/kodrdriv/agentic-reflection-commit-2026-01-08T13-50-10-230Z.md +53 -0
  106. package/output/kodrdriv/agentic-reflection-commit-2026-01-08T13-50-35-136Z.md +52 -0
  107. package/output/kodrdriv/agentic-reflection-commit-2026-01-08T14-00-30-772Z.md +52 -0
  108. package/output/kodrdriv/agentic-reflection-commit-2026-01-10T15-17-43-324Z.md +53 -0
  109. package/output/kodrdriv/agentic-reflection-commit-2026-01-10T19-52-47-424Z.md +97 -0
  110. package/output/kodrdriv/agentic-reflection-commit-2026-01-11T02-50-23-123Z.md +138 -0
  111. package/output/kodrdriv/agentic-reflection-commit-2026-01-11T02-50-45-038Z.md +114 -0
  112. package/output/kodrdriv/agentic-reflection-commit-2026-01-11T02-50-49-467Z.md +114 -0
  113. package/output/kodrdriv/agentic-reflection-commit-2026-01-13T06-57-00-384Z.md +169 -0
  114. package/output/kodrdriv/agentic-reflection-commit-2026-01-13T07-17-29-292Z.md +114 -0
  115. package/output/kodrdriv/agentic-reflection-commit-2026-01-13T07-17-47-579Z.md +114 -0
  116. package/output/kodrdriv/agentic-reflection-commit-2026-01-13T08-48-55-599Z.md +144 -0
  117. package/output/kodrdriv/agentic-reflection-commit-2026-01-13T08-53-53-725Z.md +114 -0
  118. package/output/kodrdriv/agentic-reflection-commit-2026-01-13T08-54-11-600Z.md +97 -0
  119. package/output/kodrdriv/agentic-reflection-commit-2026-01-30T19-32-17-053Z.md +174 -0
  120. package/output/kodrdriv/agentic-reflection-commit-2026-01-30T19-35-00-887Z.md +152 -0
  121. package/output/kodrdriv/agentic-reflection-commit-2026-01-30T21-02-16-553Z.md +236 -0
  122. package/output/kodrdriv/agentic-reflection-commit-2026-01-30T21-17-22-227Z.md +347 -0
  123. package/output/kodrdriv/agentic-reflection-release-2026-01-08T12-39-08-279Z.md +507 -0
  124. package/output/kodrdriv/agentic-reflection-release-2026-01-08T13-50-57-683Z.md +183 -0
  125. package/output/kodrdriv/agentic-reflection-release-2026-01-11T02-52-39-082Z.md +347 -0
  126. package/output/kodrdriv/agentic-reflection-release-2026-01-13T07-18-21-218Z.md +315 -0
  127. package/output/kodrdriv/agentic-reflection-release-2026-01-13T08-54-59-340Z.md +354 -0
  128. package/package.json +80 -0
@@ -0,0 +1,53 @@
1
+ # Agentic Workflow - Self-Reflection Report
2
+
3
+ Generated: 2026-01-08T12:36:05.658Z
4
+
5
+ ## Execution Summary
6
+
7
+ - **Iterations**: 1
8
+ - **Tool Calls**: 0
9
+ - **Unique Tools**: 0
10
+
11
+ ## Tool Effectiveness Analysis
12
+
13
+ *No tools were executed during this run.*
14
+
15
+ ## Recommendations for Improvement
16
+
17
+ *No specific recommendations at this time. Execution appears optimal.*
18
+
19
+ ## Detailed Execution Timeline
20
+
21
+ *No tool execution timeline available.*
22
+ ## Conversation History
23
+
24
+ <details>
25
+ <summary>Click to expand full agentic interaction</summary>
26
+
27
+ ```json
28
+ [
29
+ {
30
+ "role": "system",
31
+ "content": "You are a professional software engineer writing commit messages for your team.\n\n## Available Tools\n\n### Understanding\n\n**get_file_history** _(cheap)_\nGet git commit history for one or more files to understand their evolution and past changes\n\nParameters:\n- `filePaths` (required): Array of file paths to get history for\n- `limit`: Maximum number of commits to return (default: 10)\n- `format`: Output format: \"summary\" for brief or \"detailed\" for full messages\n\n**When to use:** Get git commit history for one or more files to understand their evolution and past changes\n\n**Examples:**\n- Check if file has recent refactoring: `get_file_history({\"filePaths\":[\"src/auth.ts\"],\"limit\":5})`\n- Understand evolution of multiple related files: `get_file_history({\"filePaths\":[\"src/user.ts\",\"src/auth.ts\"],\"limit\":10,\"format\":\"detailed\"})`\n\n---\n\n**get_file_content** _(moderate)_\nGet the complete current content of a file to understand context around changes. Returns a message if the file does not exist (e.g., if it was deleted).\n\nParameters:\n- `filePath` (required): Path to the file\n- `includeLineNumbers`: Include line numbers in output (default: false)\n\n**When to use:** Get the complete current content of a file to understand context around changes. Returns a message if the file does not exist (e.g., if it was deleted).\n\n**Examples:**\n- See full class definition for modified method: `get_file_content({\"filePath\":\"src/services/auth.ts\",\"includeLineNumbers\":true})`\n- Check imports and structure: `get_file_content({\"filePath\":\"src/utils/helpers.ts\"})`\n\n---\n\n**get_related_tests** _(cheap)_\nFind test files related to production files to understand what the code is supposed to do\n\nParameters:\n- `filePaths` (required): Production file paths\n\n**When to use:** Find test files related to production files to understand what the code is supposed to do\n\n**Examples:**\n- Find tests for modified service: `get_related_tests({\"filePaths\":[\"src/services/auth.ts\"]})`\n\n---\n\n**analyze_diff_section** _(cheap)_\nGet expanded context around specific lines in a file to better understand changes\n\nParameters:\n- `filePath` (required): File containing the section to analyze\n- `startLine` (required): Starting line number\n- `endLine` (required): Ending line number\n- `contextLines`: Number of additional context lines to show before and after (default: 10)\n\n**When to use:** Get expanded context around specific lines in a file to better understand changes\n\n**Examples:**\n- See context around confusing change: `analyze_diff_section({\"filePath\":\"src/auth.ts\",\"startLine\":45,\"endLine\":52,\"contextLines\":15})`\n\n---\n\n**get_recent_commits** _(cheap)_\nGet recent commits that modified the same files to understand recent work in this area\n\nParameters:\n- `filePaths` (required): Files to check for recent commits\n- `since`: Time period to look back (e.g., \"1 week ago\", \"2 days ago\")\n- `limit`: Maximum number of commits to return (default: 5)\n\n**When to use:** Get recent commits that modified the same files to understand recent work in this area\n\n**Examples:**\n- Check for duplicate commit messages: `get_recent_commits({\"filePaths\":[\"src/auth.ts\"],\"since\":\"1 week ago\",\"limit\":5})`\n\n---\n\n### Analysis\n\n**search_codebase** _(moderate)_\nSearch for code patterns, function names, or text across the codebase using git grep\n\nParameters:\n- `query` (required): Search pattern (can be plain text or regex)\n- `fileTypes`: Limit search to specific file extensions (e.g., [\"ts\", \"js\"])\n- `contextLines`: Number of context lines to show around matches (default: 2)\n\n**When to use:** Search for code patterns, function names, or text across the codebase using git grep\n\n**Examples:**\n- Find all uses of a renamed function: `search_codebase({\"query\":\"oldFunctionName\",\"fileTypes\":[\"ts\",\"tsx\"]})`\n- Check if pattern exists elsewhere: `search_codebase({\"query\":\"pattern.*string\",\"contextLines\":3})`\n\n---\n\n**get_file_dependencies** _(moderate)_\nFind which files import or depend on the changed files to assess change impact\n\nParameters:\n- `filePaths` (required): Files to analyze dependencies for\n\n**When to use:** Find which files import or depend on the changed files to assess change impact\n\n**Examples:**\n- Check impact of util function change: `get_file_dependencies({\"filePaths\":[\"src/utils/format.ts\"]})`\n\n---\n\n### Organization\n\n**group_files_by_concern** _(cheap)_\nAnalyze changed files and suggest logical groupings that might represent separate commits\n\nParameters:\n- `filePaths` (required): All changed files to analyze\n\n**When to use:** Analyze changed files and suggest logical groupings that might represent separate commits\n\n**Examples:**\n- Check if multiple unrelated changes should be split: `group_files_by_concern({\"filePaths\":[\"src/auth.ts\",\"README.md\",\"tests/auth.test.ts\",\"package.json\"]})`\n\n---\n\n\n\n## Your Task\n\nWrite a commit message that clearly explains what changed and why. Your message should help teammates understand the changes without needing to read the diff.\n\nThink about:\n- What problem does this solve?\n- How do the changes work together?\n- What should reviewers focus on?\n- Are there any important implications?\n\nUse the available tools to investigate the changes. The more you understand, the better your message will be.\n\n**Important**: If additional context is provided (from context files or other sources), use your judgment:\n- If the context is relevant to these specific changes, incorporate it\n- If the context describes unrelated changes or other packages, ignore it\n- Don't force connections between unrelated information\n- Focus on accurately describing what actually changed in this commit\n\n## Investigation Approach\n\nUse tools based on what you need to know:\n- group_files_by_concern - understand how files relate\n- get_file_content - see full context when diffs are unclear\n- get_file_history - understand how code evolved\n- get_file_dependencies - assess impact of changes\n- get_recent_commits - avoid duplicate messages\n- get_related_tests - understand behavior changes\n- search_codebase - find usage patterns\n\n## Writing Style\n\nWrite naturally and directly:\n- Use plain language, not corporate speak\n- Be specific and concrete\n- Avoid buzzwords and jargon\n- No emojis or excessive punctuation\n- No phrases like \"this commit\" or \"this PR\"\n- No meta-commentary about the commit itself\n\nFollow conventional commit format when appropriate (feat:, fix:, refactor:, docs:, test:, chore:), but prioritize clarity over formality.\n\n## Output Format\n\nWhen ready, format your response as:\n\nCOMMIT_MESSAGE:\n[Your commit message here]\n\nIf changes should be split into multiple commits:\n\nSUGGESTED_SPLITS:\nSplit 1:\nFiles: [list of files]\nRationale: [why these belong together]\nMessage: [commit message for this split]\n\nSplit 2:\n...\n\nOutput only the commit message and splits. No conversational remarks or follow-up offers."
32
+ },
33
+ {
34
+ "role": "user",
35
+ "content": "I have staged changes that need a commit message.\n\nChanged files (1):\n - package.json\n\nDiff:\ndiff --git a/package.json b/package.json\nindex bdd5750..410d4d5 100644\n--- a/package.json\n+++ b/package.json\n@@ -1,76 +1,76 @@\n {\n- \"name\": \"@theunwalked/dreadcabinet\",\n- \"version\": \"0.0.10\",\n- \"description\": \"dreadcabinet organizes the chaos.\",\n- \"main\": \"dist/dreadcabinet.cjs\",\n- \"module\": \"dist/dreadcabinet.js\",\n- \"type\": \"module\",\n- \"repository\": {\n- \"type\": \"git\",\n- \"url\": \"git+https://github.com/utilarium/dreadcabinet.git\"\n- },\n- \"homepage\": \"https://utilarium.github.io/dreadcabinet/\",\n- \"exports\": {\n- \".\": {\n- \"types\": \"./dist/dreadcabinet.d.ts\",\n- \"import\": \"./dist/dreadcabinet.js\",\n- \"require\": \"./dist/dreadcabinet.cjs\"\n- }\n- },\n- \"scripts\": {\n- \"build\": \"npm run lint && tsc --noEmit && vite build\",\n- \"start\": \"dist/main.js\",\n- \"dev\": \"vite build --watch\",\n- \"watch\": \"npm run dev\",\n- \"test\": \"npm run test:coverage && npm run test:readme\",\n- \"test:coverage\": \"vitest run --coverage\",\n- \"test:readme\": \"doccident -c .markdown-doctest-setup.mjs README.md\",\n- \"lint\": \"eslint . --ext .ts\",\n- \"lint:fix\": \"eslint . --ext .ts --fix\",\n- \"precommit\": \"npm run build && npm run test\",\n- \"clean\": \"rm -rf dist\",\n- \"prepublishOnly\": \"npm run clean && npm run build\"\n- },\n- \"keywords\": [\n- \"focus\",\n- \"productivity\",\n- \"notes\",\n- \"genai\"\n- ],\n- \"author\": \"Tim O'Brien <tobrien@discursive.com>\",\n- \"license\": \"Apache-2.0\",\n- \"dependencies\": {\n- \"commander\": \"^14.0.0\",\n- \"dayjs\": \"^1.11.13\",\n- \"glob\": \"^11.0.3\",\n- \"zod\": \"^4.0.2\"\n- },\n- \"devDependencies\": {\n- \"@babel/core\": \"^7.28.0\",\n- \"@babel/plugin-transform-modules-commonjs\": \"^7.27.1\",\n- \"@babel/plugin-transform-typescript\": \"^7.28.0\",\n- \"@babel/preset-typescript\": \"^7.27.1\",\n- \"@doccident/doccident\": \"^0.0.7\",\n- \"@eslint/eslintrc\": \"^3.3.1\",\n- \"@eslint/js\": \"^9.30.1\",\n- \"@rollup/plugin-replace\": \"^6.0.2\",\n- \"@swc/core\": \"^1.12.11\",\n- \"@theunwalked/cardigantime\": \"^0.0.16\",\n- \"@types/node\": \"^24.0.12\",\n- \"@typescript-eslint/eslint-plugin\": \"^8.36.0\",\n- \"@typescript-eslint/parser\": \"^8.36.0\",\n- \"@vitest/coverage-v8\": \"^3.2.4\",\n- \"eslint\": \"^9.30.1\",\n- \"eslint-plugin-import\": \"^2.32.0\",\n- \"globals\": \"^16.3.0\",\n- \"mockdate\": \"^3.0.5\",\n- \"typescript\": \"^5.8.3\",\n- \"vite\": \"^7.0.4\",\n- \"vite-plugin-dts\": \"^4.5.4\",\n- \"vite-plugin-node\": \"^7.0.0\",\n- \"vitest\": \"^3.2.4\"\n- },\n- \"overrides\": {\n- \"wrap-ansi\": \"7.0.0\"\n+ \"name\": \"@theunwalked/dreadcabinet\",\n+ \"version\": \"0.0.11\",\n+ \"description\": \"dreadcabinet organizes the chaos.\",\n+ \"main\": \"dist/dreadcabinet.cjs\",\n+ \"module\": \"dist/dreadcabinet.js\",\n+ \"type\": \"module\",\n+ \"repository\": {\n+ \"type\": \"git\",\n+ \"url\": \"git+https://github.com/utilarium/dreadcabinet.git\"\n+ },\n+ \"homepage\": \"https://utilarium.github.io/dreadcabinet/\",\n+ \"exports\": {\n+ \".\": {\n+ \"types\": \"./dist/dreadcabinet.d.ts\",\n+ \"import\": \"./dist/dreadcabinet.js\",\n+ \"require\": \"./dist/dreadcabinet.cjs\"\n }\n+ },\n+ \"scripts\": {\n+ \"build\": \"npm run lint && tsc --noEmit && vite build\",\n+ \"start\": \"dist/main.js\",\n+ \"dev\": \"vite build --watch\",\n+ \"watch\": \"npm run dev\",\n+ \"test\": \"npm run test:coverage && npm run test:readme\",\n+ \"test:coverage\": \"vitest run --coverage\",\n+ \"test:readme\": \"doccident -c .markdown-doctest-setup.mjs README.md\",\n+ \"lint\": \"eslint . --ext .ts\",\n+ \"lint:fix\": \"eslint . --ext .ts --fix\",\n+ \"precommit\": \"npm run build && npm run test\",\n+ \"clean\": \"rm -rf dist\",\n+ \"prepublishOnly\": \"npm run clean && npm run build\"\n+ },\n+ \"keywords\": [\n+ \"focus\",\n+ \"productivity\",\n+ \"notes\",\n+ \"genai\"\n+ ],\n+ \"author\": \"Tim O'Brien <tobrien@discursive.com>\",\n+ \"license\": \"Apache-2.0\",\n+ \"dependencies\": {\n+ \"commander\": \"^14.0.0\",\n+ \"dayjs\": \"^1.11.13\",\n+ \"glob\": \"^11.0.3\",\n+ \"zod\": \"^4.0.2\"\n+ },\n+ \"devDependencies\": {\n+ \"@babel/core\": \"^7.28.0\",\n+ \"@babel/plugin-transform-modules-commonjs\": \"^7.27.1\",\n+ \"@babel/plugin-transform-typescript\": \"^7.28.0\",\n+ \"@babel/preset-typescript\": \"^7.27.1\",\n+ \"@doccident/doccident\": \"^0.0.7\",\n+ \"@eslint/eslintrc\": \"^3.3.1\",\n+ \"@eslint/js\": \"^9.30.1\",\n+ \"@rollup/plugin-replace\": \"^6.0.2\",\n+ \"@swc/core\": \"^1.12.11\",\n+ \"@theunwalked/cardigantime\": \"^0.0.16\",\n+ \"@types/node\": \"^24.0.12\",\n+ \"@typescript-eslint/eslint-plugin\": \"^8.36.0\",\n+ \"@typescript-eslint/parser\": \"^8.36.0\",\n+ \"@vitest/coverage-v8\": \"^3.2.4\",\n+ \"eslint\": \"^9.30.1\",\n+ \"eslint-plugin-import\": \"^2.32.0\",\n+ \"globals\": \"^16.3.0\",\n+ \"mockdate\": \"^3.0.5\",\n+ \"typescript\": \"^5.8.3\",\n+ \"vite\": \"^7.0.4\",\n+ \"vite-plugin-dts\": \"^4.5.4\",\n+ \"vite-plugin-node\": \"^7.0.0\",\n+ \"vitest\": \"^3.2.4\"\n+ },\n+ \"overrides\": {\n+ \"wrap-ansi\": \"7.0.0\"\n+ }\n }\n\n\nRecent commit history for context:\ncommit 673a7e980599664e7ca0547395242438f9928755\nAuthor: Tim O'Brien <tobrien@discursive.com>\nDate: Thu Jan 8 04:35:58 2026 -0800\n\n chore: refresh package-lock.json after npm install\n \n Regenerates the npm lockfile to reflect the current dependency resolution (updated versions/integrity metadata), keeping `npm ci` installs reproducible in CI and for contributors.\n\ncommit 7021e9edabd3a8addec50f91bbf759e5fcba033c\nAuthor: Tim O'Brien <tobrien@discursive.com>\nDate: Thu Jan 8 04:32:36 2026 -0800\n\n chore: standardize on npm in CI and refresh docs/metadata for utilarium\n \n - Switch GitHub Actions (tests + docs deploy) from pnpm to `npm ci`/`npm run` to match the npm lockfile workflow\n - Update package metadata (repository/homepage) and documentation links to the `utilarium/dreadcabinet` URLs\n - Add `precommit` script and reorder `test` to run coverage before README doctests; bump `@doccident/doccident` and update lockfile\n - Add `guide/` docs (architecture/configuration/usage/development) to document internal structure and common integration patterns\n\ncommit efae4042901387794b550dc151ef3d61bfa8eaa7\nAuthor: Tim O'Brien <tobrien@discursive.com>\nDate: Wed Jan 7 20:21:54 2026 -0800\n\n SUGGESTED_SPLITS:\n Split 1:\n Files: [.github/workflows/dependency-review.yml, .github/workflows/test.yml, .github/workflows/npm-publish.yml, .github/workflows/pnpm-publish.yml]\n Rationale: CI/CD behavior changes (new security check, test trigger changes, and switching the release publish workflow to npm) are reviewable together and independent of docs/metadata updates.\n Message: |\n ci: add dependency review and publish releases via npm\n \n - Add dependency-review workflow with PR summary comments\n - Run test workflow on pull requests to main/working (instead of push)\n - Replace pnpm-based publish workflow with npm publish using npm ci and NPM_TOKEN\n \n Split 2:\n Files: [package.json, pnpm-lock.yaml, docs/pnpm-lock.yaml, pnpm-workspace.yaml]\n Rationale: Package manager/config changes (scripts/overrides/workspace + lockfile updates) should be reviewed as a cohesive “tooling” change.\n Message: |\n chore: prefer npm scripts and drop pnpm workspace config\n \n - Switch build/test/watch/prepublish scripts from pnpm to npm\n - Move wrap-ansi override to top-level overrides\n - Remove pnpm-workspace.yaml\n - Update pnpm lockfiles to match dependency resolution\n \n Split 3:\n Files: [LICENSE, README.md, docs/public/contributing.md, docs/public/faq.md, docs/src/App.tsx]\n Rationale: Ownership/branding and documentation link updates are user-facing but don’t affect runtime/CI behavior; easier to review separately.\n Message: |\n docs: update repo links and attribution to tobrien\n \n - Update GitHub URLs across docs/site from SemicolonAmbulance to tobrien\n - Update contributing guide to use npm commands\n - Update LICENSE/README and docs footer attribution\n \n Split 4:\n Files: [.DS_Store, src/.DS_Store, tests/.DS_Store]\n Rationale: Accidental OS-generated binaries shouldn’t ship; keep noise out of functional commits.\n Message: |\n chore: remove accidentally committed .DS_Store files\n\n\nAnalyze these changes and write a clear commit message. Consider:\n- What problem does this solve?\n- How do the changes work together?\n- Should this be one commit or multiple?\n\nIf context information is provided, use it only if relevant to these specific changes.\nDon't force connections that don't exist - if context doesn't apply to this package,\nsimply ignore it and focus on the actual changes.\n\nInvestigate as needed to write an accurate, helpful message."
36
+ },
37
+ {
38
+ "role": "assistant",
39
+ "content": "COMMIT_MESSAGE:\nchore(release): bump package version to 0.0.11\n\n- Update `package.json` version from 0.0.10 to 0.0.11\n- Reformat `package.json` (2-space indentation) with no functional/config changes beyond the version bump"
40
+ }
41
+ ]
42
+ ```
43
+
44
+ </details>
45
+
46
+ ## Generated Commit Message
47
+
48
+ ```
49
+ chore(release): bump package version to 0.0.11
50
+
51
+ - Update `package.json` version from 0.0.10 to 0.0.11
52
+ - Reformat `package.json` (2-space indentation) with no functional/config changes beyond the version bump
53
+ ```