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.
- package/README.md +9 -2
- package/README.zh.md +9 -2
- package/dist/apps/app-lock-file.js +33 -57
- package/dist/apps/configuration-file.js +267 -0
- package/dist/apps/enabled-apps.js +217 -252
- package/dist/apps/manifest.js +132 -0
- package/dist/apps/resolution-file.js +80 -192
- package/dist/apps/workspace-app-state.js +8 -0
- package/dist/cli/disable.js +18 -22
- package/dist/cli/enable.js +20 -58
- package/dist/cli/install.js +74 -80
- package/dist/cli/uninstall.js +48 -25
- package/dist/cli/update.js +36 -80
- package/dist/docs/app-constitution.md +12 -7
- package/dist/docs/app-constitution.zh.md +13 -8
- package/dist/llm/kernel-driver/engine.js +10 -4
- package/dist/llm/kernel-driver/flow.js +93 -0
- package/dist/llm/kernel-driver/loop.js +4 -1
- package/dist/llm/kernel-driver/subdialog.js +5 -1
- package/dist/llm/kernel-driver/tellask-special.js +48 -6
- package/dist/server/server-core.js +19 -4
- package/dist/server/websocket-handler.js +26 -6
- package/dist/static/assets/{_basePickBy-CmziIRM9.js → _basePickBy-B2o4z1Hf.js} +3 -3
- package/dist/static/assets/{_basePickBy-CmziIRM9.js.map → _basePickBy-B2o4z1Hf.js.map} +1 -1
- package/dist/static/assets/{_baseUniq-CgDZxcD0.js → _baseUniq-CLmcxjdl.js} +2 -2
- package/dist/static/assets/{_baseUniq-CgDZxcD0.js.map → _baseUniq-CLmcxjdl.js.map} +1 -1
- package/dist/static/assets/{arc-Df9rjNNk.js → arc-CymD_KN7.js} +2 -2
- package/dist/static/assets/{arc-Df9rjNNk.js.map → arc-CymD_KN7.js.map} +1 -1
- package/dist/static/assets/{architectureDiagram-VXUJARFQ-Bif8topC.js → architectureDiagram-VXUJARFQ-DJQfSJUH.js} +7 -7
- package/dist/static/assets/{architectureDiagram-VXUJARFQ-Bif8topC.js.map → architectureDiagram-VXUJARFQ-DJQfSJUH.js.map} +1 -1
- package/dist/static/assets/{blockDiagram-VD42YOAC-D9Egoflr.js → blockDiagram-VD42YOAC-pHVz60D0.js} +7 -7
- package/dist/static/assets/{blockDiagram-VD42YOAC-D9Egoflr.js.map → blockDiagram-VD42YOAC-pHVz60D0.js.map} +1 -1
- package/dist/static/assets/{c4Diagram-YG6GDRKO-DBf1NeBf.js → c4Diagram-YG6GDRKO-B0WnCfAT.js} +3 -3
- package/dist/static/assets/{c4Diagram-YG6GDRKO-DBf1NeBf.js.map → c4Diagram-YG6GDRKO-B0WnCfAT.js.map} +1 -1
- package/dist/static/assets/{channel-Dc34yAJl.js → channel-CX9BlKil.js} +2 -2
- package/dist/static/assets/{channel-Dc34yAJl.js.map → channel-CX9BlKil.js.map} +1 -1
- package/dist/static/assets/{chunk-4BX2VUAB-B65G1dJI.js → chunk-4BX2VUAB-lXArRj3o.js} +2 -2
- package/dist/static/assets/{chunk-4BX2VUAB-B65G1dJI.js.map → chunk-4BX2VUAB-lXArRj3o.js.map} +1 -1
- package/dist/static/assets/{chunk-55IACEB6-CSDEOGl2.js → chunk-55IACEB6-CdqwynH9.js} +2 -2
- package/dist/static/assets/{chunk-55IACEB6-CSDEOGl2.js.map → chunk-55IACEB6-CdqwynH9.js.map} +1 -1
- package/dist/static/assets/{chunk-B4BG7PRW-Cb6W3QWJ.js → chunk-B4BG7PRW-Y-uXcJst.js} +5 -5
- package/dist/static/assets/{chunk-B4BG7PRW-Cb6W3QWJ.js.map → chunk-B4BG7PRW-Y-uXcJst.js.map} +1 -1
- package/dist/static/assets/{chunk-DI55MBZ5-ZAJWeVWH.js → chunk-DI55MBZ5-C5xSbRST.js} +4 -4
- package/dist/static/assets/{chunk-DI55MBZ5-ZAJWeVWH.js.map → chunk-DI55MBZ5-C5xSbRST.js.map} +1 -1
- package/dist/static/assets/{chunk-FMBD7UC4-DiwRlImb.js → chunk-FMBD7UC4-5uefwCjI.js} +2 -2
- package/dist/static/assets/{chunk-FMBD7UC4-DiwRlImb.js.map → chunk-FMBD7UC4-5uefwCjI.js.map} +1 -1
- package/dist/static/assets/{chunk-QN33PNHL-wilj7fb5.js → chunk-QN33PNHL-DzWVcvpI.js} +2 -2
- package/dist/static/assets/{chunk-QN33PNHL-wilj7fb5.js.map → chunk-QN33PNHL-DzWVcvpI.js.map} +1 -1
- package/dist/static/assets/{chunk-QZHKN3VN-DGmviJfR.js → chunk-QZHKN3VN-BrrvAZdP.js} +2 -2
- package/dist/static/assets/{chunk-QZHKN3VN-DGmviJfR.js.map → chunk-QZHKN3VN-BrrvAZdP.js.map} +1 -1
- package/dist/static/assets/{chunk-TZMSLE5B-Nm5wTXa_.js → chunk-TZMSLE5B-DyKOlPTY.js} +2 -2
- package/dist/static/assets/{chunk-TZMSLE5B-Nm5wTXa_.js.map → chunk-TZMSLE5B-DyKOlPTY.js.map} +1 -1
- package/dist/static/assets/{classDiagram-2ON5EDUG-BvUbXD6H.js → classDiagram-2ON5EDUG-FCrnlCWC.js} +6 -6
- package/dist/static/assets/{classDiagram-2ON5EDUG-BvUbXD6H.js.map → classDiagram-2ON5EDUG-FCrnlCWC.js.map} +1 -1
- package/dist/static/assets/{classDiagram-v2-WZHVMYZB-BvUbXD6H.js → classDiagram-v2-WZHVMYZB-FCrnlCWC.js} +6 -6
- package/dist/static/assets/{classDiagram-v2-WZHVMYZB-BvUbXD6H.js.map → classDiagram-v2-WZHVMYZB-FCrnlCWC.js.map} +1 -1
- package/dist/static/assets/{clone-0VLS7GaA.js → clone-BlI81KqZ.js} +2 -2
- package/dist/static/assets/{clone-0VLS7GaA.js.map → clone-BlI81KqZ.js.map} +1 -1
- package/dist/static/assets/{cose-bilkent-S5V4N54A-anaPs-75.js → cose-bilkent-S5V4N54A-yM7S2atz.js} +2 -2
- package/dist/static/assets/{cose-bilkent-S5V4N54A-anaPs-75.js.map → cose-bilkent-S5V4N54A-yM7S2atz.js.map} +1 -1
- package/dist/static/assets/{dagre-6UL2VRFP-YwdsZ11r.js → dagre-6UL2VRFP-BcweuZHt.js} +7 -7
- package/dist/static/assets/{dagre-6UL2VRFP-YwdsZ11r.js.map → dagre-6UL2VRFP-BcweuZHt.js.map} +1 -1
- package/dist/static/assets/{diagram-PSM6KHXK-5KQCf3h2.js → diagram-PSM6KHXK-D4-QwLW1.js} +8 -8
- package/dist/static/assets/{diagram-PSM6KHXK-5KQCf3h2.js.map → diagram-PSM6KHXK-D4-QwLW1.js.map} +1 -1
- package/dist/static/assets/{diagram-QEK2KX5R-Mf24XxZL.js → diagram-QEK2KX5R-BVbuejJn.js} +7 -7
- package/dist/static/assets/{diagram-QEK2KX5R-Mf24XxZL.js.map → diagram-QEK2KX5R-BVbuejJn.js.map} +1 -1
- package/dist/static/assets/{diagram-S2PKOQOG-DyQjD4D5.js → diagram-S2PKOQOG-pB6N6Tq_.js} +7 -7
- package/dist/static/assets/{diagram-S2PKOQOG-DyQjD4D5.js.map → diagram-S2PKOQOG-pB6N6Tq_.js.map} +1 -1
- package/dist/static/assets/{erDiagram-Q2GNP2WA-CEzTKw1u.js → erDiagram-Q2GNP2WA-DLKmthuw.js} +5 -5
- package/dist/static/assets/{erDiagram-Q2GNP2WA-CEzTKw1u.js.map → erDiagram-Q2GNP2WA-DLKmthuw.js.map} +1 -1
- package/dist/static/assets/{flowDiagram-NV44I4VS-DT821XSz.js → flowDiagram-NV44I4VS-BsBhWukh.js} +6 -6
- package/dist/static/assets/{flowDiagram-NV44I4VS-DT821XSz.js.map → flowDiagram-NV44I4VS-BsBhWukh.js.map} +1 -1
- package/dist/static/assets/{ganttDiagram-JELNMOA3-DlmeVsGg.js → ganttDiagram-JELNMOA3-Debz-J-C.js} +3 -3
- package/dist/static/assets/{ganttDiagram-JELNMOA3-DlmeVsGg.js.map → ganttDiagram-JELNMOA3-Debz-J-C.js.map} +1 -1
- package/dist/static/assets/{gitGraphDiagram-V2S2FVAM-yAfyBG_d.js → gitGraphDiagram-V2S2FVAM-BnAPFBGR.js} +8 -8
- package/dist/static/assets/{gitGraphDiagram-V2S2FVAM-yAfyBG_d.js.map → gitGraphDiagram-V2S2FVAM-BnAPFBGR.js.map} +1 -1
- package/dist/static/assets/{graph-BYv8vyWe.js → graph-DbzWiBNK.js} +3 -3
- package/dist/static/assets/{graph-BYv8vyWe.js.map → graph-DbzWiBNK.js.map} +1 -1
- package/dist/static/assets/{index-DMbwqOm6.js → index-B-8J28g7.js} +987 -1049
- package/dist/static/assets/index-B-8J28g7.js.map +1 -0
- package/dist/static/assets/{index-BiNcBn_U.css → index-CD5wtC_i.css} +1 -1
- package/dist/static/assets/{infoDiagram-HS3SLOUP-DaadramQ.js → infoDiagram-HS3SLOUP-CZ5hWoxV.js} +6 -6
- package/dist/static/assets/{infoDiagram-HS3SLOUP-DaadramQ.js.map → infoDiagram-HS3SLOUP-CZ5hWoxV.js.map} +1 -1
- package/dist/static/assets/{journeyDiagram-XKPGCS4Q-ftN8hxu3.js → journeyDiagram-XKPGCS4Q-CKN3oSxk.js} +5 -5
- package/dist/static/assets/{journeyDiagram-XKPGCS4Q-ftN8hxu3.js.map → journeyDiagram-XKPGCS4Q-CKN3oSxk.js.map} +1 -1
- package/dist/static/assets/{kanban-definition-3W4ZIXB7-BIXETQ-C.js → kanban-definition-3W4ZIXB7-BQCMklfJ.js} +3 -3
- package/dist/static/assets/{kanban-definition-3W4ZIXB7-BIXETQ-C.js.map → kanban-definition-3W4ZIXB7-BQCMklfJ.js.map} +1 -1
- package/dist/static/assets/{layout-OTbrj0Ye.js → layout-C5B58szc.js} +5 -5
- package/dist/static/assets/{layout-OTbrj0Ye.js.map → layout-C5B58szc.js.map} +1 -1
- package/dist/static/assets/{linear-CVfOC669.js → linear-_32fut6G.js} +2 -2
- package/dist/static/assets/{linear-CVfOC669.js.map → linear-_32fut6G.js.map} +1 -1
- package/dist/static/assets/{mindmap-definition-VGOIOE7T-D2zv5uI9.js → mindmap-definition-VGOIOE7T-C_goMzjx.js} +4 -4
- package/dist/static/assets/{mindmap-definition-VGOIOE7T-D2zv5uI9.js.map → mindmap-definition-VGOIOE7T-C_goMzjx.js.map} +1 -1
- package/dist/static/assets/{pieDiagram-ADFJNKIX-DaUXTsv7.js → pieDiagram-ADFJNKIX-BQ2n0cOB.js} +8 -8
- package/dist/static/assets/{pieDiagram-ADFJNKIX-DaUXTsv7.js.map → pieDiagram-ADFJNKIX-BQ2n0cOB.js.map} +1 -1
- package/dist/static/assets/{quadrantDiagram-AYHSOK5B-B7O2wPX9.js → quadrantDiagram-AYHSOK5B-BLg7_neg.js} +3 -3
- package/dist/static/assets/{quadrantDiagram-AYHSOK5B-B7O2wPX9.js.map → quadrantDiagram-AYHSOK5B-BLg7_neg.js.map} +1 -1
- package/dist/static/assets/{requirementDiagram-UZGBJVZJ-DpauVPY1.js → requirementDiagram-UZGBJVZJ-DwkJt0zi.js} +4 -4
- package/dist/static/assets/{requirementDiagram-UZGBJVZJ-DpauVPY1.js.map → requirementDiagram-UZGBJVZJ-DwkJt0zi.js.map} +1 -1
- package/dist/static/assets/{sankeyDiagram-TZEHDZUN-B3Hbfvad.js → sankeyDiagram-TZEHDZUN-DmxmatUB.js} +2 -2
- package/dist/static/assets/{sankeyDiagram-TZEHDZUN-B3Hbfvad.js.map → sankeyDiagram-TZEHDZUN-DmxmatUB.js.map} +1 -1
- package/dist/static/assets/{sequenceDiagram-WL72ISMW-KdbWByWT.js → sequenceDiagram-WL72ISMW-KHU_eApU.js} +4 -4
- package/dist/static/assets/{sequenceDiagram-WL72ISMW-KdbWByWT.js.map → sequenceDiagram-WL72ISMW-KHU_eApU.js.map} +1 -1
- package/dist/static/assets/{stateDiagram-FKZM4ZOC-yDOCVezC.js → stateDiagram-FKZM4ZOC-B3DBCxAL.js} +9 -9
- package/dist/static/assets/{stateDiagram-FKZM4ZOC-yDOCVezC.js.map → stateDiagram-FKZM4ZOC-B3DBCxAL.js.map} +1 -1
- package/dist/static/assets/{stateDiagram-v2-4FDKWEC3-CpCJhvQO.js → stateDiagram-v2-4FDKWEC3-C-uIk7gh.js} +5 -5
- package/dist/static/assets/{stateDiagram-v2-4FDKWEC3-CpCJhvQO.js.map → stateDiagram-v2-4FDKWEC3-C-uIk7gh.js.map} +1 -1
- package/dist/static/assets/{timeline-definition-IT6M3QCI-CHxuEjhV.js → timeline-definition-IT6M3QCI-SysEcQCC.js} +3 -3
- package/dist/static/assets/{timeline-definition-IT6M3QCI-CHxuEjhV.js.map → timeline-definition-IT6M3QCI-SysEcQCC.js.map} +1 -1
- package/dist/static/assets/{treemap-GDKQZRPO-Bsqu3wIy.js → treemap-GDKQZRPO-d0AbKEc4.js} +5 -5
- package/dist/static/assets/{treemap-GDKQZRPO-Bsqu3wIy.js.map → treemap-GDKQZRPO-d0AbKEc4.js.map} +1 -1
- package/dist/static/assets/{xychartDiagram-PRI3JC2R-RZy33lFF.js → xychartDiagram-PRI3JC2R-CmSQMxUh.js} +3 -3
- package/dist/static/assets/{xychartDiagram-PRI3JC2R-RZy33lFF.js.map → xychartDiagram-PRI3JC2R-CmSQMxUh.js.map} +1 -1
- package/dist/static/index.html +2 -2
- package/dist/tools/fs.js +1 -1
- package/package.json +9 -7
- package/dist/agent-priming.js +0 -2051
- package/dist/apps/installed-file.js +0 -207
- package/dist/apps/runtime-port.js +0 -91
- package/dist/docs/dominds-agent-priming.md +0 -218
- package/dist/docs/dominds-agent-priming.zh.md +0 -196
- package/dist/docs/drive-logic-context-refactor-plan.zh.md +0 -338
- package/dist/docs/keep-going.md +0 -176
- package/dist/docs/keep-going.zh.md +0 -162
- package/dist/docs/kernel-app-architecture.md +0 -286
- package/dist/docs/kernel-app-architecture.zh.md +0 -285
- package/dist/docs/showing-by-doing.md +0 -208
- package/dist/docs/showing-by-doing.zh.md +0 -177
- package/dist/docs/team-mgmt-toolset.md +0 -482
- package/dist/docs/team-mgmt-toolset.zh.md +0 -426
- package/dist/llm/driver-entry.js +0 -28
- package/dist/llm/driver-v2/context-health.js +0 -121
- package/dist/llm/driver-v2/context.js +0 -56
- package/dist/llm/driver-v2/core.js +0 -1545
- package/dist/llm/driver-v2/index.js +0 -26
- package/dist/llm/driver-v2/orchestrator.js +0 -158
- package/dist/llm/driver-v2/policy.js +0 -129
- package/dist/llm/driver-v2/restore-dialog-hierarchy.js +0 -73
- package/dist/llm/driver-v2/round.js +0 -366
- package/dist/llm/driver-v2/runtime-utils.js +0 -365
- package/dist/llm/driver-v2/saying-events.js +0 -20
- package/dist/llm/driver-v2/subdialog-txn.js +0 -42
- package/dist/llm/driver-v2/supdialog-response.js +0 -400
- package/dist/llm/driver-v2/tellask-bridge.js +0 -1148
- package/dist/llm/driver-v2/types.js +0 -10
- package/dist/llm/driver-v2-ref-only/context-health.js +0 -121
- package/dist/llm/driver-v2-ref-only/context.js +0 -17
- package/dist/llm/driver-v2-ref-only/core.js +0 -1710
- package/dist/llm/driver-v2-ref-only/index.js +0 -26
- package/dist/llm/driver-v2-ref-only/orchestrator.js +0 -158
- package/dist/llm/driver-v2-ref-only/policy.js +0 -129
- package/dist/llm/driver-v2-ref-only/restore-dialog-hierarchy.js +0 -73
- package/dist/llm/driver-v2-ref-only/round.js +0 -366
- package/dist/llm/driver-v2-ref-only/runtime-utils.js +0 -473
- package/dist/llm/driver-v2-ref-only/saying-events.js +0 -18
- package/dist/llm/driver-v2-ref-only/subdialog-txn.js +0 -42
- package/dist/llm/driver-v2-ref-only/supdialog-response.js +0 -453
- package/dist/llm/driver-v2-ref-only/tellask-bridge.js +0 -1178
- package/dist/llm/driver-v2-ref-only/types.js +0 -10
- package/dist/llm/driver.js +0 -4093
- package/dist/minds/promptdocs.js +0 -263
- package/dist/server/prompts-routes.js +0 -545
- package/dist/shared/team-mgmt-manual.js +0 -120
- package/dist/shared/types/prompts.js +0 -2
- package/dist/shared/types/tellask.js +0 -8
- package/dist/showing-by-doing.js +0 -1091
- package/dist/snippets/README.en.md +0 -3
- package/dist/snippets/README.md +0 -4
- package/dist/static/assets/index-DMbwqOm6.js.map +0 -1
- package/dist/tellask.js +0 -439
- package/dist/tools/context-health.js +0 -177
- package/dist/tools/diag.js +0 -583
- package/dist/tools/prompts/memory/en/errors.md +0 -155
- package/dist/tools/prompts/memory/en/index.md +0 -47
- package/dist/tools/prompts/memory/en/principles.md +0 -87
- package/dist/tools/prompts/memory/en/scenarios.md +0 -174
- package/dist/tools/prompts/memory/en/tools.md +0 -129
- package/dist/tools/prompts/memory/zh/errors.md +0 -155
- package/dist/tools/prompts/memory/zh/index.md +0 -47
- package/dist/tools/prompts/memory/zh/principles.md +0 -89
- package/dist/tools/prompts/memory/zh/scenarios.md +0 -174
- package/dist/tools/prompts/memory/zh/tools.md +0 -129
- package/dist/tools/team-mgmt.js +0 -3487
- 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**.
|