dominds 1.3.1 → 1.4.2

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 (184) hide show
  1. package/README.md +9 -2
  2. package/README.zh.md +9 -2
  3. package/dist/apps/app-lock-file.js +33 -57
  4. package/dist/apps/configuration-file.js +267 -0
  5. package/dist/apps/enabled-apps.js +217 -252
  6. package/dist/apps/manifest.js +132 -0
  7. package/dist/apps/resolution-file.js +80 -192
  8. package/dist/apps/workspace-app-state.js +8 -0
  9. package/dist/cli/disable.js +18 -22
  10. package/dist/cli/enable.js +20 -58
  11. package/dist/cli/install.js +74 -80
  12. package/dist/cli/uninstall.js +48 -25
  13. package/dist/cli/update.js +36 -80
  14. package/dist/docs/app-constitution.md +12 -7
  15. package/dist/docs/app-constitution.zh.md +13 -8
  16. package/dist/llm/kernel-driver/engine.js +10 -4
  17. package/dist/llm/kernel-driver/flow.js +93 -0
  18. package/dist/llm/kernel-driver/loop.js +4 -1
  19. package/dist/llm/kernel-driver/subdialog.js +5 -1
  20. package/dist/llm/kernel-driver/tellask-special.js +48 -6
  21. package/dist/server/server-core.js +19 -4
  22. package/dist/server/websocket-handler.js +26 -6
  23. package/dist/static/assets/{_basePickBy-CmziIRM9.js → _basePickBy-B2o4z1Hf.js} +3 -3
  24. package/dist/static/assets/{_basePickBy-CmziIRM9.js.map → _basePickBy-B2o4z1Hf.js.map} +1 -1
  25. package/dist/static/assets/{_baseUniq-CgDZxcD0.js → _baseUniq-CLmcxjdl.js} +2 -2
  26. package/dist/static/assets/{_baseUniq-CgDZxcD0.js.map → _baseUniq-CLmcxjdl.js.map} +1 -1
  27. package/dist/static/assets/{arc-Df9rjNNk.js → arc-CymD_KN7.js} +2 -2
  28. package/dist/static/assets/{arc-Df9rjNNk.js.map → arc-CymD_KN7.js.map} +1 -1
  29. package/dist/static/assets/{architectureDiagram-VXUJARFQ-Bif8topC.js → architectureDiagram-VXUJARFQ-DJQfSJUH.js} +7 -7
  30. package/dist/static/assets/{architectureDiagram-VXUJARFQ-Bif8topC.js.map → architectureDiagram-VXUJARFQ-DJQfSJUH.js.map} +1 -1
  31. package/dist/static/assets/{blockDiagram-VD42YOAC-D9Egoflr.js → blockDiagram-VD42YOAC-pHVz60D0.js} +7 -7
  32. package/dist/static/assets/{blockDiagram-VD42YOAC-D9Egoflr.js.map → blockDiagram-VD42YOAC-pHVz60D0.js.map} +1 -1
  33. package/dist/static/assets/{c4Diagram-YG6GDRKO-DBf1NeBf.js → c4Diagram-YG6GDRKO-B0WnCfAT.js} +3 -3
  34. package/dist/static/assets/{c4Diagram-YG6GDRKO-DBf1NeBf.js.map → c4Diagram-YG6GDRKO-B0WnCfAT.js.map} +1 -1
  35. package/dist/static/assets/{channel-Dc34yAJl.js → channel-CX9BlKil.js} +2 -2
  36. package/dist/static/assets/{channel-Dc34yAJl.js.map → channel-CX9BlKil.js.map} +1 -1
  37. package/dist/static/assets/{chunk-4BX2VUAB-B65G1dJI.js → chunk-4BX2VUAB-lXArRj3o.js} +2 -2
  38. package/dist/static/assets/{chunk-4BX2VUAB-B65G1dJI.js.map → chunk-4BX2VUAB-lXArRj3o.js.map} +1 -1
  39. package/dist/static/assets/{chunk-55IACEB6-CSDEOGl2.js → chunk-55IACEB6-CdqwynH9.js} +2 -2
  40. package/dist/static/assets/{chunk-55IACEB6-CSDEOGl2.js.map → chunk-55IACEB6-CdqwynH9.js.map} +1 -1
  41. package/dist/static/assets/{chunk-B4BG7PRW-Cb6W3QWJ.js → chunk-B4BG7PRW-Y-uXcJst.js} +5 -5
  42. package/dist/static/assets/{chunk-B4BG7PRW-Cb6W3QWJ.js.map → chunk-B4BG7PRW-Y-uXcJst.js.map} +1 -1
  43. package/dist/static/assets/{chunk-DI55MBZ5-ZAJWeVWH.js → chunk-DI55MBZ5-C5xSbRST.js} +4 -4
  44. package/dist/static/assets/{chunk-DI55MBZ5-ZAJWeVWH.js.map → chunk-DI55MBZ5-C5xSbRST.js.map} +1 -1
  45. package/dist/static/assets/{chunk-FMBD7UC4-DiwRlImb.js → chunk-FMBD7UC4-5uefwCjI.js} +2 -2
  46. package/dist/static/assets/{chunk-FMBD7UC4-DiwRlImb.js.map → chunk-FMBD7UC4-5uefwCjI.js.map} +1 -1
  47. package/dist/static/assets/{chunk-QN33PNHL-wilj7fb5.js → chunk-QN33PNHL-DzWVcvpI.js} +2 -2
  48. package/dist/static/assets/{chunk-QN33PNHL-wilj7fb5.js.map → chunk-QN33PNHL-DzWVcvpI.js.map} +1 -1
  49. package/dist/static/assets/{chunk-QZHKN3VN-DGmviJfR.js → chunk-QZHKN3VN-BrrvAZdP.js} +2 -2
  50. package/dist/static/assets/{chunk-QZHKN3VN-DGmviJfR.js.map → chunk-QZHKN3VN-BrrvAZdP.js.map} +1 -1
  51. package/dist/static/assets/{chunk-TZMSLE5B-Nm5wTXa_.js → chunk-TZMSLE5B-DyKOlPTY.js} +2 -2
  52. package/dist/static/assets/{chunk-TZMSLE5B-Nm5wTXa_.js.map → chunk-TZMSLE5B-DyKOlPTY.js.map} +1 -1
  53. package/dist/static/assets/{classDiagram-2ON5EDUG-BvUbXD6H.js → classDiagram-2ON5EDUG-FCrnlCWC.js} +6 -6
  54. package/dist/static/assets/{classDiagram-2ON5EDUG-BvUbXD6H.js.map → classDiagram-2ON5EDUG-FCrnlCWC.js.map} +1 -1
  55. package/dist/static/assets/{classDiagram-v2-WZHVMYZB-BvUbXD6H.js → classDiagram-v2-WZHVMYZB-FCrnlCWC.js} +6 -6
  56. package/dist/static/assets/{classDiagram-v2-WZHVMYZB-BvUbXD6H.js.map → classDiagram-v2-WZHVMYZB-FCrnlCWC.js.map} +1 -1
  57. package/dist/static/assets/{clone-0VLS7GaA.js → clone-BlI81KqZ.js} +2 -2
  58. package/dist/static/assets/{clone-0VLS7GaA.js.map → clone-BlI81KqZ.js.map} +1 -1
  59. package/dist/static/assets/{cose-bilkent-S5V4N54A-anaPs-75.js → cose-bilkent-S5V4N54A-yM7S2atz.js} +2 -2
  60. package/dist/static/assets/{cose-bilkent-S5V4N54A-anaPs-75.js.map → cose-bilkent-S5V4N54A-yM7S2atz.js.map} +1 -1
  61. package/dist/static/assets/{dagre-6UL2VRFP-YwdsZ11r.js → dagre-6UL2VRFP-BcweuZHt.js} +7 -7
  62. package/dist/static/assets/{dagre-6UL2VRFP-YwdsZ11r.js.map → dagre-6UL2VRFP-BcweuZHt.js.map} +1 -1
  63. package/dist/static/assets/{diagram-PSM6KHXK-5KQCf3h2.js → diagram-PSM6KHXK-D4-QwLW1.js} +8 -8
  64. package/dist/static/assets/{diagram-PSM6KHXK-5KQCf3h2.js.map → diagram-PSM6KHXK-D4-QwLW1.js.map} +1 -1
  65. package/dist/static/assets/{diagram-QEK2KX5R-Mf24XxZL.js → diagram-QEK2KX5R-BVbuejJn.js} +7 -7
  66. package/dist/static/assets/{diagram-QEK2KX5R-Mf24XxZL.js.map → diagram-QEK2KX5R-BVbuejJn.js.map} +1 -1
  67. package/dist/static/assets/{diagram-S2PKOQOG-DyQjD4D5.js → diagram-S2PKOQOG-pB6N6Tq_.js} +7 -7
  68. package/dist/static/assets/{diagram-S2PKOQOG-DyQjD4D5.js.map → diagram-S2PKOQOG-pB6N6Tq_.js.map} +1 -1
  69. package/dist/static/assets/{erDiagram-Q2GNP2WA-CEzTKw1u.js → erDiagram-Q2GNP2WA-DLKmthuw.js} +5 -5
  70. package/dist/static/assets/{erDiagram-Q2GNP2WA-CEzTKw1u.js.map → erDiagram-Q2GNP2WA-DLKmthuw.js.map} +1 -1
  71. package/dist/static/assets/{flowDiagram-NV44I4VS-DT821XSz.js → flowDiagram-NV44I4VS-BsBhWukh.js} +6 -6
  72. package/dist/static/assets/{flowDiagram-NV44I4VS-DT821XSz.js.map → flowDiagram-NV44I4VS-BsBhWukh.js.map} +1 -1
  73. package/dist/static/assets/{ganttDiagram-JELNMOA3-DlmeVsGg.js → ganttDiagram-JELNMOA3-Debz-J-C.js} +3 -3
  74. package/dist/static/assets/{ganttDiagram-JELNMOA3-DlmeVsGg.js.map → ganttDiagram-JELNMOA3-Debz-J-C.js.map} +1 -1
  75. package/dist/static/assets/{gitGraphDiagram-V2S2FVAM-yAfyBG_d.js → gitGraphDiagram-V2S2FVAM-BnAPFBGR.js} +8 -8
  76. package/dist/static/assets/{gitGraphDiagram-V2S2FVAM-yAfyBG_d.js.map → gitGraphDiagram-V2S2FVAM-BnAPFBGR.js.map} +1 -1
  77. package/dist/static/assets/{graph-BYv8vyWe.js → graph-DbzWiBNK.js} +3 -3
  78. package/dist/static/assets/{graph-BYv8vyWe.js.map → graph-DbzWiBNK.js.map} +1 -1
  79. package/dist/static/assets/{index-DMbwqOm6.js → index-B-8J28g7.js} +987 -1049
  80. package/dist/static/assets/index-B-8J28g7.js.map +1 -0
  81. package/dist/static/assets/{index-BiNcBn_U.css → index-CD5wtC_i.css} +1 -1
  82. package/dist/static/assets/{infoDiagram-HS3SLOUP-DaadramQ.js → infoDiagram-HS3SLOUP-CZ5hWoxV.js} +6 -6
  83. package/dist/static/assets/{infoDiagram-HS3SLOUP-DaadramQ.js.map → infoDiagram-HS3SLOUP-CZ5hWoxV.js.map} +1 -1
  84. package/dist/static/assets/{journeyDiagram-XKPGCS4Q-ftN8hxu3.js → journeyDiagram-XKPGCS4Q-CKN3oSxk.js} +5 -5
  85. package/dist/static/assets/{journeyDiagram-XKPGCS4Q-ftN8hxu3.js.map → journeyDiagram-XKPGCS4Q-CKN3oSxk.js.map} +1 -1
  86. package/dist/static/assets/{kanban-definition-3W4ZIXB7-BIXETQ-C.js → kanban-definition-3W4ZIXB7-BQCMklfJ.js} +3 -3
  87. package/dist/static/assets/{kanban-definition-3W4ZIXB7-BIXETQ-C.js.map → kanban-definition-3W4ZIXB7-BQCMklfJ.js.map} +1 -1
  88. package/dist/static/assets/{layout-OTbrj0Ye.js → layout-C5B58szc.js} +5 -5
  89. package/dist/static/assets/{layout-OTbrj0Ye.js.map → layout-C5B58szc.js.map} +1 -1
  90. package/dist/static/assets/{linear-CVfOC669.js → linear-_32fut6G.js} +2 -2
  91. package/dist/static/assets/{linear-CVfOC669.js.map → linear-_32fut6G.js.map} +1 -1
  92. package/dist/static/assets/{mindmap-definition-VGOIOE7T-D2zv5uI9.js → mindmap-definition-VGOIOE7T-C_goMzjx.js} +4 -4
  93. package/dist/static/assets/{mindmap-definition-VGOIOE7T-D2zv5uI9.js.map → mindmap-definition-VGOIOE7T-C_goMzjx.js.map} +1 -1
  94. package/dist/static/assets/{pieDiagram-ADFJNKIX-DaUXTsv7.js → pieDiagram-ADFJNKIX-BQ2n0cOB.js} +8 -8
  95. package/dist/static/assets/{pieDiagram-ADFJNKIX-DaUXTsv7.js.map → pieDiagram-ADFJNKIX-BQ2n0cOB.js.map} +1 -1
  96. package/dist/static/assets/{quadrantDiagram-AYHSOK5B-B7O2wPX9.js → quadrantDiagram-AYHSOK5B-BLg7_neg.js} +3 -3
  97. package/dist/static/assets/{quadrantDiagram-AYHSOK5B-B7O2wPX9.js.map → quadrantDiagram-AYHSOK5B-BLg7_neg.js.map} +1 -1
  98. package/dist/static/assets/{requirementDiagram-UZGBJVZJ-DpauVPY1.js → requirementDiagram-UZGBJVZJ-DwkJt0zi.js} +4 -4
  99. package/dist/static/assets/{requirementDiagram-UZGBJVZJ-DpauVPY1.js.map → requirementDiagram-UZGBJVZJ-DwkJt0zi.js.map} +1 -1
  100. package/dist/static/assets/{sankeyDiagram-TZEHDZUN-B3Hbfvad.js → sankeyDiagram-TZEHDZUN-DmxmatUB.js} +2 -2
  101. package/dist/static/assets/{sankeyDiagram-TZEHDZUN-B3Hbfvad.js.map → sankeyDiagram-TZEHDZUN-DmxmatUB.js.map} +1 -1
  102. package/dist/static/assets/{sequenceDiagram-WL72ISMW-KdbWByWT.js → sequenceDiagram-WL72ISMW-KHU_eApU.js} +4 -4
  103. package/dist/static/assets/{sequenceDiagram-WL72ISMW-KdbWByWT.js.map → sequenceDiagram-WL72ISMW-KHU_eApU.js.map} +1 -1
  104. package/dist/static/assets/{stateDiagram-FKZM4ZOC-yDOCVezC.js → stateDiagram-FKZM4ZOC-B3DBCxAL.js} +9 -9
  105. package/dist/static/assets/{stateDiagram-FKZM4ZOC-yDOCVezC.js.map → stateDiagram-FKZM4ZOC-B3DBCxAL.js.map} +1 -1
  106. package/dist/static/assets/{stateDiagram-v2-4FDKWEC3-CpCJhvQO.js → stateDiagram-v2-4FDKWEC3-C-uIk7gh.js} +5 -5
  107. package/dist/static/assets/{stateDiagram-v2-4FDKWEC3-CpCJhvQO.js.map → stateDiagram-v2-4FDKWEC3-C-uIk7gh.js.map} +1 -1
  108. package/dist/static/assets/{timeline-definition-IT6M3QCI-CHxuEjhV.js → timeline-definition-IT6M3QCI-SysEcQCC.js} +3 -3
  109. package/dist/static/assets/{timeline-definition-IT6M3QCI-CHxuEjhV.js.map → timeline-definition-IT6M3QCI-SysEcQCC.js.map} +1 -1
  110. package/dist/static/assets/{treemap-GDKQZRPO-Bsqu3wIy.js → treemap-GDKQZRPO-d0AbKEc4.js} +5 -5
  111. package/dist/static/assets/{treemap-GDKQZRPO-Bsqu3wIy.js.map → treemap-GDKQZRPO-d0AbKEc4.js.map} +1 -1
  112. package/dist/static/assets/{xychartDiagram-PRI3JC2R-RZy33lFF.js → xychartDiagram-PRI3JC2R-CmSQMxUh.js} +3 -3
  113. package/dist/static/assets/{xychartDiagram-PRI3JC2R-RZy33lFF.js.map → xychartDiagram-PRI3JC2R-CmSQMxUh.js.map} +1 -1
  114. package/dist/static/index.html +2 -2
  115. package/dist/tools/fs.js +1 -1
  116. package/package.json +9 -7
  117. package/dist/agent-priming.js +0 -2051
  118. package/dist/apps/installed-file.js +0 -207
  119. package/dist/apps/runtime-port.js +0 -91
  120. package/dist/docs/dominds-agent-priming.md +0 -218
  121. package/dist/docs/dominds-agent-priming.zh.md +0 -196
  122. package/dist/docs/drive-logic-context-refactor-plan.zh.md +0 -338
  123. package/dist/docs/keep-going.md +0 -176
  124. package/dist/docs/keep-going.zh.md +0 -162
  125. package/dist/docs/kernel-app-architecture.md +0 -286
  126. package/dist/docs/kernel-app-architecture.zh.md +0 -285
  127. package/dist/docs/showing-by-doing.md +0 -208
  128. package/dist/docs/showing-by-doing.zh.md +0 -177
  129. package/dist/docs/team-mgmt-toolset.md +0 -482
  130. package/dist/docs/team-mgmt-toolset.zh.md +0 -426
  131. package/dist/llm/driver-entry.js +0 -28
  132. package/dist/llm/driver-v2/context-health.js +0 -121
  133. package/dist/llm/driver-v2/context.js +0 -56
  134. package/dist/llm/driver-v2/core.js +0 -1545
  135. package/dist/llm/driver-v2/index.js +0 -26
  136. package/dist/llm/driver-v2/orchestrator.js +0 -158
  137. package/dist/llm/driver-v2/policy.js +0 -129
  138. package/dist/llm/driver-v2/restore-dialog-hierarchy.js +0 -73
  139. package/dist/llm/driver-v2/round.js +0 -366
  140. package/dist/llm/driver-v2/runtime-utils.js +0 -365
  141. package/dist/llm/driver-v2/saying-events.js +0 -20
  142. package/dist/llm/driver-v2/subdialog-txn.js +0 -42
  143. package/dist/llm/driver-v2/supdialog-response.js +0 -400
  144. package/dist/llm/driver-v2/tellask-bridge.js +0 -1148
  145. package/dist/llm/driver-v2/types.js +0 -10
  146. package/dist/llm/driver-v2-ref-only/context-health.js +0 -121
  147. package/dist/llm/driver-v2-ref-only/context.js +0 -17
  148. package/dist/llm/driver-v2-ref-only/core.js +0 -1710
  149. package/dist/llm/driver-v2-ref-only/index.js +0 -26
  150. package/dist/llm/driver-v2-ref-only/orchestrator.js +0 -158
  151. package/dist/llm/driver-v2-ref-only/policy.js +0 -129
  152. package/dist/llm/driver-v2-ref-only/restore-dialog-hierarchy.js +0 -73
  153. package/dist/llm/driver-v2-ref-only/round.js +0 -366
  154. package/dist/llm/driver-v2-ref-only/runtime-utils.js +0 -473
  155. package/dist/llm/driver-v2-ref-only/saying-events.js +0 -18
  156. package/dist/llm/driver-v2-ref-only/subdialog-txn.js +0 -42
  157. package/dist/llm/driver-v2-ref-only/supdialog-response.js +0 -453
  158. package/dist/llm/driver-v2-ref-only/tellask-bridge.js +0 -1178
  159. package/dist/llm/driver-v2-ref-only/types.js +0 -10
  160. package/dist/llm/driver.js +0 -4093
  161. package/dist/minds/promptdocs.js +0 -263
  162. package/dist/server/prompts-routes.js +0 -545
  163. package/dist/shared/team-mgmt-manual.js +0 -120
  164. package/dist/shared/types/prompts.js +0 -2
  165. package/dist/shared/types/tellask.js +0 -8
  166. package/dist/showing-by-doing.js +0 -1091
  167. package/dist/snippets/README.en.md +0 -3
  168. package/dist/snippets/README.md +0 -4
  169. package/dist/static/assets/index-DMbwqOm6.js.map +0 -1
  170. package/dist/tellask.js +0 -439
  171. package/dist/tools/context-health.js +0 -177
  172. package/dist/tools/diag.js +0 -583
  173. package/dist/tools/prompts/memory/en/errors.md +0 -155
  174. package/dist/tools/prompts/memory/en/index.md +0 -47
  175. package/dist/tools/prompts/memory/en/principles.md +0 -87
  176. package/dist/tools/prompts/memory/en/scenarios.md +0 -174
  177. package/dist/tools/prompts/memory/en/tools.md +0 -129
  178. package/dist/tools/prompts/memory/zh/errors.md +0 -155
  179. package/dist/tools/prompts/memory/zh/index.md +0 -47
  180. package/dist/tools/prompts/memory/zh/principles.md +0 -89
  181. package/dist/tools/prompts/memory/zh/scenarios.md +0 -174
  182. package/dist/tools/prompts/memory/zh/tools.md +0 -129
  183. package/dist/tools/team-mgmt.js +0 -3487
  184. package/dist/utils/task-doc.js +0 -236
@@ -1,155 +0,0 @@
1
- # memory Error Handling
2
-
3
- ## Template (Errors)
4
-
5
- ### Error Chain (required)
6
-
7
- 1. Trigger Condition
8
- 2. Detection Signal
9
- 3. Recovery Steps
10
- 4. Success Criteria
11
- 5. Escalation Path (optional)
12
-
13
- ## Error Codes
14
-
15
- ### MEMORY_ALREADY_EXISTS
16
-
17
- **Description:** Path already exists, cannot use `add_memory` to create new memory.
18
-
19
- **Cause:**
20
-
21
- - The path you're trying to add is already occupied by another memory
22
-
23
- **Solution:**
24
-
25
- - Use `replace_memory` to update existing memory
26
- - Or use a different path to create new memory
27
-
28
- **Example:**
29
-
30
- ```
31
- Error:
32
- status: error
33
- error_code: MEMORY_ALREADY_EXISTS
34
- message: Path "project/todo" already exists, please use replace_memory to update
35
- ```
36
-
37
- ### MEMORY_NOT_FOUND
38
-
39
- **Description:** Path does not exist, cannot perform operation.
40
-
41
- **Cause:**
42
-
43
- - The memory path you're trying to access doesn't exist
44
- - The path was deleted or never created
45
-
46
- **Solution:**
47
-
48
- - For update/delete operations, first use `add_memory` to create
49
- - Check if the path is correct
50
-
51
- **Example:**
52
-
53
- ```
54
- Error:
55
- status: error
56
- error_code: MEMORY_NOT_FOUND
57
- message: Path "project/todo" does not exist, please use add_memory to create first
58
- ```
59
-
60
- ### MEMORY_PATH_INVALID
61
-
62
- **Description:** Path format is invalid.
63
-
64
- **Cause:**
65
-
66
- - Path contains illegal characters
67
- - Path length exceeds limit
68
-
69
- **Solution:**
70
-
71
- - Ensure path only contains letters, numbers, underscores, slashes
72
- - Path length should not exceed 255 characters
73
-
74
- **Example:**
75
-
76
- ```
77
- Error:
78
- status: error
79
- error_code: MEMORY_PATH_INVALID
80
- message: Path "project/*invalid*" contains illegal characters
81
- ```
82
-
83
- ### MEMORY_CONTENT_TOO_LARGE
84
-
85
- **Description:** Memory content is too large.
86
-
87
- **Cause:**
88
-
89
- - Single memory content exceeds 1MB limit
90
-
91
- **Solution:**
92
-
93
- - Compress content
94
- - Split into multiple memories
95
- - Use external storage (e.g., files)
96
-
97
- **Example:**
98
-
99
- ```
100
- Error:
101
- status: error
102
- error_code: MEMORY_CONTENT_TOO_LARGE
103
- message: Content size 1.2MB exceeds 1MB limit
104
- ```
105
-
106
- ### MEMORY_STORAGE_ERROR
107
-
108
- **Description:** Storage error.
109
-
110
- **Cause:**
111
-
112
- - Insufficient disk space
113
- - Permission issues
114
- - File system error
115
-
116
- **Solution:**
117
-
118
- - Check disk space
119
- - Check file permissions
120
- - Retry operation
121
-
122
- **Example:**
123
-
124
- ```
125
- Error:
126
- status: error
127
- error_code: MEMORY_STORAGE_ERROR
128
- message: Cannot write to storage, insufficient disk space
129
- ```
130
-
131
- ## Frequently Asked Questions
132
-
133
- ### Q: Does memory auto-save?
134
-
135
- A: Yes, all memory operations are immediately persisted to disk. No manual save is needed.
136
-
137
- ### Q: Is there a limit on the number of memories?
138
-
139
- A: There's no strict limit, but it's recommended to keep the number of memories reasonable (less than 100 recommended).
140
-
141
- ### Q: Can other members see my memories?
142
-
143
- A: No, memory is a personal memory tool, only the current agent can access it. If you need to share with team members, please use team_memory.
144
-
145
- ### Q: Will clear_memory delete all memories?
146
-
147
- A: Yes, `clear_memory` will delete all personal memories, this operation is irreversible. Please use with caution.
148
-
149
- ### Q: Do memories expire?
150
-
151
- A: No, memories are permanently saved until explicitly deleted.
152
-
153
- ### Q: How do I view all current memories?
154
-
155
- A: The agent can access all personal memories during response generation. You can directly ask the agent what memories it currently has.
@@ -1,47 +0,0 @@
1
- # memory Personal Memory Tools Manual
2
-
3
- ## Template (Index)
4
-
5
- ### One-line Positioning
6
-
7
- - <What this toolset is for, in one sentence>
8
-
9
- ### Tool List
10
-
11
- - <Enumerate core tools or point to Tools/Schema section>
12
-
13
- ### 30-Second Quickstart
14
-
15
- 1. <call ...>
16
- 2. <observe ...>
17
- 3. <next step ...>
18
-
19
- ### Navigation
20
-
21
- - principles / tools / scenarios / errors
22
-
23
- ### Boundaries vs Other Toolsets
24
-
25
- - <When to use this vs a sibling toolset>
26
-
27
- memory is Dominds' **personal memory toolset** for managing an agent's private memory:
28
-
29
- - **Privacy**: Memory is only visible to the current agent, not shared with other members
30
- - **Persistence**: Memory is persisted to disk and retained after conversation restarts
31
- - **Structured**: Supports organizing memory by path for easy categorization and retrieval
32
-
33
- ## Quick Navigation
34
-
35
- | Topic | Description |
36
- | ----------------------------- | ----------------------------------------------- |
37
- | [principles](./principles.md) | Core concepts, memory lifecycle, best practices |
38
- | [tools](./tools.md) | Complete tool list and interface contracts |
39
- | [scenarios](./scenarios.md) | Common usage scenarios (copy-paste ready) |
40
- | [errors](./errors.md) | Error codes and solutions |
41
-
42
- ## Status
43
-
44
- - Status: Implemented
45
- - Main implementation files:
46
- - Tool implementation: `dominds/main/tools/mem.ts`
47
- - Toolset metadata: `dominds/main/tools/builtins.ts`, `dominds/main/tools/registry.ts`
@@ -1,87 +0,0 @@
1
- # memory Principles and Core Concepts
2
-
3
- ## Template (Principles)
4
-
5
- ### Design Goals
6
-
7
- - <Goal 1>
8
- - <Goal 2>
9
-
10
- ### Contract Principles
11
-
12
- - <Input/Output contract rules>
13
-
14
- ### Safety & Boundaries
15
-
16
- - <Access constraints / guardrails>
17
-
18
- ### Failure & Recovery
19
-
20
- - <What to do when a call fails>
21
-
22
- ### Glossary
23
-
24
- - <Toolset-specific terms>
25
-
26
- ## Memory Model
27
-
28
- The memory toolset uses a **path key-value storage** model:
29
-
30
- - **Path**: Unique identifier for the memory, similar to a file system path, e.g., `project/todo` or `user/preferences/theme`
31
- - **Content**: Actual content of the memory, can be arbitrary text
32
-
33
- ## Tool Overview
34
-
35
- | Tool | Function |
36
- | -------------- | -------------------------------------------- |
37
- | add_memory | Create new memory (when path does not exist) |
38
- | replace_memory | Update existing memory (when path exists) |
39
- | drop_memory | Delete memory |
40
- | clear_memory | Clear all personal memory (irrecoverable) |
41
-
42
- ## Memory Lifecycle
43
-
44
- 1. **Create (add)**: Use `add_memory` to create new memory
45
- 2. **Read**: Agent can read existing memory during response generation
46
- 3. **Update (replace)**: Use `replace_memory` to update memory content
47
- 4. **Delete (drop)**: Use `drop_memory` to delete specific memory
48
-
49
- ## Best Practices
50
-
51
- ### 1. Path Naming Conventions
52
-
53
- - Use descriptive paths: `project/architecture`, `user/preferences/language`
54
- - Use `/` to organize hierarchy (this is the recommended usage), with guardrails:
55
- - Absolute paths are forbidden (must not start with `/`)
56
- - Path traversal is forbidden (`..` is not allowed)
57
- - Avoid `\\` (cross-platform readability; prefer `/`)
58
- - Keep paths _flat_: prefer a small number of topic files rather than a deep directory tree.
59
-
60
- ### 2. Content Format
61
-
62
- - Treat personal memory as a **carry-along stable-facts memo**: enable **0 ripgrep** startup within your scope.
63
- - Store stable facts only: **anchor points (file/symbol) + 1-line meaning + key contracts/priorities (≤3)**.
64
- - Fewer memory files is better: group facts that will be updated together into one file; avoid adding extra “directory-of-directory” layers.
65
- - Do not store task progress or daily state here:
66
- - Team-visible progress belongs in Taskdoc `progress`
67
- - Short-term working set belongs in reminders
68
-
69
- ### 3. Usage Scenarios
70
-
71
- - **Task persistence**: Save long-term task progress
72
- - **Context memory**: Save important information from conversation context
73
- - **Preference settings**: Save user preferences and configuration information
74
-
75
- > Note: If you find yourself using personal memory to store “current progress of this run”, it likely belongs in Taskdoc `progress` or reminders instead.
76
-
77
- ## Relationship with Other Tools
78
-
79
- - **team_memory**: Team shared memory, visible to all members
80
- - **reminder**: Temporary reminder, session-level
81
- - **change_mind**: Update taskdoc (goals/constraints/progress)
82
-
83
- ## Limitations and Notes
84
-
85
- 1. Memory content has size limit (max 1MB per memory)
86
- 2. Memory path cannot exceed 255 characters
87
- 3. `clear_memory` will delete all memory, **irrecoverable**
@@ -1,174 +0,0 @@
1
- # memory Usage Scenarios
2
-
3
- ## Template (Scenarios)
4
-
5
- ### Scenario Format
6
-
7
- - Goal
8
- - Preconditions
9
- - Steps
10
- - Expected Signal
11
- - Failure Branch
12
- - Completion Criteria
13
-
14
- ## Scenario 1: Task Progress Tracking
15
-
16
- ### Scenario Description
17
-
18
- In long-running tasks, you need to persist task progress to continue after restart.
19
-
20
- ### Example
21
-
22
- **Add Task List**
23
-
24
- ```typescript
25
- add_memory({
26
- path: 'project/i18n-tasks',
27
- content:
28
- '## TODO\n\n- [ ] Create ws_mod manual\n- [ ] Create team_mgmt manual\n- [ ] Create memory manual\n- [ ] Create control manual\n\n## In Progress\n- [ ] Create ws_mod manual [100%]',
29
- });
30
- ```
31
-
32
- **Update Task Progress**
33
-
34
- ```typescript
35
- replace_memory({
36
- path: 'project/i18n-tasks',
37
- content:
38
- '## TODO\n\n- [ ] Create team_mgmt manual\n- [ ] Create memory manual\n- [ ] Create control manual\n\n## Completed\n- [x] Create ws_mod manual\n\n## In Progress\n- [ ] Create team_mgmt manual [50%]',
39
- });
40
- ```
41
-
42
- ## Scenario 2: User Preferences Storage
43
-
44
- ### Scenario Description
45
-
46
- Save user preferences, such as programming language, theme, etc.
47
-
48
- ### Example
49
-
50
- **Save User Preferences**
51
-
52
- ```typescript
53
- add_memory({
54
- path: 'user/preferences',
55
- content:
56
- '## User Preferences\n\n- Programming Language: TypeScript\n- Code Style: strict\n- Theme: dark\n- Auto Save: true',
57
- });
58
- ```
59
-
60
- **Update Preferences**
61
-
62
- ```typescript
63
- replace_memory({
64
- path: 'user/preferences',
65
- content:
66
- '## User Preferences\n\n- Programming Language: TypeScript\n- Code Style: strict\n- Theme: light\n- Auto Save: true',
67
- });
68
- ```
69
-
70
- ## Scenario 3: Context Information Preservation
71
-
72
- ### Scenario Description
73
-
74
- In complex tasks, save important context information to avoid repeated queries.
75
-
76
- ### Example
77
-
78
- **Save API Information**
79
-
80
- ```typescript
81
- add_memory({
82
- path: 'context/api-endpoints',
83
- content:
84
- '## API Endpoints\n\n- User Login: POST /api/auth/login\n- Get User Info: GET /api/user/info\n- Update User Settings: PUT /api/user/settings\n\n## Authentication\n- Use Bearer Token\n- Validity: 24 hours',
85
- });
86
- ```
87
-
88
- **Save Tech Stack**
89
-
90
- ```typescript
91
- add_memory({
92
- path: 'context/tech-stack',
93
- content:
94
- '## Tech Stack\n\n- Frontend: React + TypeScript\n- Backend: Node.js + Express\n- Database: PostgreSQL\n- Cache: Redis',
95
- });
96
- ```
97
-
98
- ## Scenario 4: Meeting Notes
99
-
100
- ### Scenario Description
101
-
102
- Save meeting highlights and decisions.
103
-
104
- ### Example
105
-
106
- ```typescript
107
- add_memory({
108
- path: 'meeting/2024-01-15',
109
- content:
110
- '## Meeting Notes: 2024-01-15\n\n### Participants\n- @fullstack\n- @i18n\n- @ux\n\n### Agenda\n1. i18n manual creation plan\n2. man function UX improvements\n\n### Decisions\n- Prioritize creating ws_mod and team_mgmt manuals\n- man function supports fuzzy matching\n\n### TODO\n- @i18n: Create memory manual\n- @fullstack: Optimize man function',
111
- });
112
- ```
113
-
114
- ## Scenario 5: Knowledge Base
115
-
116
- ### Scenario Description
117
-
118
- Build a personal knowledge base and save learning notes.
119
-
120
- ### Example
121
-
122
- ```typescript
123
- add_memory({
124
- path: 'knowledge/typescript-tips',
125
- content:
126
- '## TypeScript Tips\n\n### 1. Type Inference\nconst x = 1; // Type inferred as number\n\n### 2. Interface vs Type\n- Interface: Extensible, suitable for object types\n- Type: Supports union types, intersection types\n\n### 3. Strict Mode\nEnabling strict mode provides better type safety',
127
- });
128
- ```
129
-
130
- ## Scenario 6: Temporary Notes
131
-
132
- ### Scenario Description
133
-
134
- Temporarily save information to process later.
135
-
136
- ### Example
137
-
138
- ```typescript
139
- add_memory({
140
- path: 'scratchpad/temp-notes',
141
- content:
142
- '## Temporary Notes\n\n- TODO: Check team.yaml configuration\n- TODO: Verify man function types\n- TODO: Update taskdoc progress',
143
- });
144
- ```
145
-
146
- **Delete after processing**
147
-
148
- ```typescript
149
- drop_memory({
150
- path: 'scratchpad/temp-notes',
151
- });
152
- ```
153
-
154
- ## Scenario 7: Cleaning Up Outdated Memory
155
-
156
- ### Scenario Description
157
-
158
- Regularly clean up memories that are no longer needed.
159
-
160
- ### Example
161
-
162
- ```typescript
163
- // View all current memories (agent can read)
164
- // Delete unnecessary memories one by one
165
- drop_memory({
166
- path: 'project/old-feature',
167
- });
168
- ```
169
-
170
- Or use `clear_memory` to clear all memories (use with caution):
171
-
172
- ```typescript
173
- clear_memory({});
174
- ```
@@ -1,129 +0,0 @@
1
- # memory Tool Reference
2
-
3
- ## Template (Tools)
4
-
5
- ### How to Read
6
-
7
- - The schema-generated "Tool Contract (Schema)" section is canonical for parameters/returns.
8
-
9
- ### Per-Tool Fields (order)
10
-
11
- 1. Purpose
12
- 2. Call Signature
13
- 3. Parameters (refer to schema)
14
- 4. Preconditions
15
- 5. Success Signal
16
- 6. Failure/Errors
17
- 7. Copy-Ready Example
18
- 8. Common Misuse
19
-
20
- ## Tool List
21
-
22
- ### 1. add_memory
23
-
24
- Create new memory (when path does not exist).
25
-
26
- **Parameters:**
27
-
28
- - `path` (required): Unique identifier for the memory
29
- - `content` (required): Memory content
30
-
31
- **Returns:**
32
-
33
- - Success: a short plain-text message in the work language (e.g. `Added`).
34
- - Failure: a plain-text error message (often starts with `Error:`) with an actionable next step (e.g. use `replace_memory`).
35
-
36
- **Errors:**
37
-
38
- - `MEMORY_ALREADY_EXISTS`: Path already exists, use `replace_memory` to update
39
-
40
- ### 2. replace_memory
41
-
42
- Update existing memory (when path exists).
43
-
44
- **Parameters:**
45
-
46
- - `path` (required): Unique identifier for the memory
47
- - `content` (required): New memory content
48
-
49
- **Returns:**
50
-
51
- - Success: a short plain-text message in the work language (e.g. `Updated`).
52
- - Failure: a plain-text error message (often starts with `Error:`) with an actionable next step (e.g. use `add_memory`).
53
-
54
- **Errors:**
55
-
56
- - `MEMORY_NOT_FOUND`: Path does not exist, use `add_memory` to create
57
-
58
- ### 3. drop_memory
59
-
60
- Delete specified memory.
61
-
62
- **Parameters:**
63
-
64
- - `path` (required): Memory path to delete
65
-
66
- **Returns:**
67
-
68
- - Success: a short plain-text message in the work language (e.g. `Deleted`).
69
- - Failure: a plain-text error message (often starts with `Error:`).
70
-
71
- **Errors:**
72
-
73
- - `MEMORY_NOT_FOUND`: Path does not exist
74
-
75
- ### 4. clear_memory
76
-
77
- Clear all personal memory.
78
-
79
- **Warning:** This operation is irreversible!
80
-
81
- **Parameters:** None
82
-
83
- **Returns:**
84
-
85
- - Success: a short plain-text message in the work language (e.g. `Cleared`). If there is nothing to clear, returns a message like `No personal memory to clear.`
86
- - Failure: a plain-text error message.
87
-
88
- **Errors:**
89
-
90
- - None (returns success even if no memories exist)
91
-
92
- ## Usage Examples
93
-
94
- ### Add New Memory
95
-
96
- ```typescript
97
- add_memory({
98
- path: 'project/todo',
99
- content: '- Complete i18n docs\n- Write test cases\n- Update README',
100
- });
101
- ```
102
-
103
- ### Update Existing Memory
104
-
105
- ```typescript
106
- replace_memory({
107
- path: 'project/todo',
108
- content: '- Complete i18n docs [DONE]\n- Write test cases [IN PROGRESS]\n- Update README',
109
- });
110
- ```
111
-
112
- ### Delete Memory
113
-
114
- ```typescript
115
- drop_memory({
116
- path: 'project/todo',
117
- });
118
- ```
119
-
120
- ### Clear All Memory
121
-
122
- ```typescript
123
- clear_memory({});
124
- ```
125
-
126
- ## Output and Language
127
-
128
- - Output is **plain text**, not structured JSON/YAML.
129
- - The message language follows the current **work language**.