pybao-cli 1.4.51 → 1.4.53

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 (152) hide show
  1. package/dist/REPL-ETXBX4GD.js +46 -0
  2. package/dist/{acp-2C774HUW.js → acp-BBK67FZZ.js} +31 -32
  3. package/dist/{acp-2C774HUW.js.map → acp-BBK67FZZ.js.map} +1 -1
  4. package/dist/{agentsValidate-RCXZBOU3.js → agentsValidate-BCIRX632.js} +7 -7
  5. package/dist/{ask-EIO3Q6ED.js → ask-VG4YM3A7.js} +30 -31
  6. package/dist/{ask-EIO3Q6ED.js.map → ask-VG4YM3A7.js.map} +1 -1
  7. package/dist/{autoUpdater-IIJMDPJE.js → autoUpdater-ZTZNG6MQ.js} +3 -3
  8. package/dist/{chunk-GLS3ZXCS.js → chunk-33IRPD3C.js} +3 -3
  9. package/dist/{chunk-YNVGW5VZ.js → chunk-5N2LR5UC.js} +7 -7
  10. package/dist/{chunk-PKAVBIO7.js → chunk-6JK5BGNC.js} +1 -1
  11. package/dist/{chunk-G2FI43IB.js → chunk-A4J6UBNK.js} +2 -2
  12. package/dist/{chunk-OBFMPMGW.js → chunk-AFVEZLTD.js} +2 -2
  13. package/dist/{chunk-TMFNSMVV.js → chunk-B4JRDZFF.js} +6 -6
  14. package/dist/{chunk-N6DXTYLR.js → chunk-CJ44MBCI.js} +3 -3
  15. package/dist/{chunk-YTUV273Y.js → chunk-CO4JIH76.js} +1456 -1371
  16. package/dist/chunk-CO4JIH76.js.map +7 -0
  17. package/dist/{chunk-DCSAQNHW.js → chunk-ERGKRFDJ.js} +4 -4
  18. package/dist/{chunk-GTP62T63.js → chunk-HKKI5CUW.js} +3 -3
  19. package/dist/{chunk-KNOCJVE6.js → chunk-IEWJUZZ4.js} +1 -1
  20. package/dist/{chunk-6MFZG46W.js → chunk-IZQSETD3.js} +1 -1
  21. package/dist/chunk-J5FWFAJE.js +421 -0
  22. package/dist/chunk-J5FWFAJE.js.map +7 -0
  23. package/dist/{chunk-OYCMMRZV.js → chunk-JK4U5YCO.js} +1 -1
  24. package/dist/{chunk-LEQNJ73H.js → chunk-JMNAD5PO.js} +3 -3
  25. package/dist/{chunk-ESKTQXW6.js → chunk-JXFMOIM3.js} +1 -1
  26. package/dist/{chunk-ESKTQXW6.js.map → chunk-JXFMOIM3.js.map} +1 -1
  27. package/dist/{chunk-VUILI5ED.js → chunk-KQBOSZTO.js} +22 -6
  28. package/dist/{chunk-VUILI5ED.js.map → chunk-KQBOSZTO.js.map} +3 -3
  29. package/dist/{chunk-HY24VLOS.js → chunk-KURHDENJ.js} +1 -1
  30. package/dist/{chunk-WCKPMAYX.js → chunk-MDTAHWRA.js} +1 -1
  31. package/dist/{chunk-KDKXQODT.js → chunk-MKAUTQIV.js} +2 -2
  32. package/dist/{chunk-SQJJRPIY.js → chunk-N7BSSU3C.js} +5 -5
  33. package/dist/{chunk-U7MPXQO4.js → chunk-N7HOL2FL.js} +3 -3
  34. package/dist/{chunk-HJDETBB6.js → chunk-OF6NW3CH.js} +1 -1
  35. package/dist/{chunk-SNKLRBWT.js → chunk-OTLOWUV5.js} +2 -2
  36. package/dist/{chunk-MZ6UJROW.js → chunk-R7JCTOLR.js} +4 -4
  37. package/dist/{chunk-ZQAKMVXR.js → chunk-R7WBU6WF.js} +3 -3
  38. package/dist/{chunk-LAQQRRQR.js → chunk-SLX2OHBV.js} +4 -4
  39. package/dist/{chunk-WSN5UCPE.js → chunk-T7TN326S.js} +1 -1
  40. package/dist/{chunk-LAFEZLTD.js → chunk-XO4WYS66.js} +158 -128
  41. package/dist/chunk-XO4WYS66.js.map +7 -0
  42. package/dist/{chunk-5RX62PWR.js → chunk-YSI7SECE.js} +1 -1
  43. package/dist/{cli-JPS6PPHH.js → cli-ETJKNFLN.js} +95 -97
  44. package/dist/cli-ETJKNFLN.js.map +7 -0
  45. package/dist/commands-Y3MZUUJF.js +50 -0
  46. package/dist/{config-7RFJBYCF.js → config-E2UT2BHP.js} +4 -4
  47. package/dist/{context-L6IDU4ZF.js → context-NF6UL2WQ.js} +6 -6
  48. package/dist/{customCommands-2ZLDKEPS.js → customCommands-K5TOBWOG.js} +4 -4
  49. package/dist/{env-KKHHZ47D.js → env-YPNG4GCZ.js} +2 -2
  50. package/dist/{file-QGJRLWJ7.js → file-5HB5JDXE.js} +4 -4
  51. package/dist/index.js +3 -3
  52. package/dist/{llm-HHSKS5JE.js → llm-HPFALZTO.js} +31 -32
  53. package/dist/{llm-HHSKS5JE.js.map → llm-HPFALZTO.js.map} +1 -1
  54. package/dist/{llmLazy-YV33JO4W.js → llmLazy-XVV3PCWC.js} +1 -1
  55. package/dist/{loader-YCEP5CYE.js → loader-F4IFI6TI.js} +4 -4
  56. package/dist/{lsp-TG3EZZOU.js → lsp-OXYIZORL.js} +6 -6
  57. package/dist/{lspAnchor-T3544E7J.js → lspAnchor-PE3Z6SSS.js} +6 -6
  58. package/dist/{mcp-SWYFI5FF.js → mcp-OUNIDN7C.js} +7 -7
  59. package/dist/{mentionProcessor-IP6FAEXL.js → mentionProcessor-SR75ZPZL.js} +5 -9
  60. package/dist/{mentionProcessor-IP6FAEXL.js.map → mentionProcessor-SR75ZPZL.js.map} +1 -1
  61. package/dist/{messages-3B2ZJJKW.js → messages-RIUPLGZZ.js} +1 -1
  62. package/dist/{model-HDJXCBKD.js → model-6CB447EG.js} +5 -5
  63. package/dist/{openai-DF2BQT7X.js → openai-NMN24LHZ.js} +5 -6
  64. package/dist/{outputStyles-GWUBSKDY.js → outputStyles-S4QVJQ2M.js} +4 -4
  65. package/dist/{pluginRuntime-LKAAMJH2.js → pluginRuntime-VVPWXAOG.js} +6 -6
  66. package/dist/{pluginValidation-7GJA32YV.js → pluginValidation-4X76H7AS.js} +6 -6
  67. package/dist/prompts-6WUAD4N6.js +52 -0
  68. package/dist/{pybAgentSessionLoad-BGIX7L4O.js → pybAgentSessionLoad-FQQDJPAZ.js} +4 -4
  69. package/dist/{pybAgentSessionResume-VKK6VZSA.js → pybAgentSessionResume-FW2PPCMQ.js} +4 -4
  70. package/dist/{pybAgentStreamJsonSession-HDXJ4F5W.js → pybAgentStreamJsonSession-ANEZ2MDI.js} +1 -1
  71. package/dist/{pybHooks-LEIAZ7D6.js → pybHooks-VX6L72CF.js} +5 -5
  72. package/dist/query-KOXXXDL6.js +54 -0
  73. package/dist/{registry-C4V5AZ6N.js → registry-CS624VEB.js} +5 -5
  74. package/dist/{ripgrep-PWIRRS2Q.js → ripgrep-E3KEWB5J.js} +3 -3
  75. package/dist/{skillMarketplace-GZN6RWUY.js → skillMarketplace-ZDK43624.js} +3 -3
  76. package/dist/{state-T7WQKFBG.js → state-NPZMMSLQ.js} +2 -2
  77. package/dist/{theme-CLYLDSCI.js → theme-EDG2CUW3.js} +5 -5
  78. package/dist/{toolPermissionSettings-UYHSUTC5.js → toolPermissionSettings-YAZJAQU7.js} +6 -6
  79. package/dist/tools-B2QJ3TNV.js +51 -0
  80. package/dist/{userInput-KZXH5O7V.js → userInput-PJ4OVVPF.js} +32 -33
  81. package/dist/{userInput-KZXH5O7V.js.map → userInput-PJ4OVVPF.js.map} +1 -1
  82. package/package.json +1 -1
  83. package/dist/REPL-6YEOSMEP.js +0 -47
  84. package/dist/chunk-ERMQRV55.js +0 -24
  85. package/dist/chunk-ERMQRV55.js.map +0 -7
  86. package/dist/chunk-L2FQX7IL.js +0 -1552
  87. package/dist/chunk-L2FQX7IL.js.map +0 -7
  88. package/dist/chunk-LAFEZLTD.js.map +0 -7
  89. package/dist/chunk-YTUV273Y.js.map +0 -7
  90. package/dist/cli-JPS6PPHH.js.map +0 -7
  91. package/dist/commands-3IJYY2KF.js +0 -51
  92. package/dist/prompts-DB772NLS.js +0 -53
  93. package/dist/query-LVPGQYDL.js +0 -55
  94. package/dist/tools-SEWCFM5P.js +0 -52
  95. /package/dist/{REPL-6YEOSMEP.js.map → REPL-ETXBX4GD.js.map} +0 -0
  96. /package/dist/{agentsValidate-RCXZBOU3.js.map → agentsValidate-BCIRX632.js.map} +0 -0
  97. /package/dist/{autoUpdater-IIJMDPJE.js.map → autoUpdater-ZTZNG6MQ.js.map} +0 -0
  98. /package/dist/{chunk-GLS3ZXCS.js.map → chunk-33IRPD3C.js.map} +0 -0
  99. /package/dist/{chunk-YNVGW5VZ.js.map → chunk-5N2LR5UC.js.map} +0 -0
  100. /package/dist/{chunk-PKAVBIO7.js.map → chunk-6JK5BGNC.js.map} +0 -0
  101. /package/dist/{chunk-G2FI43IB.js.map → chunk-A4J6UBNK.js.map} +0 -0
  102. /package/dist/{chunk-OBFMPMGW.js.map → chunk-AFVEZLTD.js.map} +0 -0
  103. /package/dist/{chunk-TMFNSMVV.js.map → chunk-B4JRDZFF.js.map} +0 -0
  104. /package/dist/{chunk-N6DXTYLR.js.map → chunk-CJ44MBCI.js.map} +0 -0
  105. /package/dist/{chunk-DCSAQNHW.js.map → chunk-ERGKRFDJ.js.map} +0 -0
  106. /package/dist/{chunk-GTP62T63.js.map → chunk-HKKI5CUW.js.map} +0 -0
  107. /package/dist/{chunk-KNOCJVE6.js.map → chunk-IEWJUZZ4.js.map} +0 -0
  108. /package/dist/{chunk-6MFZG46W.js.map → chunk-IZQSETD3.js.map} +0 -0
  109. /package/dist/{chunk-OYCMMRZV.js.map → chunk-JK4U5YCO.js.map} +0 -0
  110. /package/dist/{chunk-LEQNJ73H.js.map → chunk-JMNAD5PO.js.map} +0 -0
  111. /package/dist/{chunk-HY24VLOS.js.map → chunk-KURHDENJ.js.map} +0 -0
  112. /package/dist/{chunk-WCKPMAYX.js.map → chunk-MDTAHWRA.js.map} +0 -0
  113. /package/dist/{chunk-KDKXQODT.js.map → chunk-MKAUTQIV.js.map} +0 -0
  114. /package/dist/{chunk-SQJJRPIY.js.map → chunk-N7BSSU3C.js.map} +0 -0
  115. /package/dist/{chunk-U7MPXQO4.js.map → chunk-N7HOL2FL.js.map} +0 -0
  116. /package/dist/{chunk-HJDETBB6.js.map → chunk-OF6NW3CH.js.map} +0 -0
  117. /package/dist/{chunk-SNKLRBWT.js.map → chunk-OTLOWUV5.js.map} +0 -0
  118. /package/dist/{chunk-MZ6UJROW.js.map → chunk-R7JCTOLR.js.map} +0 -0
  119. /package/dist/{chunk-ZQAKMVXR.js.map → chunk-R7WBU6WF.js.map} +0 -0
  120. /package/dist/{chunk-LAQQRRQR.js.map → chunk-SLX2OHBV.js.map} +0 -0
  121. /package/dist/{chunk-WSN5UCPE.js.map → chunk-T7TN326S.js.map} +0 -0
  122. /package/dist/{chunk-5RX62PWR.js.map → chunk-YSI7SECE.js.map} +0 -0
  123. /package/dist/{commands-3IJYY2KF.js.map → commands-Y3MZUUJF.js.map} +0 -0
  124. /package/dist/{config-7RFJBYCF.js.map → config-E2UT2BHP.js.map} +0 -0
  125. /package/dist/{context-L6IDU4ZF.js.map → context-NF6UL2WQ.js.map} +0 -0
  126. /package/dist/{customCommands-2ZLDKEPS.js.map → customCommands-K5TOBWOG.js.map} +0 -0
  127. /package/dist/{env-KKHHZ47D.js.map → env-YPNG4GCZ.js.map} +0 -0
  128. /package/dist/{file-QGJRLWJ7.js.map → file-5HB5JDXE.js.map} +0 -0
  129. /package/dist/{llmLazy-YV33JO4W.js.map → llmLazy-XVV3PCWC.js.map} +0 -0
  130. /package/dist/{loader-YCEP5CYE.js.map → loader-F4IFI6TI.js.map} +0 -0
  131. /package/dist/{lsp-TG3EZZOU.js.map → lsp-OXYIZORL.js.map} +0 -0
  132. /package/dist/{lspAnchor-T3544E7J.js.map → lspAnchor-PE3Z6SSS.js.map} +0 -0
  133. /package/dist/{mcp-SWYFI5FF.js.map → mcp-OUNIDN7C.js.map} +0 -0
  134. /package/dist/{messages-3B2ZJJKW.js.map → messages-RIUPLGZZ.js.map} +0 -0
  135. /package/dist/{model-HDJXCBKD.js.map → model-6CB447EG.js.map} +0 -0
  136. /package/dist/{openai-DF2BQT7X.js.map → openai-NMN24LHZ.js.map} +0 -0
  137. /package/dist/{outputStyles-GWUBSKDY.js.map → outputStyles-S4QVJQ2M.js.map} +0 -0
  138. /package/dist/{pluginRuntime-LKAAMJH2.js.map → pluginRuntime-VVPWXAOG.js.map} +0 -0
  139. /package/dist/{pluginValidation-7GJA32YV.js.map → pluginValidation-4X76H7AS.js.map} +0 -0
  140. /package/dist/{prompts-DB772NLS.js.map → prompts-6WUAD4N6.js.map} +0 -0
  141. /package/dist/{pybAgentSessionLoad-BGIX7L4O.js.map → pybAgentSessionLoad-FQQDJPAZ.js.map} +0 -0
  142. /package/dist/{pybAgentSessionResume-VKK6VZSA.js.map → pybAgentSessionResume-FW2PPCMQ.js.map} +0 -0
  143. /package/dist/{pybAgentStreamJsonSession-HDXJ4F5W.js.map → pybAgentStreamJsonSession-ANEZ2MDI.js.map} +0 -0
  144. /package/dist/{pybHooks-LEIAZ7D6.js.map → pybHooks-VX6L72CF.js.map} +0 -0
  145. /package/dist/{query-LVPGQYDL.js.map → query-KOXXXDL6.js.map} +0 -0
  146. /package/dist/{registry-C4V5AZ6N.js.map → registry-CS624VEB.js.map} +0 -0
  147. /package/dist/{ripgrep-PWIRRS2Q.js.map → ripgrep-E3KEWB5J.js.map} +0 -0
  148. /package/dist/{skillMarketplace-GZN6RWUY.js.map → skillMarketplace-ZDK43624.js.map} +0 -0
  149. /package/dist/{state-T7WQKFBG.js.map → state-NPZMMSLQ.js.map} +0 -0
  150. /package/dist/{theme-CLYLDSCI.js.map → theme-EDG2CUW3.js.map} +0 -0
  151. /package/dist/{toolPermissionSettings-UYHSUTC5.js.map → toolPermissionSettings-YAZJAQU7.js.map} +0 -0
  152. /package/dist/{tools-SEWCFM5P.js.map → tools-B2QJ3TNV.js.map} +0 -0
@@ -4,17 +4,17 @@ import {
4
4
  LspServerRegistry,
5
5
  findNearestRoot,
6
6
  getInstallNotices
7
- } from "./chunk-U7MPXQO4.js";
7
+ } from "./chunk-N7HOL2FL.js";
8
8
  import {
9
9
  levenshtein
10
10
  } from "./chunk-UZ34JEUK.js";
11
11
  import {
12
12
  debug
13
- } from "./chunk-6MFZG46W.js";
13
+ } from "./chunk-IZQSETD3.js";
14
14
  import {
15
15
  getCwd,
16
16
  getSessionRoot
17
- } from "./chunk-HJDETBB6.js";
17
+ } from "./chunk-OF6NW3CH.js";
18
18
 
19
19
  // src/lsp/index.ts
20
20
  import { extname as extname2 } from "path";
@@ -565,7 +565,7 @@ var LspClientManager = class _LspClientManager {
565
565
  const safeCwd = /[^\x00-\x7F]/.test(resolvedRoot) ? process.cwd() : resolvedRoot;
566
566
  let initOpts = serverInfo.initializationOptions;
567
567
  if (serverInfo.id === "pyright" || serverInfo.id === "ty") {
568
- const { detectPythonVenv } = await import("./registry-C4V5AZ6N.js");
568
+ const { detectPythonVenv } = await import("./registry-CS624VEB.js");
569
569
  const pythonPath = detectPythonVenv(resolvedRoot);
570
570
  if (pythonPath) {
571
571
  initOpts = { ...initOpts ?? {}, pythonPath };
@@ -4,10 +4,10 @@ import {
4
4
  PRODUCT_NAME,
5
5
  execFileNoThrow,
6
6
  logError
7
- } from "./chunk-HJDETBB6.js";
7
+ } from "./chunk-OF6NW3CH.js";
8
8
  import {
9
9
  MACRO
10
- } from "./chunk-ESKTQXW6.js";
10
+ } from "./chunk-JXFMOIM3.js";
11
11
 
12
12
  // src/utils/session/autoUpdater.ts
13
13
  async function getSemver() {
@@ -82,7 +82,7 @@ async function checkAndNotifyUpdate() {
82
82
  const [
83
83
  { isAutoUpdaterDisabled, getGlobalConfig, saveGlobalConfig },
84
84
  { env }
85
- ] = await Promise.all([import("./config-7RFJBYCF.js"), import("./env-KKHHZ47D.js")]);
85
+ ] = await Promise.all([import("./config-E2UT2BHP.js"), import("./env-YPNG4GCZ.js")]);
86
86
  if (await isAutoUpdaterDisabled()) return;
87
87
  if (await env.getIsDocker()) return;
88
88
  if (!await env.hasInternetAccess()) return;
@@ -2,7 +2,7 @@ import { createRequire as __pybCreateRequire } from "node:module";
2
2
  const require = __pybCreateRequire(import.meta.url);
3
3
  import {
4
4
  getSessionProjectDir
5
- } from "./chunk-SNKLRBWT.js";
5
+ } from "./chunk-OTLOWUV5.js";
6
6
  import {
7
7
  isUuid
8
8
  } from "./chunk-5P7HBXTD.js";
@@ -3,7 +3,7 @@ const require = __pybCreateRequire(import.meta.url);
3
3
  import {
4
4
  SESSION_ID,
5
5
  resolveXdgCachePath
6
- } from "./chunk-HJDETBB6.js";
6
+ } from "./chunk-OF6NW3CH.js";
7
7
 
8
8
  // src/utils/log/debugLogger.ts
9
9
  import { existsSync, mkdirSync, appendFileSync } from "fs";
@@ -0,0 +1,421 @@
1
+ import { createRequire as __pybCreateRequire } from "node:module";
2
+ const require = __pybCreateRequire(import.meta.url);
3
+ import {
4
+ debug
5
+ } from "./chunk-IZQSETD3.js";
6
+ import {
7
+ logError
8
+ } from "./chunk-OF6NW3CH.js";
9
+
10
+ // src/services/system/systemReminder.ts
11
+ var SystemReminderService = class {
12
+ sessionState = {
13
+ lastFileAccess: 0,
14
+ lastTaskUpdate: 0,
15
+ sessionStartTime: Date.now(),
16
+ remindersSent: /* @__PURE__ */ new Set(),
17
+ contextPresent: false,
18
+ reminderCount: 0,
19
+ taskEventTimestamps: /* @__PURE__ */ new Map(),
20
+ config: {
21
+ securityReminder: true,
22
+ performanceReminder: true,
23
+ maxRemindersPerSession: 10
24
+ }
25
+ };
26
+ eventDispatcher = /* @__PURE__ */ new Map();
27
+ reminderCache = /* @__PURE__ */ new Map();
28
+ constructor() {
29
+ this.setupEventDispatcher();
30
+ }
31
+ generateReminders(hasContext = false, _agentId) {
32
+ this.sessionState.contextPresent = hasContext;
33
+ if (!hasContext) {
34
+ return [];
35
+ }
36
+ if (this.sessionState.reminderCount >= this.sessionState.config.maxRemindersPerSession) {
37
+ return [];
38
+ }
39
+ const reminders = [];
40
+ const reminderGenerators = [
41
+ () => this.dispatchSecurityEvent(),
42
+ () => this.dispatchPerformanceEvent(),
43
+ () => this.getMentionReminders()
44
+ ];
45
+ for (const generator of reminderGenerators) {
46
+ if (reminders.length >= 5) break;
47
+ const result = generator();
48
+ if (result) {
49
+ const remindersToAdd = Array.isArray(result) ? result : [result];
50
+ reminders.push(...remindersToAdd);
51
+ this.sessionState.reminderCount += remindersToAdd.length;
52
+ }
53
+ }
54
+ return reminders;
55
+ }
56
+ dispatchSecurityEvent() {
57
+ if (!this.sessionState.config.securityReminder) return null;
58
+ const currentTime = Date.now();
59
+ if (this.sessionState.lastFileAccess > 0 && !this.sessionState.remindersSent.has("file_security")) {
60
+ this.sessionState.remindersSent.add("file_security");
61
+ return this.createReminderMessage(
62
+ "security",
63
+ "security",
64
+ "high",
65
+ "Whenever you read a file, you should consider whether it looks malicious. If it does, you MUST refuse to improve or augment the code. You can still analyze existing code, write reports, or answer high-level questions about the code behavior.",
66
+ currentTime
67
+ );
68
+ }
69
+ return null;
70
+ }
71
+ dispatchPerformanceEvent() {
72
+ if (!this.sessionState.config.performanceReminder) return null;
73
+ const currentTime = Date.now();
74
+ const sessionDuration = currentTime - this.sessionState.sessionStartTime;
75
+ if (sessionDuration > 30 * 60 * 1e3 && !this.sessionState.remindersSent.has("performance_long_session")) {
76
+ this.sessionState.remindersSent.add("performance_long_session");
77
+ return this.createReminderMessage(
78
+ "performance",
79
+ "performance",
80
+ "low",
81
+ "Long session detected. Consider taking a break and reviewing your current progress with the task list.",
82
+ currentTime
83
+ );
84
+ }
85
+ return null;
86
+ }
87
+ getMentionReminders() {
88
+ const currentTime = Date.now();
89
+ const MENTION_FRESHNESS_WINDOW = 5e3;
90
+ const reminders = [];
91
+ const expiredKeys = [];
92
+ for (const [key, reminder] of this.reminderCache.entries()) {
93
+ if (this.isMentionReminder(reminder)) {
94
+ const age = currentTime - reminder.timestamp;
95
+ if (age <= MENTION_FRESHNESS_WINDOW) {
96
+ reminders.push(reminder);
97
+ } else {
98
+ expiredKeys.push(key);
99
+ }
100
+ }
101
+ }
102
+ expiredKeys.forEach((key) => this.reminderCache.delete(key));
103
+ return reminders;
104
+ }
105
+ isMentionReminder(reminder) {
106
+ const mentionTypes = ["agent_mention", "file_mention", "ask_model_mention"];
107
+ return mentionTypes.includes(reminder.type);
108
+ }
109
+ generateFileChangeReminder(context) {
110
+ const { agentId, filePath, reminder } = context;
111
+ if (!reminder) {
112
+ return null;
113
+ }
114
+ const currentTime = Date.now();
115
+ const reminderKey = `file_changed_${agentId}_${filePath}_${currentTime}`;
116
+ if (this.sessionState.remindersSent.has(reminderKey)) {
117
+ return null;
118
+ }
119
+ this.sessionState.remindersSent.add(reminderKey);
120
+ return this.createReminderMessage(
121
+ "file_changed",
122
+ "general",
123
+ "medium",
124
+ reminder,
125
+ currentTime
126
+ );
127
+ }
128
+ createReminderMessage(type, category, priority, content, timestamp) {
129
+ return {
130
+ role: "system",
131
+ content: `<system-reminder>
132
+ ${content}
133
+ </system-reminder>`,
134
+ isMeta: true,
135
+ timestamp,
136
+ type,
137
+ priority,
138
+ category
139
+ };
140
+ }
141
+ shouldEmitTaskReminder(key, throttleMs) {
142
+ const now = Date.now();
143
+ const last = this.sessionState.taskEventTimestamps.get(key) ?? 0;
144
+ if (now - last < throttleMs) {
145
+ return false;
146
+ }
147
+ this.sessionState.taskEventTimestamps.set(key, now);
148
+ return true;
149
+ }
150
+ createTaskListReminder(context) {
151
+ const { listId, summary } = context;
152
+ if (!summary || !listId) return null;
153
+ const reminderKey = `task_list_${listId}_${summary.total}_${summary.ready}_${summary.blocked}_${summary.inProgress}_${summary.pending}_${summary.done}_${summary.deleted}`;
154
+ if (this.sessionState.remindersSent.has(reminderKey)) return null;
155
+ this.sessionState.remindersSent.add(reminderKey);
156
+ return this.createReminderMessage(
157
+ "task_list_changed",
158
+ "task",
159
+ "medium",
160
+ `Your task list changed. Ready: ${summary.ready}, Blocked: ${summary.blocked}, In progress: ${summary.inProgress}, Pending: ${summary.pending}, Done: ${summary.done}, Deleted: ${summary.deleted}.`,
161
+ Date.now()
162
+ );
163
+ }
164
+ createTaskReadyReminder(context) {
165
+ const { listId, readyIds } = context;
166
+ if (!listId || !Array.isArray(readyIds)) return null;
167
+ const limited = readyIds.slice(0, 5).join(", ");
168
+ const reminderKey = `task_ready_${listId}_${readyIds.length}_${limited}`;
169
+ if (this.sessionState.remindersSent.has(reminderKey)) return null;
170
+ this.sessionState.remindersSent.add(reminderKey);
171
+ return this.createReminderMessage(
172
+ "task_ready_changed",
173
+ "task",
174
+ "medium",
175
+ `Task readiness changed. Ready count: ${readyIds.length}. Ready ids: ${limited || "none"}.`,
176
+ Date.now()
177
+ );
178
+ }
179
+ createTaskCreatedReminder(context) {
180
+ const { listId, taskId, task } = context;
181
+ if (!listId || !taskId) return null;
182
+ const reminderKey = `task_created_${listId}_${taskId}`;
183
+ if (this.sessionState.remindersSent.has(reminderKey)) return null;
184
+ this.sessionState.remindersSent.add(reminderKey);
185
+ const subject = task?.subject || taskId;
186
+ return this.createReminderMessage(
187
+ "task_created",
188
+ "task",
189
+ "medium",
190
+ `Task created: ${subject} (${taskId}). Review details and adjust status if needed.`,
191
+ Date.now()
192
+ );
193
+ }
194
+ createTaskUpdatedReminder(context) {
195
+ const { listId, taskId, task } = context;
196
+ if (!listId || !taskId) return null;
197
+ const reminderKey = `task_updated_${listId}_${taskId}`;
198
+ if (this.sessionState.remindersSent.has(reminderKey)) return null;
199
+ this.sessionState.remindersSent.add(reminderKey);
200
+ const subject = task?.subject || taskId;
201
+ return this.createReminderMessage(
202
+ "task_updated",
203
+ "task",
204
+ "medium",
205
+ `Task updated: ${subject} (${taskId}). Confirm dependencies and status are correct.`,
206
+ Date.now()
207
+ );
208
+ }
209
+ createTaskStatusReminder(context) {
210
+ const { listId, taskId, previousStatus, status } = context;
211
+ if (!listId || !taskId) return null;
212
+ const reminderKey = `task_status_${listId}_${taskId}_${previousStatus}_${status}`;
213
+ if (this.sessionState.remindersSent.has(reminderKey)) return null;
214
+ this.sessionState.remindersSent.add(reminderKey);
215
+ return this.createReminderMessage(
216
+ "task_status_changed",
217
+ "task",
218
+ "medium",
219
+ `Task status changed for ${taskId}: ${previousStatus} \u2192 ${status}. Review dependent tasks if needed.`,
220
+ Date.now()
221
+ );
222
+ }
223
+ createTaskDepsReminder(context) {
224
+ const { listId, taskId, deps } = context;
225
+ if (!listId || !taskId) return null;
226
+ const reminderKey = `task_deps_${listId}_${taskId}_${JSON.stringify(deps ?? {})}`;
227
+ if (this.sessionState.remindersSent.has(reminderKey)) return null;
228
+ this.sessionState.remindersSent.add(reminderKey);
229
+ return this.createReminderMessage(
230
+ "task_deps_changed",
231
+ "task",
232
+ "medium",
233
+ `Task dependencies changed for ${taskId}. Recheck readiness and blockers.`,
234
+ Date.now()
235
+ );
236
+ }
237
+ setupEventDispatcher() {
238
+ this.addEventListener("session:startup", (context) => {
239
+ this.resetSession();
240
+ this.sessionState.sessionStartTime = Date.now();
241
+ this.sessionState.contextPresent = Object.keys(context.context || {}).length > 0;
242
+ });
243
+ this.addEventListener("task:list_changed", (context) => {
244
+ const key = `task_list_${context.listId}`;
245
+ if (!this.shouldEmitTaskReminder(key, 2e3)) return;
246
+ this.sessionState.lastTaskUpdate = Date.now();
247
+ const reminder = this.createTaskListReminder(context);
248
+ if (reminder) {
249
+ this.emitEvent("reminder:inject", {
250
+ reminder: reminder.content,
251
+ listId: context.listId,
252
+ type: "task_list_changed",
253
+ timestamp: Date.now()
254
+ });
255
+ }
256
+ });
257
+ this.addEventListener("task:ready_changed", (context) => {
258
+ const key = `task_ready_${context.listId}`;
259
+ if (!this.shouldEmitTaskReminder(key, 2e3)) return;
260
+ const reminder = this.createTaskReadyReminder(context);
261
+ if (reminder) {
262
+ this.emitEvent("reminder:inject", {
263
+ reminder: reminder.content,
264
+ listId: context.listId,
265
+ type: "task_ready_changed",
266
+ timestamp: Date.now()
267
+ });
268
+ }
269
+ });
270
+ this.addEventListener("task.created", (context) => {
271
+ const key = `task_created_${context.listId}_${context.taskId}`;
272
+ if (!this.shouldEmitTaskReminder(key, 2e3)) return;
273
+ const reminder = this.createTaskCreatedReminder(context);
274
+ if (reminder) {
275
+ this.emitEvent("reminder:inject", {
276
+ reminder: reminder.content,
277
+ listId: context.listId,
278
+ type: reminder.type,
279
+ timestamp: reminder.timestamp
280
+ });
281
+ }
282
+ });
283
+ this.addEventListener("task.updated", (context) => {
284
+ const key = `task_updated_${context.listId}_${context.taskId}`;
285
+ if (!this.shouldEmitTaskReminder(key, 2e3)) return;
286
+ const reminder = this.createTaskUpdatedReminder(context);
287
+ if (reminder) {
288
+ this.emitEvent("reminder:inject", {
289
+ reminder: reminder.content,
290
+ listId: context.listId,
291
+ type: reminder.type,
292
+ timestamp: reminder.timestamp
293
+ });
294
+ }
295
+ });
296
+ this.addEventListener("task.status_changed", (context) => {
297
+ const key = `task_status_${context.listId}_${context.taskId}`;
298
+ if (!this.shouldEmitTaskReminder(key, 2e3)) return;
299
+ const reminder = this.createTaskStatusReminder(context);
300
+ if (reminder) {
301
+ this.emitEvent("reminder:inject", {
302
+ reminder: reminder.content,
303
+ listId: context.listId,
304
+ type: reminder.type,
305
+ timestamp: reminder.timestamp
306
+ });
307
+ }
308
+ });
309
+ this.addEventListener("task.deps_changed", (context) => {
310
+ const key = `task_deps_${context.listId}_${context.taskId}`;
311
+ if (!this.shouldEmitTaskReminder(key, 2e3)) return;
312
+ const reminder = this.createTaskDepsReminder(context);
313
+ if (reminder) {
314
+ this.emitEvent("reminder:inject", {
315
+ reminder: reminder.content,
316
+ listId: context.listId,
317
+ type: reminder.type,
318
+ timestamp: reminder.timestamp
319
+ });
320
+ }
321
+ });
322
+ this.addEventListener("file:read", (context) => {
323
+ this.sessionState.lastFileAccess = Date.now();
324
+ });
325
+ this.addEventListener("file:edited", (context) => {
326
+ });
327
+ this.addEventListener("agent:mentioned", (context) => {
328
+ this.createMentionReminder({
329
+ type: "agent_mention",
330
+ key: `agent_mention_${context.agentType}_${context.timestamp}`,
331
+ category: "task",
332
+ priority: "high",
333
+ content: `The user mentioned @${context.originalMention}. You MUST use the Task tool with subagent_type="${context.agentType}" to delegate this task to the specified agent. Provide a detailed, self-contained task description that fully captures the user's intent for the ${context.agentType} agent to execute.`,
334
+ timestamp: context.timestamp
335
+ });
336
+ });
337
+ this.addEventListener("file:mentioned", (context) => {
338
+ this.createMentionReminder({
339
+ type: "file_mention",
340
+ key: `file_mention_${context.filePath}_${context.timestamp}`,
341
+ category: "general",
342
+ priority: "high",
343
+ content: `The user mentioned @${context.originalMention}. You MUST read the entire content of the file at path: ${context.filePath} using the Read tool to understand the full context before proceeding with the user's request.`,
344
+ timestamp: context.timestamp
345
+ });
346
+ });
347
+ this.addEventListener("ask-model:mentioned", (context) => {
348
+ this.createMentionReminder({
349
+ type: "ask_model_mention",
350
+ key: `ask_model_mention_${context.modelName}_${context.timestamp}`,
351
+ category: "task",
352
+ priority: "high",
353
+ content: `The user mentioned @${context.modelName}. You MUST use the AskExpertModelTool to consult this specific model for expert opinions and analysis. Provide the user's question or context clearly to get the most relevant response from ${context.modelName}.`,
354
+ timestamp: context.timestamp
355
+ });
356
+ });
357
+ }
358
+ addEventListener(event, callback) {
359
+ if (!this.eventDispatcher.has(event)) {
360
+ this.eventDispatcher.set(event, []);
361
+ }
362
+ this.eventDispatcher.get(event).push(callback);
363
+ }
364
+ emitEvent(event, context) {
365
+ const listeners = this.eventDispatcher.get(event) || [];
366
+ listeners.forEach((callback) => {
367
+ try {
368
+ callback(context);
369
+ } catch (error) {
370
+ logError(error);
371
+ debug.warn("SYSTEM_REMINDER_LISTENER_ERROR", {
372
+ event,
373
+ error: error instanceof Error ? error.message : String(error)
374
+ });
375
+ }
376
+ });
377
+ }
378
+ createMentionReminder(params) {
379
+ if (!this.sessionState.remindersSent.has(params.key)) {
380
+ this.sessionState.remindersSent.add(params.key);
381
+ const reminder = this.createReminderMessage(
382
+ params.type,
383
+ params.category,
384
+ params.priority,
385
+ params.content,
386
+ params.timestamp
387
+ );
388
+ this.reminderCache.set(params.key, reminder);
389
+ }
390
+ }
391
+ resetSession() {
392
+ this.sessionState = {
393
+ lastFileAccess: 0,
394
+ lastTaskUpdate: 0,
395
+ sessionStartTime: Date.now(),
396
+ remindersSent: /* @__PURE__ */ new Set(),
397
+ contextPresent: false,
398
+ reminderCount: 0,
399
+ taskEventTimestamps: /* @__PURE__ */ new Map(),
400
+ config: { ...this.sessionState.config }
401
+ };
402
+ this.reminderCache.clear();
403
+ }
404
+ updateConfig(config) {
405
+ this.sessionState.config = { ...this.sessionState.config, ...config };
406
+ }
407
+ getSessionState() {
408
+ return { ...this.sessionState };
409
+ }
410
+ };
411
+ var systemReminderService = new SystemReminderService();
412
+ var generateSystemReminders = (hasContext = false, agentId) => systemReminderService.generateReminders(hasContext, agentId);
413
+ var emitReminderEvent = (event, context) => systemReminderService.emitEvent(event, context);
414
+ var resetReminderSession = () => systemReminderService.resetSession();
415
+
416
+ export {
417
+ systemReminderService,
418
+ generateSystemReminders,
419
+ emitReminderEvent,
420
+ resetReminderSession
421
+ };
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/services/system/systemReminder.ts"],
4
+ "sourcesContent": ["import { debug as debugLogger } from '@utils/log/debugLogger'\nimport { logError } from '@utils/log'\n\nexport interface ReminderMessage {\n role: 'system'\n content: string\n isMeta: boolean\n timestamp: number\n type: string\n priority: 'low' | 'medium' | 'high'\n category: 'task' | 'security' | 'performance' | 'general'\n}\n\ninterface ReminderConfig {\n securityReminder: boolean\n performanceReminder: boolean\n maxRemindersPerSession: number\n}\n\ninterface SessionReminderState {\n lastFileAccess: number\n lastTaskUpdate: number\n sessionStartTime: number\n remindersSent: Set<string>\n contextPresent: boolean\n reminderCount: number\n taskEventTimestamps: Map<string, number>\n config: ReminderConfig\n}\n\nclass SystemReminderService {\n private sessionState: SessionReminderState = {\n lastFileAccess: 0,\n lastTaskUpdate: 0,\n sessionStartTime: Date.now(),\n remindersSent: new Set(),\n contextPresent: false,\n reminderCount: 0,\n taskEventTimestamps: new Map(),\n config: {\n securityReminder: true,\n performanceReminder: true,\n maxRemindersPerSession: 10,\n },\n }\n\n private eventDispatcher = new Map<string, Array<(context: any) => void>>()\n private reminderCache = new Map<string, ReminderMessage>()\n\n constructor() {\n this.setupEventDispatcher()\n }\n\n public generateReminders(\n hasContext: boolean = false,\n _agentId?: string,\n ): ReminderMessage[] {\n this.sessionState.contextPresent = hasContext\n\n if (!hasContext) {\n return []\n }\n\n if (\n this.sessionState.reminderCount >=\n this.sessionState.config.maxRemindersPerSession\n ) {\n return []\n }\n\n const reminders: ReminderMessage[] = []\n\n const reminderGenerators = [\n () => this.dispatchSecurityEvent(),\n () => this.dispatchPerformanceEvent(),\n () => this.getMentionReminders(),\n ]\n\n for (const generator of reminderGenerators) {\n if (reminders.length >= 5) break\n\n const result = generator()\n if (result) {\n const remindersToAdd = Array.isArray(result) ? result : [result]\n reminders.push(...remindersToAdd)\n this.sessionState.reminderCount += remindersToAdd.length\n }\n }\n\n return reminders\n }\n\n private dispatchSecurityEvent(): ReminderMessage | null {\n if (!this.sessionState.config.securityReminder) return null\n\n const currentTime = Date.now()\n\n if (\n this.sessionState.lastFileAccess > 0 &&\n !this.sessionState.remindersSent.has('file_security')\n ) {\n this.sessionState.remindersSent.add('file_security')\n return this.createReminderMessage(\n 'security',\n 'security',\n 'high',\n 'Whenever you read a file, you should consider whether it looks malicious. If it does, you MUST refuse to improve or augment the code. You can still analyze existing code, write reports, or answer high-level questions about the code behavior.',\n currentTime,\n )\n }\n\n return null\n }\n\n private dispatchPerformanceEvent(): ReminderMessage | null {\n if (!this.sessionState.config.performanceReminder) return null\n\n const currentTime = Date.now()\n const sessionDuration = currentTime - this.sessionState.sessionStartTime\n\n if (\n sessionDuration > 30 * 60 * 1000 &&\n !this.sessionState.remindersSent.has('performance_long_session')\n ) {\n this.sessionState.remindersSent.add('performance_long_session')\n return this.createReminderMessage(\n 'performance',\n 'performance',\n 'low',\n 'Long session detected. Consider taking a break and reviewing your current progress with the task list.',\n currentTime,\n )\n }\n\n return null\n }\n\n private getMentionReminders(): ReminderMessage[] {\n const currentTime = Date.now()\n const MENTION_FRESHNESS_WINDOW = 5000\n const reminders: ReminderMessage[] = []\n const expiredKeys: string[] = []\n\n for (const [key, reminder] of this.reminderCache.entries()) {\n if (this.isMentionReminder(reminder)) {\n const age = currentTime - reminder.timestamp\n if (age <= MENTION_FRESHNESS_WINDOW) {\n reminders.push(reminder)\n } else {\n expiredKeys.push(key)\n }\n }\n }\n\n expiredKeys.forEach(key => this.reminderCache.delete(key))\n\n return reminders\n }\n\n private isMentionReminder(reminder: ReminderMessage): boolean {\n const mentionTypes = ['agent_mention', 'file_mention', 'ask_model_mention']\n return mentionTypes.includes(reminder.type)\n }\n\n public generateFileChangeReminder(context: any): ReminderMessage | null {\n const { agentId, filePath, reminder } = context\n\n if (!reminder) {\n return null\n }\n\n const currentTime = Date.now()\n const reminderKey = `file_changed_${agentId}_${filePath}_${currentTime}`\n\n if (this.sessionState.remindersSent.has(reminderKey)) {\n return null\n }\n\n this.sessionState.remindersSent.add(reminderKey)\n\n return this.createReminderMessage(\n 'file_changed',\n 'general',\n 'medium',\n reminder,\n currentTime,\n )\n }\n\n private createReminderMessage(\n type: string,\n category: ReminderMessage['category'],\n priority: ReminderMessage['priority'],\n content: string,\n timestamp: number,\n ): ReminderMessage {\n return {\n role: 'system',\n content: `<system-reminder>\\n${content}\\n</system-reminder>`,\n isMeta: true,\n timestamp,\n type,\n priority,\n category,\n }\n }\n\n private shouldEmitTaskReminder(key: string, throttleMs: number): boolean {\n const now = Date.now()\n const last = this.sessionState.taskEventTimestamps.get(key) ?? 0\n if (now - last < throttleMs) {\n return false\n }\n this.sessionState.taskEventTimestamps.set(key, now)\n return true\n }\n\n private createTaskListReminder(context: any): ReminderMessage | null {\n const { listId, summary } = context\n if (!summary || !listId) return null\n const reminderKey = `task_list_${listId}_${summary.total}_${summary.ready}_${summary.blocked}_${summary.inProgress}_${summary.pending}_${summary.done}_${summary.deleted}`\n if (this.sessionState.remindersSent.has(reminderKey)) return null\n this.sessionState.remindersSent.add(reminderKey)\n return this.createReminderMessage(\n 'task_list_changed',\n 'task',\n 'medium',\n `Your task list changed. Ready: ${summary.ready}, Blocked: ${summary.blocked}, In progress: ${summary.inProgress}, Pending: ${summary.pending}, Done: ${summary.done}, Deleted: ${summary.deleted}.`,\n Date.now(),\n )\n }\n\n private createTaskReadyReminder(context: any): ReminderMessage | null {\n const { listId, readyIds } = context\n if (!listId || !Array.isArray(readyIds)) return null\n const limited = readyIds.slice(0, 5).join(', ')\n const reminderKey = `task_ready_${listId}_${readyIds.length}_${limited}`\n if (this.sessionState.remindersSent.has(reminderKey)) return null\n this.sessionState.remindersSent.add(reminderKey)\n return this.createReminderMessage(\n 'task_ready_changed',\n 'task',\n 'medium',\n `Task readiness changed. Ready count: ${readyIds.length}. Ready ids: ${limited || 'none'}.`,\n Date.now(),\n )\n }\n\n private createTaskCreatedReminder(context: any): ReminderMessage | null {\n const { listId, taskId, task } = context\n if (!listId || !taskId) return null\n const reminderKey = `task_created_${listId}_${taskId}`\n if (this.sessionState.remindersSent.has(reminderKey)) return null\n this.sessionState.remindersSent.add(reminderKey)\n const subject = task?.subject || taskId\n return this.createReminderMessage(\n 'task_created',\n 'task',\n 'medium',\n `Task created: ${subject} (${taskId}). Review details and adjust status if needed.`,\n Date.now(),\n )\n }\n\n private createTaskUpdatedReminder(context: any): ReminderMessage | null {\n const { listId, taskId, task } = context\n if (!listId || !taskId) return null\n const reminderKey = `task_updated_${listId}_${taskId}`\n if (this.sessionState.remindersSent.has(reminderKey)) return null\n this.sessionState.remindersSent.add(reminderKey)\n const subject = task?.subject || taskId\n return this.createReminderMessage(\n 'task_updated',\n 'task',\n 'medium',\n `Task updated: ${subject} (${taskId}). Confirm dependencies and status are correct.`,\n Date.now(),\n )\n }\n\n private createTaskStatusReminder(context: any): ReminderMessage | null {\n const { listId, taskId, previousStatus, status } = context\n if (!listId || !taskId) return null\n const reminderKey = `task_status_${listId}_${taskId}_${previousStatus}_${status}`\n if (this.sessionState.remindersSent.has(reminderKey)) return null\n this.sessionState.remindersSent.add(reminderKey)\n return this.createReminderMessage(\n 'task_status_changed',\n 'task',\n 'medium',\n `Task status changed for ${taskId}: ${previousStatus} \u2192 ${status}. Review dependent tasks if needed.`,\n Date.now(),\n )\n }\n\n private createTaskDepsReminder(context: any): ReminderMessage | null {\n const { listId, taskId, deps } = context\n if (!listId || !taskId) return null\n const reminderKey = `task_deps_${listId}_${taskId}_${JSON.stringify(deps ?? {})}`\n if (this.sessionState.remindersSent.has(reminderKey)) return null\n this.sessionState.remindersSent.add(reminderKey)\n return this.createReminderMessage(\n 'task_deps_changed',\n 'task',\n 'medium',\n `Task dependencies changed for ${taskId}. Recheck readiness and blockers.`,\n Date.now(),\n )\n }\n\n private setupEventDispatcher(): void {\n this.addEventListener('session:startup', context => {\n this.resetSession()\n\n this.sessionState.sessionStartTime = Date.now()\n this.sessionState.contextPresent =\n Object.keys(context.context || {}).length > 0\n })\n\n this.addEventListener('task:list_changed', context => {\n const key = `task_list_${context.listId}`\n if (!this.shouldEmitTaskReminder(key, 2000)) return\n this.sessionState.lastTaskUpdate = Date.now()\n const reminder = this.createTaskListReminder(context)\n if (reminder) {\n this.emitEvent('reminder:inject', {\n reminder: reminder.content,\n listId: context.listId,\n type: 'task_list_changed',\n timestamp: Date.now(),\n })\n }\n })\n\n this.addEventListener('task:ready_changed', context => {\n const key = `task_ready_${context.listId}`\n if (!this.shouldEmitTaskReminder(key, 2000)) return\n const reminder = this.createTaskReadyReminder(context)\n if (reminder) {\n this.emitEvent('reminder:inject', {\n reminder: reminder.content,\n listId: context.listId,\n type: 'task_ready_changed',\n timestamp: Date.now(),\n })\n }\n })\n\n this.addEventListener('task.created', context => {\n const key = `task_created_${context.listId}_${context.taskId}`\n if (!this.shouldEmitTaskReminder(key, 2000)) return\n const reminder = this.createTaskCreatedReminder(context)\n if (reminder) {\n this.emitEvent('reminder:inject', {\n reminder: reminder.content,\n listId: context.listId,\n type: reminder.type,\n timestamp: reminder.timestamp,\n })\n }\n })\n\n this.addEventListener('task.updated', context => {\n const key = `task_updated_${context.listId}_${context.taskId}`\n if (!this.shouldEmitTaskReminder(key, 2000)) return\n const reminder = this.createTaskUpdatedReminder(context)\n if (reminder) {\n this.emitEvent('reminder:inject', {\n reminder: reminder.content,\n listId: context.listId,\n type: reminder.type,\n timestamp: reminder.timestamp,\n })\n }\n })\n\n this.addEventListener('task.status_changed', context => {\n const key = `task_status_${context.listId}_${context.taskId}`\n if (!this.shouldEmitTaskReminder(key, 2000)) return\n const reminder = this.createTaskStatusReminder(context)\n if (reminder) {\n this.emitEvent('reminder:inject', {\n reminder: reminder.content,\n listId: context.listId,\n type: reminder.type,\n timestamp: reminder.timestamp,\n })\n }\n })\n\n this.addEventListener('task.deps_changed', context => {\n const key = `task_deps_${context.listId}_${context.taskId}`\n if (!this.shouldEmitTaskReminder(key, 2000)) return\n const reminder = this.createTaskDepsReminder(context)\n if (reminder) {\n this.emitEvent('reminder:inject', {\n reminder: reminder.content,\n listId: context.listId,\n type: reminder.type,\n timestamp: reminder.timestamp,\n })\n }\n })\n\n this.addEventListener('file:read', context => {\n this.sessionState.lastFileAccess = Date.now()\n })\n\n this.addEventListener('file:edited', context => {\n })\n\n this.addEventListener('agent:mentioned', context => {\n this.createMentionReminder({\n type: 'agent_mention',\n key: `agent_mention_${context.agentType}_${context.timestamp}`,\n category: 'task',\n priority: 'high',\n content: `The user mentioned @${context.originalMention}. You MUST use the Task tool with subagent_type=\"${context.agentType}\" to delegate this task to the specified agent. Provide a detailed, self-contained task description that fully captures the user's intent for the ${context.agentType} agent to execute.`,\n timestamp: context.timestamp,\n })\n })\n\n this.addEventListener('file:mentioned', context => {\n this.createMentionReminder({\n type: 'file_mention',\n key: `file_mention_${context.filePath}_${context.timestamp}`,\n category: 'general',\n priority: 'high',\n content: `The user mentioned @${context.originalMention}. You MUST read the entire content of the file at path: ${context.filePath} using the Read tool to understand the full context before proceeding with the user's request.`,\n timestamp: context.timestamp,\n })\n })\n\n this.addEventListener('ask-model:mentioned', context => {\n this.createMentionReminder({\n type: 'ask_model_mention',\n key: `ask_model_mention_${context.modelName}_${context.timestamp}`,\n category: 'task',\n priority: 'high',\n content: `The user mentioned @${context.modelName}. You MUST use the AskExpertModelTool to consult this specific model for expert opinions and analysis. Provide the user's question or context clearly to get the most relevant response from ${context.modelName}.`,\n timestamp: context.timestamp,\n })\n })\n }\n\n public addEventListener(\n event: string,\n callback: (context: any) => void,\n ): void {\n if (!this.eventDispatcher.has(event)) {\n this.eventDispatcher.set(event, [])\n }\n this.eventDispatcher.get(event)!.push(callback)\n }\n\n public emitEvent(event: string, context: any): void {\n const listeners = this.eventDispatcher.get(event) || []\n listeners.forEach(callback => {\n try {\n callback(context)\n } catch (error) {\n logError(error)\n debugLogger.warn('SYSTEM_REMINDER_LISTENER_ERROR', {\n event,\n error: error instanceof Error ? error.message : String(error),\n })\n }\n })\n }\n\n private createMentionReminder(params: {\n type: string\n key: string\n category: ReminderMessage['category']\n priority: ReminderMessage['priority']\n content: string\n timestamp: number\n }): void {\n if (!this.sessionState.remindersSent.has(params.key)) {\n this.sessionState.remindersSent.add(params.key)\n\n const reminder = this.createReminderMessage(\n params.type,\n params.category,\n params.priority,\n params.content,\n params.timestamp,\n )\n\n this.reminderCache.set(params.key, reminder)\n }\n }\n\n public resetSession(): void {\n this.sessionState = {\n lastFileAccess: 0,\n lastTaskUpdate: 0,\n sessionStartTime: Date.now(),\n remindersSent: new Set(),\n contextPresent: false,\n reminderCount: 0,\n taskEventTimestamps: new Map(),\n config: { ...this.sessionState.config },\n }\n this.reminderCache.clear()\n }\n\n public updateConfig(config: Partial<ReminderConfig>): void {\n this.sessionState.config = { ...this.sessionState.config, ...config }\n }\n\n public getSessionState(): SessionReminderState {\n return { ...this.sessionState }\n }\n}\n\nexport const systemReminderService = new SystemReminderService()\n\nexport const generateSystemReminders = (\n hasContext: boolean = false,\n agentId?: string,\n) => systemReminderService.generateReminders(hasContext, agentId)\n\nexport const generateFileChangeReminder = (context: any) =>\n systemReminderService.generateFileChangeReminder(context)\n\nexport const emitReminderEvent = (event: string, context: any) =>\n systemReminderService.emitEvent(event, context)\n\nexport const resetReminderSession = () => systemReminderService.resetSession()\nexport const getReminderSessionState = () =>\n systemReminderService.getSessionState()\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -3,7 +3,7 @@ const require = __pybCreateRequire(import.meta.url);
3
3
  import {
4
4
  getSessionProjectDir,
5
5
  getSessionProjectsDir
6
- } from "./chunk-SNKLRBWT.js";
6
+ } from "./chunk-OTLOWUV5.js";
7
7
  import {
8
8
  isUuid
9
9
  } from "./chunk-5P7HBXTD.js";
@@ -5,13 +5,13 @@ import {
5
5
  } from "./chunk-RQVLBMP7.js";
6
6
  import {
7
7
  debug
8
- } from "./chunk-6MFZG46W.js";
8
+ } from "./chunk-IZQSETD3.js";
9
9
  import {
10
10
  getCwd,
11
11
  getGlobalConfigFilePath,
12
12
  getLegacyGlobalConfigFilePath,
13
13
  logError
14
- } from "./chunk-HJDETBB6.js";
14
+ } from "./chunk-OF6NW3CH.js";
15
15
 
16
16
  // src/core/config/schema.ts
17
17
  function isAutoUpdaterStatus(value) {
@@ -688,7 +688,7 @@ function setModelPointer(pointer, modelName) {
688
688
  }
689
689
  };
690
690
  saveGlobalConfig(updatedConfig);
691
- import("./model-HDJXCBKD.js").then(({ reloadModelManager }) => {
691
+ import("./model-6CB447EG.js").then(({ reloadModelManager }) => {
692
692
  reloadModelManager();
693
693
  });
694
694
  }
@@ -4,7 +4,7 @@ const require = __pybCreateRequire(import.meta.url);
4
4
  // package.json
5
5
  var package_default = {
6
6
  name: "pybao-cli",
7
- version: "1.4.51",
7
+ version: "1.4.53",
8
8
  bin: {
9
9
  pyb: "cli.js",
10
10
  "pyb-acp": "cli-acp.js"