dominds 1.6.2 → 1.6.4
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/dist/apps/installed-file.js +207 -0
- package/dist/apps/runtime-port.js +91 -0
- package/dist/apps/runtime.js +6 -0
- package/dist/docs/kernel-app-architecture.md +286 -0
- package/dist/docs/kernel-app-architecture.zh.md +285 -0
- package/dist/llm/driver-entry.js +28 -0
- package/dist/llm/driver-v2/context-health.js +121 -0
- package/dist/llm/driver-v2/context.js +56 -0
- package/dist/llm/driver-v2/core.js +1545 -0
- package/dist/llm/driver-v2/index.js +26 -0
- package/dist/llm/driver-v2/orchestrator.js +158 -0
- package/dist/llm/driver-v2/policy.js +129 -0
- package/dist/llm/driver-v2/restore-dialog-hierarchy.js +73 -0
- package/dist/llm/driver-v2/round.js +366 -0
- package/dist/llm/driver-v2/runtime-utils.js +365 -0
- package/dist/llm/driver-v2/saying-events.js +20 -0
- package/dist/llm/driver-v2/subdialog-txn.js +42 -0
- package/dist/llm/driver-v2/supdialog-response.js +400 -0
- package/dist/llm/driver-v2/tellask-bridge.js +1148 -0
- package/dist/llm/driver-v2/types.js +10 -0
- package/dist/llm/driver-v2-ref-only/context-health.js +121 -0
- package/dist/llm/driver-v2-ref-only/context.js +17 -0
- package/dist/llm/driver-v2-ref-only/core.js +1710 -0
- package/dist/llm/driver-v2-ref-only/index.js +26 -0
- package/dist/llm/driver-v2-ref-only/orchestrator.js +158 -0
- package/dist/llm/driver-v2-ref-only/policy.js +129 -0
- package/dist/llm/driver-v2-ref-only/restore-dialog-hierarchy.js +73 -0
- package/dist/llm/driver-v2-ref-only/round.js +366 -0
- package/dist/llm/driver-v2-ref-only/runtime-utils.js +473 -0
- package/dist/llm/driver-v2-ref-only/saying-events.js +18 -0
- package/dist/llm/driver-v2-ref-only/subdialog-txn.js +42 -0
- package/dist/llm/driver-v2-ref-only/supdialog-response.js +453 -0
- package/dist/llm/driver-v2-ref-only/tellask-bridge.js +1178 -0
- package/dist/llm/driver-v2-ref-only/types.js +10 -0
- package/dist/static/assets/{_basePickBy-DSCRdLZO.js → _basePickBy-BI5Rq0uy.js} +3 -3
- package/dist/static/assets/{_basePickBy-DSCRdLZO.js.map → _basePickBy-BI5Rq0uy.js.map} +1 -1
- package/dist/static/assets/{_baseUniq-4QF_OoKK.js → _baseUniq-B198d-KY.js} +2 -2
- package/dist/static/assets/{_baseUniq-4QF_OoKK.js.map → _baseUniq-B198d-KY.js.map} +1 -1
- package/dist/static/assets/{arc-BVQeKKx9.js → arc-DaOMBOGX.js} +2 -2
- package/dist/static/assets/{arc-BVQeKKx9.js.map → arc-DaOMBOGX.js.map} +1 -1
- package/dist/static/assets/{architectureDiagram-VXUJARFQ-B4I8KFTn.js → architectureDiagram-VXUJARFQ-D-S9nnw1.js} +7 -7
- package/dist/static/assets/{architectureDiagram-VXUJARFQ-B4I8KFTn.js.map → architectureDiagram-VXUJARFQ-D-S9nnw1.js.map} +1 -1
- package/dist/static/assets/{blockDiagram-VD42YOAC-CexS18Qs.js → blockDiagram-VD42YOAC-BTOxO1BR.js} +7 -7
- package/dist/static/assets/{blockDiagram-VD42YOAC-CexS18Qs.js.map → blockDiagram-VD42YOAC-BTOxO1BR.js.map} +1 -1
- package/dist/static/assets/{c4Diagram-YG6GDRKO-CuSqcxrm.js → c4Diagram-YG6GDRKO-BC30TrOS.js} +3 -3
- package/dist/static/assets/{c4Diagram-YG6GDRKO-CuSqcxrm.js.map → c4Diagram-YG6GDRKO-BC30TrOS.js.map} +1 -1
- package/dist/static/assets/{channel-BYCxsEk5.js → channel-BxJm9rVf.js} +2 -2
- package/dist/static/assets/{channel-BYCxsEk5.js.map → channel-BxJm9rVf.js.map} +1 -1
- package/dist/static/assets/{chunk-4BX2VUAB-N8tlmsFc.js → chunk-4BX2VUAB-DZhNVfjS.js} +2 -2
- package/dist/static/assets/{chunk-4BX2VUAB-N8tlmsFc.js.map → chunk-4BX2VUAB-DZhNVfjS.js.map} +1 -1
- package/dist/static/assets/{chunk-55IACEB6-DxOFWSAF.js → chunk-55IACEB6-CNu24wD5.js} +2 -2
- package/dist/static/assets/{chunk-55IACEB6-DxOFWSAF.js.map → chunk-55IACEB6-CNu24wD5.js.map} +1 -1
- package/dist/static/assets/{chunk-B4BG7PRW-C1tSyN_l.js → chunk-B4BG7PRW-B4pvVnuq.js} +5 -5
- package/dist/static/assets/{chunk-B4BG7PRW-C1tSyN_l.js.map → chunk-B4BG7PRW-B4pvVnuq.js.map} +1 -1
- package/dist/static/assets/{chunk-DI55MBZ5-BTmIrFZd.js → chunk-DI55MBZ5-DPtQdiEz.js} +4 -4
- package/dist/static/assets/{chunk-DI55MBZ5-BTmIrFZd.js.map → chunk-DI55MBZ5-DPtQdiEz.js.map} +1 -1
- package/dist/static/assets/{chunk-FMBD7UC4-s7Uar1x2.js → chunk-FMBD7UC4-BvHbQUmg.js} +2 -2
- package/dist/static/assets/{chunk-FMBD7UC4-s7Uar1x2.js.map → chunk-FMBD7UC4-BvHbQUmg.js.map} +1 -1
- package/dist/static/assets/{chunk-QN33PNHL-DC20K06j.js → chunk-QN33PNHL-BDzIqYT9.js} +2 -2
- package/dist/static/assets/{chunk-QN33PNHL-DC20K06j.js.map → chunk-QN33PNHL-BDzIqYT9.js.map} +1 -1
- package/dist/static/assets/{chunk-QZHKN3VN-6mPLLfRu.js → chunk-QZHKN3VN-DCSYTX8L.js} +2 -2
- package/dist/static/assets/{chunk-QZHKN3VN-6mPLLfRu.js.map → chunk-QZHKN3VN-DCSYTX8L.js.map} +1 -1
- package/dist/static/assets/{chunk-TZMSLE5B-GrDvKWzz.js → chunk-TZMSLE5B-CSzc4mi_.js} +2 -2
- package/dist/static/assets/{chunk-TZMSLE5B-GrDvKWzz.js.map → chunk-TZMSLE5B-CSzc4mi_.js.map} +1 -1
- package/dist/static/assets/{classDiagram-2ON5EDUG-fO59bj9m.js → classDiagram-2ON5EDUG-CJsEP-fz.js} +6 -6
- package/dist/static/assets/{classDiagram-2ON5EDUG-fO59bj9m.js.map → classDiagram-2ON5EDUG-CJsEP-fz.js.map} +1 -1
- package/dist/static/assets/{classDiagram-v2-WZHVMYZB-fO59bj9m.js → classDiagram-v2-WZHVMYZB-CJsEP-fz.js} +6 -6
- package/dist/static/assets/{classDiagram-v2-WZHVMYZB-fO59bj9m.js.map → classDiagram-v2-WZHVMYZB-CJsEP-fz.js.map} +1 -1
- package/dist/static/assets/{clone-IE0Tnwxn.js → clone-CNyZHFPL.js} +2 -2
- package/dist/static/assets/{clone-IE0Tnwxn.js.map → clone-CNyZHFPL.js.map} +1 -1
- package/dist/static/assets/{cose-bilkent-S5V4N54A-CfeoQnK-.js → cose-bilkent-S5V4N54A-DMvvhmW4.js} +2 -2
- package/dist/static/assets/{cose-bilkent-S5V4N54A-CfeoQnK-.js.map → cose-bilkent-S5V4N54A-DMvvhmW4.js.map} +1 -1
- package/dist/static/assets/{dagre-6UL2VRFP-DsiyUZhi.js → dagre-6UL2VRFP-BuNhcUpS.js} +7 -7
- package/dist/static/assets/{dagre-6UL2VRFP-DsiyUZhi.js.map → dagre-6UL2VRFP-BuNhcUpS.js.map} +1 -1
- package/dist/static/assets/{diagram-PSM6KHXK-IAjJ50CC.js → diagram-PSM6KHXK-D0APVthl.js} +8 -8
- package/dist/static/assets/{diagram-PSM6KHXK-IAjJ50CC.js.map → diagram-PSM6KHXK-D0APVthl.js.map} +1 -1
- package/dist/static/assets/{diagram-QEK2KX5R-DiZLndjJ.js → diagram-QEK2KX5R-_TJXK1XR.js} +7 -7
- package/dist/static/assets/{diagram-QEK2KX5R-DiZLndjJ.js.map → diagram-QEK2KX5R-_TJXK1XR.js.map} +1 -1
- package/dist/static/assets/{diagram-S2PKOQOG-ZL3Kts-u.js → diagram-S2PKOQOG-D58YgxwF.js} +7 -7
- package/dist/static/assets/{diagram-S2PKOQOG-ZL3Kts-u.js.map → diagram-S2PKOQOG-D58YgxwF.js.map} +1 -1
- package/dist/static/assets/{erDiagram-Q2GNP2WA-DbVLZtGY.js → erDiagram-Q2GNP2WA-DoStgM_4.js} +5 -5
- package/dist/static/assets/{erDiagram-Q2GNP2WA-DbVLZtGY.js.map → erDiagram-Q2GNP2WA-DoStgM_4.js.map} +1 -1
- package/dist/static/assets/{flowDiagram-NV44I4VS-CVd2p2Br.js → flowDiagram-NV44I4VS-CjRvEre8.js} +6 -6
- package/dist/static/assets/{flowDiagram-NV44I4VS-CVd2p2Br.js.map → flowDiagram-NV44I4VS-CjRvEre8.js.map} +1 -1
- package/dist/static/assets/{ganttDiagram-JELNMOA3-6NsYNEcf.js → ganttDiagram-JELNMOA3-BUTAh-bt.js} +3 -3
- package/dist/static/assets/{ganttDiagram-JELNMOA3-6NsYNEcf.js.map → ganttDiagram-JELNMOA3-BUTAh-bt.js.map} +1 -1
- package/dist/static/assets/{gitGraphDiagram-V2S2FVAM-B0Y7WTbj.js → gitGraphDiagram-V2S2FVAM-jNkE61r9.js} +8 -8
- package/dist/static/assets/{gitGraphDiagram-V2S2FVAM-B0Y7WTbj.js.map → gitGraphDiagram-V2S2FVAM-jNkE61r9.js.map} +1 -1
- package/dist/static/assets/{graph-BE1Fw6SE.js → graph-CCjti2O0.js} +3 -3
- package/dist/static/assets/{graph-BE1Fw6SE.js.map → graph-CCjti2O0.js.map} +1 -1
- package/dist/static/assets/{index-1Tlt2ebA.js → index-DLmfFirx.js} +328 -320
- package/dist/static/assets/index-DLmfFirx.js.map +1 -0
- package/dist/static/assets/{infoDiagram-HS3SLOUP-p6CQsk4A.js → infoDiagram-HS3SLOUP-BFxdxbX3.js} +6 -6
- package/dist/static/assets/{infoDiagram-HS3SLOUP-p6CQsk4A.js.map → infoDiagram-HS3SLOUP-BFxdxbX3.js.map} +1 -1
- package/dist/static/assets/{journeyDiagram-XKPGCS4Q-DR4cvYtN.js → journeyDiagram-XKPGCS4Q-BCLnxPc7.js} +5 -5
- package/dist/static/assets/{journeyDiagram-XKPGCS4Q-DR4cvYtN.js.map → journeyDiagram-XKPGCS4Q-BCLnxPc7.js.map} +1 -1
- package/dist/static/assets/{kanban-definition-3W4ZIXB7-JPOdtj9o.js → kanban-definition-3W4ZIXB7-BDeqtjCx.js} +3 -3
- package/dist/static/assets/{kanban-definition-3W4ZIXB7-JPOdtj9o.js.map → kanban-definition-3W4ZIXB7-BDeqtjCx.js.map} +1 -1
- package/dist/static/assets/{layout-BOn5O0Mv.js → layout-BcSBhjCx.js} +5 -5
- package/dist/static/assets/{layout-BOn5O0Mv.js.map → layout-BcSBhjCx.js.map} +1 -1
- package/dist/static/assets/{linear-BVAPTXI-.js → linear-yE500fJs.js} +2 -2
- package/dist/static/assets/{linear-BVAPTXI-.js.map → linear-yE500fJs.js.map} +1 -1
- package/dist/static/assets/{mindmap-definition-VGOIOE7T-DUJXw6w6.js → mindmap-definition-VGOIOE7T-B7T5bXb-.js} +4 -4
- package/dist/static/assets/{mindmap-definition-VGOIOE7T-DUJXw6w6.js.map → mindmap-definition-VGOIOE7T-B7T5bXb-.js.map} +1 -1
- package/dist/static/assets/{pieDiagram-ADFJNKIX-76JJOJvZ.js → pieDiagram-ADFJNKIX-CWFbaJ0k.js} +8 -8
- package/dist/static/assets/{pieDiagram-ADFJNKIX-76JJOJvZ.js.map → pieDiagram-ADFJNKIX-CWFbaJ0k.js.map} +1 -1
- package/dist/static/assets/{quadrantDiagram-AYHSOK5B-iKXJUo4i.js → quadrantDiagram-AYHSOK5B-DNdamKCt.js} +3 -3
- package/dist/static/assets/{quadrantDiagram-AYHSOK5B-iKXJUo4i.js.map → quadrantDiagram-AYHSOK5B-DNdamKCt.js.map} +1 -1
- package/dist/static/assets/{requirementDiagram-UZGBJVZJ-B0uk_5yk.js → requirementDiagram-UZGBJVZJ-Ct8UB1vk.js} +4 -4
- package/dist/static/assets/{requirementDiagram-UZGBJVZJ-B0uk_5yk.js.map → requirementDiagram-UZGBJVZJ-Ct8UB1vk.js.map} +1 -1
- package/dist/static/assets/{sankeyDiagram-TZEHDZUN-O3weNg52.js → sankeyDiagram-TZEHDZUN-DC7E0Ymo.js} +2 -2
- package/dist/static/assets/{sankeyDiagram-TZEHDZUN-O3weNg52.js.map → sankeyDiagram-TZEHDZUN-DC7E0Ymo.js.map} +1 -1
- package/dist/static/assets/{sequenceDiagram-WL72ISMW-DFnXuPNE.js → sequenceDiagram-WL72ISMW-IiC8_KXA.js} +4 -4
- package/dist/static/assets/{sequenceDiagram-WL72ISMW-DFnXuPNE.js.map → sequenceDiagram-WL72ISMW-IiC8_KXA.js.map} +1 -1
- package/dist/static/assets/{stateDiagram-FKZM4ZOC-BZjZXttD.js → stateDiagram-FKZM4ZOC-CCJb2r9z.js} +9 -9
- package/dist/static/assets/{stateDiagram-FKZM4ZOC-BZjZXttD.js.map → stateDiagram-FKZM4ZOC-CCJb2r9z.js.map} +1 -1
- package/dist/static/assets/{stateDiagram-v2-4FDKWEC3-C_R3IF0y.js → stateDiagram-v2-4FDKWEC3-BvHtU6GE.js} +5 -5
- package/dist/static/assets/{stateDiagram-v2-4FDKWEC3-C_R3IF0y.js.map → stateDiagram-v2-4FDKWEC3-BvHtU6GE.js.map} +1 -1
- package/dist/static/assets/{timeline-definition-IT6M3QCI-Kkhw0x0F.js → timeline-definition-IT6M3QCI-Bn2Z-SBO.js} +3 -3
- package/dist/static/assets/{timeline-definition-IT6M3QCI-Kkhw0x0F.js.map → timeline-definition-IT6M3QCI-Bn2Z-SBO.js.map} +1 -1
- package/dist/static/assets/{treemap-GDKQZRPO-DCcRUg7I.js → treemap-GDKQZRPO-BQopYfN_.js} +5 -5
- package/dist/static/assets/{treemap-GDKQZRPO-DCcRUg7I.js.map → treemap-GDKQZRPO-BQopYfN_.js.map} +1 -1
- package/dist/static/assets/{xychartDiagram-PRI3JC2R-DQKFjqLB.js → xychartDiagram-PRI3JC2R-CsLeQwkI.js} +3 -3
- package/dist/static/assets/{xychartDiagram-PRI3JC2R-DQKFjqLB.js.map → xychartDiagram-PRI3JC2R-CsLeQwkI.js.map} +1 -1
- package/dist/static/index.html +1 -1
- package/dist/tools/prompts/memory/en/errors.md +155 -0
- package/dist/tools/prompts/memory/en/index.md +47 -0
- package/dist/tools/prompts/memory/en/principles.md +79 -0
- package/dist/tools/prompts/memory/en/scenarios.md +174 -0
- package/dist/tools/prompts/memory/en/tools.md +154 -0
- package/dist/tools/prompts/memory/zh/errors.md +155 -0
- package/dist/tools/prompts/memory/zh/index.md +47 -0
- package/dist/tools/prompts/memory/zh/principles.md +79 -0
- package/dist/tools/prompts/memory/zh/scenarios.md +174 -0
- package/dist/tools/prompts/memory/zh/tools.md +154 -0
- package/package.json +1 -1
- package/dist/static/assets/index-1Tlt2ebA.js.map +0 -1
|
@@ -0,0 +1,285 @@
|
|
|
1
|
+
# Kernel–App 架构(原型 v0.1)
|
|
2
|
+
|
|
3
|
+
English version: [English](./kernel-app-architecture.md)
|
|
4
|
+
|
|
5
|
+
## 范围与目标
|
|
6
|
+
|
|
7
|
+
本文件描述 Dominds 的 Kernel–App 分离原型设计,覆盖:
|
|
8
|
+
|
|
9
|
+
- 两级 namespace(kernel 外层 / app 内层)与解析规则
|
|
10
|
+
- app install json(`app --json`)扩展字段
|
|
11
|
+
- export/import 语义与冲突处理
|
|
12
|
+
- app defunc 语义
|
|
13
|
+
- app 集成手册(`app_integration_manual`)
|
|
14
|
+
- app 语言约束(work/ui language 与 i18n)
|
|
15
|
+
- `<rtws>/.apps/<app-id>/team.yaml` 增量覆盖 DSL
|
|
16
|
+
|
|
17
|
+
本原型的代码实现用于 **概念与功能验证**;本文件是“综合方案推进”的主载体(可被后续实现/迁移/评审稳定引用)。
|
|
18
|
+
|
|
19
|
+
## 非目标
|
|
20
|
+
|
|
21
|
+
- 2.x 前不引入协议/schema 版本与兼容策略
|
|
22
|
+
- 2.x 前不引入 sandbox 隔离
|
|
23
|
+
- run control 大幅扩展不在本文讨论(将单独出专项文档)
|
|
24
|
+
|
|
25
|
+
## 核心概念
|
|
26
|
+
|
|
27
|
+
- Kernel registry 维持当前 dominds 状态,内置能力将逐步迁出为独立 app。
|
|
28
|
+
- 每个 app 维护独立 registry,**app 本地优先、允许同名覆盖**。
|
|
29
|
+
- app 不会把对象注册到 kernel registry。
|
|
30
|
+
- app 之间互相隔离,只有通过 export/import 显式交换对象。
|
|
31
|
+
|
|
32
|
+
## Identity 与解析(Resolution)
|
|
33
|
+
|
|
34
|
+
### 名称空间
|
|
35
|
+
|
|
36
|
+
- 两级 scope:`kernel` 与 `app`。
|
|
37
|
+
- 在“运行时解析”中,对象的 **短 ID**(例如 `toolsetId`、`memberId`、`toolName`)仍然以当前 kernel 的习惯用法为主。
|
|
38
|
+
- 在“日志/诊断/Problems/文档”中,需要可唯一指认来源,因此引入 **Qualified Id**(仅用于诊断/显示,不强制写入 wire 协议):
|
|
39
|
+
- `kernel:<name>`
|
|
40
|
+
- `app:<appId>:<name>`
|
|
41
|
+
|
|
42
|
+
### 解析顺序(app 内)
|
|
43
|
+
|
|
44
|
+
对任意解析请求(tool/toolset/member),在 app 内的解析顺序固定为:
|
|
45
|
+
|
|
46
|
+
1. `local(app)`(含:app 自身注册 + import 进来的对象)
|
|
47
|
+
2. `kernel`
|
|
48
|
+
|
|
49
|
+
说明:
|
|
50
|
+
|
|
51
|
+
- **允许同名覆盖**仅发生在 `local(app)` 覆盖 `kernel` 的场景。
|
|
52
|
+
- App 之间互不覆盖;若 import 导致 `local(app)` 内部同名冲突,则 app 置为 defunc。
|
|
53
|
+
|
|
54
|
+
## App install json(`app --json`)
|
|
55
|
+
|
|
56
|
+
在现有 `DomindsAppInstallJsonV1` 基础上新增:
|
|
57
|
+
|
|
58
|
+
- `depends?: [{ appId: string; versionRange: string }]`
|
|
59
|
+
- `exports?: { members?: string[]; toolsets?: string[] }`
|
|
60
|
+
|
|
61
|
+
约定:
|
|
62
|
+
|
|
63
|
+
- `exports` 为空表示不允许被 import。
|
|
64
|
+
- `exports` 可以列出多个对象,但 import 的最小单元固定为 **单个成员 / 单个工具集**(一次 import 指向一个 ID)。
|
|
65
|
+
- `exports` 中的成员必须来自 `contributes.teammatesYamlRelPath` 的成员定义。
|
|
66
|
+
- `exports` 中的工具集必须来自 `contributes.toolsets`。
|
|
67
|
+
|
|
68
|
+
## Registry 与解析规则
|
|
69
|
+
|
|
70
|
+
- App 内对象解析顺序:**local(app) → kernel**。
|
|
71
|
+
- App 之间互不覆盖;若 import 后发生同名冲突,app 置为 defunc。
|
|
72
|
+
- Kernel registry 不接收 app 注册对象,因此不存在“从 kernel registry 移除”这一操作。
|
|
73
|
+
- defunc 的 app 不参与解析(但其对象也不会被“移除”——因为它们从未进入 kernel registry)。
|
|
74
|
+
|
|
75
|
+
## Export / Import 语义
|
|
76
|
+
|
|
77
|
+
### Export
|
|
78
|
+
|
|
79
|
+
- 由 app install json 的 `exports` 声明。
|
|
80
|
+
- Kernel 对外提供 app exports 查询(API 形态可在实现阶段确定)。
|
|
81
|
+
|
|
82
|
+
### Import
|
|
83
|
+
|
|
84
|
+
- **成员 import**:在 app 的 `team.yaml` 中声明。
|
|
85
|
+
- **工具集 import**:在 app 的 `team.yaml` 中声明;运行时通过 dominds API 拉取工具集元信息,并注册到 app registry。
|
|
86
|
+
|
|
87
|
+
推荐结构(示意):
|
|
88
|
+
|
|
89
|
+
```yaml
|
|
90
|
+
imports:
|
|
91
|
+
members:
|
|
92
|
+
- app: foo_app
|
|
93
|
+
id: npc_foo
|
|
94
|
+
toolsets:
|
|
95
|
+
- app: bar_app
|
|
96
|
+
id: bar_toolset
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
### 冲突与依赖失败
|
|
100
|
+
|
|
101
|
+
- import 冲突或依赖不满足 → app 置为 defunc。
|
|
102
|
+
|
|
103
|
+
#### 冲突矩阵(最小规则集)
|
|
104
|
+
|
|
105
|
+
| 场景 | 结果 |
|
|
106
|
+
| ------------------------------------------- | ------------------------- |
|
|
107
|
+
| `local(app)` 与 `kernel` 同名 | 允许(local 覆盖 kernel) |
|
|
108
|
+
| import 的 member/toolset 与 app 本地同名 | defunc |
|
|
109
|
+
| import 的 member/toolset 与其它 import 同名 | defunc |
|
|
110
|
+
| import 指向未 export 的对象 | defunc |
|
|
111
|
+
| depends 不满足(缺失/版本不匹配) | defunc |
|
|
112
|
+
|
|
113
|
+
## Defunc 语义
|
|
114
|
+
|
|
115
|
+
- defunc 后 app 功能不可用。
|
|
116
|
+
- 不会从 registry 移除(app registry 不再被使用;kernel registry 没有 app 对象)。
|
|
117
|
+
- defunc 原因应被记录并可被诊断。
|
|
118
|
+
|
|
119
|
+
### Defunc 触发条件(建议枚举)
|
|
120
|
+
|
|
121
|
+
- `MANIFEST_INVALID`:install json 字段缺失/格式错误。
|
|
122
|
+
- `DEPENDENCY_MISSING` / `DEPENDENCY_VERSION_MISMATCH`:depends 缺失或不满足。
|
|
123
|
+
- `EXPORTS_INVALID`:exports 声明引用不存在的 member/toolset。
|
|
124
|
+
- `IMPORT_NOT_EXPORTED`:import 指向的对象未在对方 exports 声明。
|
|
125
|
+
- `IMPORT_CONFLICT`:import 引入同名冲突。
|
|
126
|
+
- `TEAM_OVERRIDE_INVALID`:`<rtws>/.apps/<app-id>/team.yaml` 覆盖 DSL 解析或校验失败。
|
|
127
|
+
- `IMPORT_FETCH_FAILED`:通过 API 拉取 toolset 元信息失败或返回无效。
|
|
128
|
+
|
|
129
|
+
### 重试语义(建议)
|
|
130
|
+
|
|
131
|
+
- defunc 默认 **可重试**:当依赖/配置问题被修复后,kernel 在下一次 app 刷新周期重新加载该 app。
|
|
132
|
+
- 重试不会自动修改已有对话/历史 round;仅影响后续解析与新调用。
|
|
133
|
+
|
|
134
|
+
### 可观测性(建议)
|
|
135
|
+
|
|
136
|
+
- defunc 必须进入 Problems(或等价的可见面),至少包含:`appId`、`reasonKind`、`detail`、`firstSeenAt`、`lastSeenAt`、`retryable`、`suggestedAction`。
|
|
137
|
+
- `app_integration_manual` 调用失败 **不触发 defunc**(失败应被记录,但不应让 app 进入不可用)。
|
|
138
|
+
|
|
139
|
+
## App 集成手册(`app_integration_manual`)
|
|
140
|
+
|
|
141
|
+
- kernel 固定工具:`app_integration_manual`
|
|
142
|
+
- 参数:`{ appId: string, language?: string }`
|
|
143
|
+
- 未指定 `language` 时默认 **work language**。
|
|
144
|
+
- kernel 通过 IPC 路由到 app host,由 app 返回内容。
|
|
145
|
+
- app 可以静态输出 markdown,或运行时动态生成。
|
|
146
|
+
- app 必须提供 zh/en 双语内容。
|
|
147
|
+
- 调用失败不触发 defunc(返回错误即可)。
|
|
148
|
+
|
|
149
|
+
## 语言约束
|
|
150
|
+
|
|
151
|
+
- **work language** 来自 `LANG` 环境变量,kernel 与 app host 继承并且运行期不可变。
|
|
152
|
+
- app 必须遵守 kernel 的 work language。
|
|
153
|
+
- app UI 可以独立设置 ui language。
|
|
154
|
+
- 所有 app 必须至少支持 zh/en 双语。
|
|
155
|
+
|
|
156
|
+
## `team.yaml` 增量覆盖 DSL
|
|
157
|
+
|
|
158
|
+
覆盖文件:`<rtws>/.apps/<app-id>/team.yaml`
|
|
159
|
+
|
|
160
|
+
- 无需 `actions:` 顶层。
|
|
161
|
+
- 使用领域特定语法,支持 **add/replace/modify/delete**。
|
|
162
|
+
- 每次读取磁盘时执行动作,失败则 app 置为 defunc。
|
|
163
|
+
|
|
164
|
+
示意:
|
|
165
|
+
|
|
166
|
+
```yaml
|
|
167
|
+
version: 1
|
|
168
|
+
|
|
169
|
+
add:
|
|
170
|
+
members:
|
|
171
|
+
- id: npc_new
|
|
172
|
+
value:
|
|
173
|
+
name: 新NPC
|
|
174
|
+
toolsets: [trae_toolset]
|
|
175
|
+
|
|
176
|
+
replace:
|
|
177
|
+
members:
|
|
178
|
+
- id: npc_old
|
|
179
|
+
value:
|
|
180
|
+
name: 旧NPC
|
|
181
|
+
hidden: true
|
|
182
|
+
|
|
183
|
+
modify:
|
|
184
|
+
members:
|
|
185
|
+
- id: npc_village_head
|
|
186
|
+
set:
|
|
187
|
+
toolsets: [trae_toolset, extra_toolset]
|
|
188
|
+
streaming: true
|
|
189
|
+
unset: [tools]
|
|
190
|
+
merge:
|
|
191
|
+
model_params:
|
|
192
|
+
codex:
|
|
193
|
+
temperature: 0.2
|
|
194
|
+
member_defaults:
|
|
195
|
+
set:
|
|
196
|
+
provider: codex
|
|
197
|
+
|
|
198
|
+
delete:
|
|
199
|
+
members:
|
|
200
|
+
- id: npc_removed
|
|
201
|
+
|
|
202
|
+
set_default_responder: npc_village_head
|
|
203
|
+
|
|
204
|
+
add_shell_specialist:
|
|
205
|
+
- npc_village_head
|
|
206
|
+
|
|
207
|
+
remove_shell_specialist:
|
|
208
|
+
- npc_foo
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
语义约束:
|
|
212
|
+
|
|
213
|
+
- `modify_member` 支持 `set`/`unset`/`merge`,其中 `merge` 对对象执行深合并。
|
|
214
|
+
- 所有新增/替换/修改需经过现有 team.yaml 校验逻辑。
|
|
215
|
+
- 出现冲突或解析失败,app 置 defunc。
|
|
216
|
+
|
|
217
|
+
## 加载流程(建议)
|
|
218
|
+
|
|
219
|
+
1. 解析并落实工具集(本地 toolsets + imports.toolsets),**先注册工具集与内含工具**
|
|
220
|
+
2. 读取 app 内置 team.yaml
|
|
221
|
+
3. 解析 imports.members
|
|
222
|
+
4. 应用 `<rtws>/.apps/<app-id>/team.yaml` 覆盖
|
|
223
|
+
5. 执行校验(此时工具/工具集已可解析)
|
|
224
|
+
6. 成功 → 注册成员到 app registry
|
|
225
|
+
7. 失败 → app defunc
|
|
226
|
+
|
|
227
|
+
## 复核包(Review Packet)
|
|
228
|
+
|
|
229
|
+
本节用于让 reviewer 在 30 分钟内完成复核并继续推进(不把实现细节写进差遣牒 progress)。
|
|
230
|
+
|
|
231
|
+
### 产物索引(Artifacts)
|
|
232
|
+
|
|
233
|
+
- 架构文档(语义源):`dominds/docs/kernel-app-architecture.zh.md`
|
|
234
|
+
- 英文对齐:`dominds/docs/kernel-app-architecture.md`
|
|
235
|
+
|
|
236
|
+
### 近期变更影响面(Delta)
|
|
237
|
+
|
|
238
|
+
- WebSocket 驱动不再接收 `runControlId/runControlInput`(run control 的大幅扩展另起专项文档)。
|
|
239
|
+
- apps-host 的 run control 结果不再支持 `systemPromptPatch/prompt`(收敛为最小的 continue/reject 形态)。
|
|
240
|
+
- kernel-driver 的 context-health 驱动逻辑对齐 driver-v2 的实现方式(仅作为原型期收敛/清理)。
|
|
241
|
+
|
|
242
|
+
### 最小行为复核(Smoke,建议)
|
|
243
|
+
|
|
244
|
+
以下 smoke 以“原型仅概念/功能验证”为前提,重点验证系统未因近期清理而破坏既有路径:
|
|
245
|
+
|
|
246
|
+
1. `pnpm -C dominds run lint:types` 通过。
|
|
247
|
+
2. 若当前 rtws 存在已启用 app:启动后 apps runtime 能启动 apps-host,并将 app 的 `contributes.toolsets` 注册为 proxy tools(不发生 name collision)。
|
|
248
|
+
3. 在 WebUI 驱动对话与 Q4H 回答时,不再需要/不再发送 `runControlId/runControlInput`。
|
|
249
|
+
|
|
250
|
+
## 原型现状与问题清单(Gap List)
|
|
251
|
+
|
|
252
|
+
本原型当前已具备的“可验证骨架”(仅陈述事实,不承诺完备):
|
|
253
|
+
|
|
254
|
+
- 已有 apps runtime + apps-host IPC 基础设施,可启动 apps-host 子进程并转发 tool 调用。
|
|
255
|
+
- 已支持按 app 的 `contributes.toolsets` 注册 proxy toolset/tool(用于概念/功能验证)。
|
|
256
|
+
- 已支持 app 声明 dialog run controls 的注册(但 run control 语义扩展另起专项文档)。
|
|
257
|
+
|
|
258
|
+
本原型尚未闭环/需要后续实现明确落点的事项(作为“现状与问题”产物):
|
|
259
|
+
|
|
260
|
+
- `depends/exports/imports` 的加载、校验与冲突处理目前主要停留在架构规格层,尚需落地实现与端到端验证。
|
|
261
|
+
- defunc 的生命周期状态机、Problems 可观测面、可重试/重载入口需要实现级闭包(含日志/错误分类)。
|
|
262
|
+
- `<rtws>/.apps/<app-id>/team.yaml` override DSL 的实际读取/动作执行/校验落点需要实现与回归。
|
|
263
|
+
- `app_integration_manual(appId, language?)` 的 kernel 固定工具与 IPC 路由需要实现与回归。
|
|
264
|
+
- 迁移路线图(内置能力迁出顺序、回滚策略、dogfooding gate)需在后续实现阶段形成可执行清单。
|
|
265
|
+
|
|
266
|
+
## 完成定义(验收口径)
|
|
267
|
+
|
|
268
|
+
当以下条件满足时,可认为本原型的“综合方案推进”文档交付完成:
|
|
269
|
+
|
|
270
|
+
- 本文覆盖并明确:Identity/Resolution、defunc 触发与可重试、imports/exports 粒度与冲突矩阵、team.yaml override DSL、`app_integration_manual` 契约。
|
|
271
|
+
- 关键规则使用“发生 X → 系统做 Y”的句式,且没有依赖读源码才能理解的隐式前提。
|
|
272
|
+
- `kernel-app-architecture.zh.md` 与英文版 `kernel-app-architecture.md` 同步一致(zh 为语义基准)。
|
|
273
|
+
|
|
274
|
+
## 关键落点(现有代码)
|
|
275
|
+
|
|
276
|
+
- install json 解析:`dominds/main/apps/app-json.ts`
|
|
277
|
+
- apps runtime:`dominds/main/apps/runtime.ts`
|
|
278
|
+
- apps host contract:`dominds/main/apps-host/app-host-contract.ts`
|
|
279
|
+
- apps host IPC:`dominds/main/apps-host/ipc-types.ts`
|
|
280
|
+
- team.yaml 解析:`dominds/main/team.ts`
|
|
281
|
+
- app teammates loader:`dominds/main/apps/teammates.ts`
|
|
282
|
+
|
|
283
|
+
---
|
|
284
|
+
|
|
285
|
+
本文件为原型阶段设计草案,后续实现细节会跟随代码落地更新。
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getActiveDriverEngine = getActiveDriverEngine;
|
|
4
|
+
exports.driveDialogStream = driveDialogStream;
|
|
5
|
+
exports.emitSayingEvents = emitSayingEvents;
|
|
6
|
+
exports.supplyResponseToSupdialog = supplyResponseToSupdialog;
|
|
7
|
+
exports.restoreDialogHierarchy = restoreDialogHierarchy;
|
|
8
|
+
exports.runBackendDriver = runBackendDriver;
|
|
9
|
+
const driver_v2_1 = require("./driver-v2");
|
|
10
|
+
const ACTIVE_DRIVER_ENGINE = 'v2';
|
|
11
|
+
function getActiveDriverEngine() {
|
|
12
|
+
return ACTIVE_DRIVER_ENGINE;
|
|
13
|
+
}
|
|
14
|
+
async function driveDialogStream(...args) {
|
|
15
|
+
return await (0, driver_v2_1.driveDialogStream)(...args);
|
|
16
|
+
}
|
|
17
|
+
async function emitSayingEvents(...args) {
|
|
18
|
+
return await (0, driver_v2_1.emitSayingEvents)(...args);
|
|
19
|
+
}
|
|
20
|
+
async function supplyResponseToSupdialog(...args) {
|
|
21
|
+
return await (0, driver_v2_1.supplyResponseToSupdialog)(...args);
|
|
22
|
+
}
|
|
23
|
+
async function restoreDialogHierarchy(...args) {
|
|
24
|
+
return await (0, driver_v2_1.restoreDialogHierarchy)(...args);
|
|
25
|
+
}
|
|
26
|
+
function runBackendDriver() {
|
|
27
|
+
return (0, driver_v2_1.runBackendDriver)();
|
|
28
|
+
}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DRIVER_V2_DEFAULT_CAUTION_REMEDIATION_CADENCE_GENERATIONS = exports.DRIVER_V2_DEFAULT_CRITICAL_COUNTDOWN_GENERATIONS = void 0;
|
|
4
|
+
exports.resetContextHealthRoundState = resetContextHealthRoundState;
|
|
5
|
+
exports.resolveCriticalCountdownRemaining = resolveCriticalCountdownRemaining;
|
|
6
|
+
exports.consumeCriticalCountdown = consumeCriticalCountdown;
|
|
7
|
+
exports.resolveCautionRemediationCadenceGenerations = resolveCautionRemediationCadenceGenerations;
|
|
8
|
+
exports.decideDriverV2ContextHealth = decideDriverV2ContextHealth;
|
|
9
|
+
exports.DRIVER_V2_DEFAULT_CRITICAL_COUNTDOWN_GENERATIONS = 5;
|
|
10
|
+
exports.DRIVER_V2_DEFAULT_CAUTION_REMEDIATION_CADENCE_GENERATIONS = 10;
|
|
11
|
+
const contextHealthRoundStateByDialogKey = new Map();
|
|
12
|
+
function getContextHealthRoundState(dialogKey) {
|
|
13
|
+
const existing = contextHealthRoundStateByDialogKey.get(dialogKey);
|
|
14
|
+
if (existing) {
|
|
15
|
+
return existing;
|
|
16
|
+
}
|
|
17
|
+
const created = {};
|
|
18
|
+
contextHealthRoundStateByDialogKey.set(dialogKey, created);
|
|
19
|
+
return created;
|
|
20
|
+
}
|
|
21
|
+
function resetContextHealthRoundState(dialogKey) {
|
|
22
|
+
contextHealthRoundStateByDialogKey.delete(dialogKey);
|
|
23
|
+
}
|
|
24
|
+
function resolveCriticalCountdownRemaining(dialogKey, snapshot) {
|
|
25
|
+
if (!snapshot || snapshot.kind !== 'available') {
|
|
26
|
+
resetContextHealthRoundState(dialogKey);
|
|
27
|
+
return exports.DRIVER_V2_DEFAULT_CRITICAL_COUNTDOWN_GENERATIONS;
|
|
28
|
+
}
|
|
29
|
+
if (snapshot.level !== 'critical') {
|
|
30
|
+
if (snapshot.level === 'healthy') {
|
|
31
|
+
resetContextHealthRoundState(dialogKey);
|
|
32
|
+
return exports.DRIVER_V2_DEFAULT_CRITICAL_COUNTDOWN_GENERATIONS;
|
|
33
|
+
}
|
|
34
|
+
const state = getContextHealthRoundState(dialogKey);
|
|
35
|
+
state.criticalCountdownRemaining = undefined;
|
|
36
|
+
return exports.DRIVER_V2_DEFAULT_CRITICAL_COUNTDOWN_GENERATIONS;
|
|
37
|
+
}
|
|
38
|
+
const state = getContextHealthRoundState(dialogKey);
|
|
39
|
+
if (state.lastSeenLevel !== 'critical' ||
|
|
40
|
+
typeof state.criticalCountdownRemaining !== 'number' ||
|
|
41
|
+
!Number.isFinite(state.criticalCountdownRemaining)) {
|
|
42
|
+
state.lastSeenLevel = 'critical';
|
|
43
|
+
state.criticalCountdownRemaining = exports.DRIVER_V2_DEFAULT_CRITICAL_COUNTDOWN_GENERATIONS;
|
|
44
|
+
}
|
|
45
|
+
const remaining = Math.floor(state.criticalCountdownRemaining);
|
|
46
|
+
return remaining > 0 ? remaining : 0;
|
|
47
|
+
}
|
|
48
|
+
function consumeCriticalCountdown(dialogKey) {
|
|
49
|
+
const state = getContextHealthRoundState(dialogKey);
|
|
50
|
+
const currentRaw = typeof state.criticalCountdownRemaining === 'number' &&
|
|
51
|
+
Number.isFinite(state.criticalCountdownRemaining)
|
|
52
|
+
? Math.floor(state.criticalCountdownRemaining)
|
|
53
|
+
: exports.DRIVER_V2_DEFAULT_CRITICAL_COUNTDOWN_GENERATIONS;
|
|
54
|
+
const current = currentRaw > 0 ? currentRaw : 0;
|
|
55
|
+
const next = Math.max(0, current - 1);
|
|
56
|
+
state.lastSeenLevel = 'critical';
|
|
57
|
+
state.criticalCountdownRemaining = next;
|
|
58
|
+
return next;
|
|
59
|
+
}
|
|
60
|
+
function resolveCautionRemediationCadenceGenerations(configured) {
|
|
61
|
+
if (typeof configured !== 'number' || !Number.isFinite(configured)) {
|
|
62
|
+
return exports.DRIVER_V2_DEFAULT_CAUTION_REMEDIATION_CADENCE_GENERATIONS;
|
|
63
|
+
}
|
|
64
|
+
const normalized = Math.floor(configured);
|
|
65
|
+
if (normalized <= 0) {
|
|
66
|
+
return exports.DRIVER_V2_DEFAULT_CAUTION_REMEDIATION_CADENCE_GENERATIONS;
|
|
67
|
+
}
|
|
68
|
+
return normalized;
|
|
69
|
+
}
|
|
70
|
+
function decideDriverV2ContextHealth(args) {
|
|
71
|
+
const { snapshot, dialogKey } = args;
|
|
72
|
+
if (!snapshot || snapshot.kind !== 'available') {
|
|
73
|
+
return { kind: 'proceed' };
|
|
74
|
+
}
|
|
75
|
+
if (snapshot.level === 'healthy') {
|
|
76
|
+
return { kind: 'proceed' };
|
|
77
|
+
}
|
|
78
|
+
if (snapshot.level === 'caution') {
|
|
79
|
+
const state = getContextHealthRoundState(dialogKey);
|
|
80
|
+
const cadence = resolveCautionRemediationCadenceGenerations(args.cautionRemediationCadenceGenerations);
|
|
81
|
+
const enteringCaution = state.lastSeenLevel !== 'caution';
|
|
82
|
+
state.lastSeenLevel = 'caution';
|
|
83
|
+
state.criticalCountdownRemaining = undefined;
|
|
84
|
+
if (enteringCaution) {
|
|
85
|
+
state.cautionPromptDue = true;
|
|
86
|
+
state.cautionGenerationsSincePrompt = 0;
|
|
87
|
+
}
|
|
88
|
+
else if (state.cautionPromptDue !== true) {
|
|
89
|
+
const previous = typeof state.cautionGenerationsSincePrompt === 'number' &&
|
|
90
|
+
Number.isFinite(state.cautionGenerationsSincePrompt)
|
|
91
|
+
? Math.max(0, Math.floor(state.cautionGenerationsSincePrompt))
|
|
92
|
+
: 0;
|
|
93
|
+
const next = previous + 1;
|
|
94
|
+
state.cautionGenerationsSincePrompt = next;
|
|
95
|
+
if (next >= cadence) {
|
|
96
|
+
state.cautionPromptDue = true;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
const shouldInjectPrompt = state.cautionPromptDue === true && !args.hadUserPromptThisGen && args.canInjectPromptThisGen;
|
|
100
|
+
if (!shouldInjectPrompt) {
|
|
101
|
+
return { kind: 'proceed' };
|
|
102
|
+
}
|
|
103
|
+
state.cautionPromptDue = false;
|
|
104
|
+
state.cautionGenerationsSincePrompt = 0;
|
|
105
|
+
return { kind: 'continue', reason: 'caution_soft_remediation' };
|
|
106
|
+
}
|
|
107
|
+
if (snapshot.level === 'critical') {
|
|
108
|
+
const state = getContextHealthRoundState(dialogKey);
|
|
109
|
+
state.lastSeenLevel = 'critical';
|
|
110
|
+
state.cautionPromptDue = undefined;
|
|
111
|
+
state.cautionGenerationsSincePrompt = undefined;
|
|
112
|
+
if (args.criticalCountdownRemaining <= 0) {
|
|
113
|
+
return { kind: 'continue', reason: 'critical_force_new_course' };
|
|
114
|
+
}
|
|
115
|
+
return args.hadUserPromptThisGen
|
|
116
|
+
? { kind: 'suspend', reason: 'critical_wait_human' }
|
|
117
|
+
: { kind: 'continue', reason: 'critical_countdown_remediation' };
|
|
118
|
+
}
|
|
119
|
+
const _exhaustive = snapshot.level;
|
|
120
|
+
return _exhaustive;
|
|
121
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildDriveBaseContextMessages = buildDriveBaseContextMessages;
|
|
4
|
+
exports.appendDriveEphemeralContext = appendDriveEphemeralContext;
|
|
5
|
+
exports.appendDriveTailContext = appendDriveTailContext;
|
|
6
|
+
exports.assembleDriveContextMessages = assembleDriveContextMessages;
|
|
7
|
+
function findLastUserPromptLikeIndex(msgs) {
|
|
8
|
+
for (let i = msgs.length - 1; i >= 0; i--) {
|
|
9
|
+
const msg = msgs[i];
|
|
10
|
+
if (msg &&
|
|
11
|
+
(msg.type === 'prompting_msg' || msg.type === 'environment_msg') &&
|
|
12
|
+
msg.role === 'user') {
|
|
13
|
+
return i;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return -1;
|
|
17
|
+
}
|
|
18
|
+
function insertBeforeLastUserPromptLike(msgs, toInsert) {
|
|
19
|
+
if (toInsert.length === 0)
|
|
20
|
+
return [...msgs];
|
|
21
|
+
const next = [...msgs];
|
|
22
|
+
const insertIndex = findLastUserPromptLikeIndex(next);
|
|
23
|
+
if (insertIndex >= 0) {
|
|
24
|
+
next.splice(insertIndex, 0, ...toInsert);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
next.push(...toInsert);
|
|
28
|
+
}
|
|
29
|
+
return next;
|
|
30
|
+
}
|
|
31
|
+
function buildDriveBaseContextMessages(parts) {
|
|
32
|
+
return [
|
|
33
|
+
...parts.prependedContextMessages,
|
|
34
|
+
...parts.memories,
|
|
35
|
+
...(parts.taskDocMsg ? [parts.taskDocMsg] : []),
|
|
36
|
+
...parts.coursePrefixMsgs,
|
|
37
|
+
...parts.dialogMsgsForContext,
|
|
38
|
+
];
|
|
39
|
+
}
|
|
40
|
+
function appendDriveEphemeralContext(base, parts) {
|
|
41
|
+
const next = [...base];
|
|
42
|
+
if (Array.isArray(parts.subdialogResponseContextMsgs) &&
|
|
43
|
+
parts.subdialogResponseContextMsgs.length > 0) {
|
|
44
|
+
next.push(...parts.subdialogResponseContextMsgs);
|
|
45
|
+
}
|
|
46
|
+
return next;
|
|
47
|
+
}
|
|
48
|
+
function appendDriveTailContext(source, parts) {
|
|
49
|
+
const withReminders = insertBeforeLastUserPromptLike(source, parts.renderedReminders);
|
|
50
|
+
return insertBeforeLastUserPromptLike(withReminders, [parts.languageGuideMsg]);
|
|
51
|
+
}
|
|
52
|
+
function assembleDriveContextMessages(args) {
|
|
53
|
+
const baseMsgs = buildDriveBaseContextMessages(args.base);
|
|
54
|
+
const withEphemeral = appendDriveEphemeralContext(baseMsgs, args.ephemeral);
|
|
55
|
+
return appendDriveTailContext(withEphemeral, args.tail);
|
|
56
|
+
}
|