opencode-haimati 1.6.1 → 1.6.3

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 CHANGED
@@ -11,7 +11,8 @@
11
11
  - 版本并发控制:基于 version 的乐观锁
12
12
  - 文件锁机制:支持网络共享挂载多用户并发写入
13
13
  - 自动工作规则提示:会话首条消息时自动注入工作流程提醒
14
- - memo-map 文件关联:记忆与项目文件/目录建立关联,读取文件时自动提示相关记忆
14
+ - memo-map 文件关联:记忆与项目文件/目录建立关联(多路径数组支持),读取文件时自动提示相关记忆
15
+ - 文件路径校验:filePath 自动检查路径是否存在,项目内用相对路径、项目外用绝对路径
15
16
  - 自动关联记忆检索(auto-read):关键词提取 → 搜索 → 注入 Top 3 相关记忆到消息上下文
16
17
  - 自动记忆写入(autoWrite,默认关闭):AI 回复完成后异步触发 AI 自主审查并写入有价值的知识
17
18
  - autoUpdate:启动时自动检查 npm registry 新版本,无需手动升级
@@ -84,10 +85,10 @@ bun add -g opencode-haimati
84
85
 
85
86
  | 工具 | 说明 |
86
87
  |------|------|
87
- | `haimati_read` | 读取记忆(单条/批量,支持分页) |
88
- | `haimati_write` | 写入新记忆,可选 filePath 建立文件关联 |
88
+ | `haimati_read` | 读取记忆(单条/批量,支持分页,显示创建时间和更新时间) |
89
+ | `haimati_write` | 写入新记忆,可选 filePath 数组建立文件关联 |
89
90
  | `haimati_search` | 搜索(标题/分类/内容,match必填) |
90
- | `haimati_edit` | 部分修改(字符串替换 + 增减文件关联) |
91
+ | `haimati_edit` | 部分修改(字符串替换 + 增减文件关联数组) |
91
92
  | `haimati_move` | 修改分类路径和/或标题 |
92
93
  | `haimati_delete` | 删除记忆(自动清理文件关联) |
93
94
  | `haimati_list` | 列出索引(按分类浏览,支持详细内容) |
@@ -99,10 +100,13 @@ bun add -g opencode-haimati
99
100
  haimati_write({ category: "xxx项目/签章", title: "签章服务WS通信机制", content: "..." })
100
101
 
101
102
  // 写入 + 文件关联
102
- haimati_write({ category: "xxx项目/签章", title: "签章服务WS通信机制", content: "...", filePath: "src/ws.ts" })
103
+ haimati_write({ category: "xxx项目/签章", title: "签章服务WS通信机制", content: "...", filePath: ["src/ws.ts"] })
104
+
105
+ // 写入 + 多文件关联(数组支持多路径)
106
+ haimati_write({ category: "xxx项目/签章", title: "签章服务WS通信机制", content: "...", filePath: ["src/ws.ts", "src/tools.ts"] })
103
107
 
104
108
  // 写入 + 目录关联(末尾 / 表示目录,匹配该目录下所有文件)
105
- haimati_write({ category: "xxx项目/签章", title: "签章服务WS通信机制", content: "...", filePath: "src/" })
109
+ haimati_write({ category: "xxx项目/签章", title: "签章服务WS通信机制", content: "...", filePath: ["src/"] })
106
110
 
107
111
  // 读取(单条)
108
112
  haimati_read({ query: "086" })
@@ -130,11 +134,11 @@ haimati_edit({
130
134
  replaceAll: true
131
135
  })
132
136
 
133
- // 编辑 + 新增文件关联
134
- haimati_edit({ query: "086", oldString: "...", newString: "...", filePath: "src/new.ts" })
137
+ // 编辑 + 新增文件关联(数组支持多路径)
138
+ haimati_edit({ query: "086", oldString: "...", newString: "...", filePath: ["src/new.ts", "src/utils.ts"] })
135
139
 
136
- // 编辑 + 移除文件关联
137
- haimati_edit({ query: "086", oldString: "...", newString: "...", removeFilePath: "src/old.ts" })
140
+ // 编辑 + 移除文件关联(数组支持多路径)
141
+ haimati_edit({ query: "086", oldString: "...", newString: "...", removeFilePath: ["src/old.ts"] })
138
142
 
139
143
  // 移动
140
144
  haimati_move({ query: "086", newCategory: "xxx项目/客户端" })
@@ -154,27 +158,31 @@ haimati_list({ category: "xxx项目", recursive: true, detail: true })
154
158
  记忆可与项目文件/目录建立关联。AI 通过 `read` 工具读取文件时,自动在输出末尾注入提示:
155
159
 
156
160
  ```
157
- src/index.ts和海马体#43、#44有关,建议读取记忆
161
+ src/index.ts和海马体#43、#44有关,你要读取记忆
158
162
  ```
159
163
 
160
- - `filePath="src/index.ts"` — 精确文件关联
161
- - `filePath="src/"` — 目录关联(末尾 `/`,匹配该目录下所有文件及子目录)
164
+ - `filePath: ["src/index.ts"]` — 精确文件关联(数组支持多路径)
165
+ - `filePath: ["src/"]` — 目录关联(末尾 `/`,匹配该目录下所有文件及子目录)
166
+ - `filePath: ["src/index.ts", "C:/external/file.txt"]` — 项目内文件用相对路径,项目外文件用绝对路径
167
+ - 路径失效校验:filePath 中不存在的路径会报错提示
162
168
  - 关联关系记录在 `.haimati/memo-map.yaml`
163
169
  - 插件启动时自动清理已不存在的文件/目录条目
164
170
 
165
171
  ### haimati_edit 使用说明
166
172
 
167
- **关键特性**:
168
- - 支持字符串模式匹配替换(类似系统 edit 工具)
169
- - 使用 `oldString` 定位要替换的文本
170
- - `replaceAll` 控制是否替换所有匹配项
171
- - oldString 内容匹配隐式提供并发检测
173
+ **三种编辑模式**:
174
+
175
+ 1. **内容替换**:提供 `oldString` + `newString`,替换记忆正文中的文本
176
+ 2. **关联变更**:提供 `filePath` / `removeFilePath` 数组,增减文件关联
177
+ 3. **同时执行**:以上参数都提供时,内容替换和关联变更都会生效
172
178
 
173
179
  **参数说明**:
174
- - `oldString` 不能为空
175
- - 如果 `oldString` 在内容中不存在,会报错提示,说明内容已被修改
180
+ - `oldString` / `newString` 均为可选,必须**同时存在**才执行内容替换
181
+ - `filePath` / `removeFilePath` 可选,存在时才执行关联增减
182
+ - 至少需要提供**内容替换**或**关联变更**之一,否则报错
176
183
  - `replaceAll=false`(默认):只替换第一个匹配项
177
184
  - `replaceAll=true`:替换所有匹配项
185
+ - 如果 `oldString` 在内容中不存在,会报错提示,说明内容已被修改
178
186
 
179
187
  ## 日志
180
188
 
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
- import{tool as $}from"@opencode-ai/plugin";import I from"path";import Mt from"os";import J from"fs";var wt=".haimati",$t="\u7D22\u5F15.md";var Pt="info";import O from"path";import Zt from"os";import T from"fs";var te=["haimati.jsonc","haimati.json"];function ee(t){let n="",e=0,r=!1;for(;e<t.length;){let i=t[e],a=t[e+1];if(r){if(i==="\\"){n+=i+a,e+=2;continue}i==='"'&&(r=!1),n+=i,e++;continue}if(i==='"'){r=!0,n+=i,e++;continue}if(i==="/"&&a==="/"){for(;e<t.length&&t[e]!==`
2
- `;)e++;continue}if(i==="/"&&a==="*"){for(e+=2;e<t.length-1&&!(t[e]==="*"&&t[e+1]==="/");)e++;e+=2;continue}n+=i,e++}return n}function rt(t){let e=ee(t).replace(/,\s*([}\]])/g,"$1");return JSON.parse(e)}function nt(t){for(let n of te){let e=O.join(t,n);if(T.existsSync(e))return e}return null}function it(t){try{let n=T.readFileSync(t,"utf-8"),e=rt(n);return typeof e=="object"&&e!==null?e:{}}catch{return{}}}function G(t,n){let e={...t};for(let r of Object.keys(n)){let i=e[r],a=n[r];i&&a&&typeof i=="object"&&typeof a=="object"&&!Array.isArray(i)&&!Array.isArray(a)?e[r]=G(i,a):a!==void 0&&(e[r]=a)}return e}function bt(){return O.join(Zt.homedir(),".config","opencode")}function ne(){return process.env.OPENCODE_CONFIG_DIR||null}function ie(t){return O.join(t,".opencode")}function re(){let t=bt(),n=O.join(t,"haimati.jsonc");if(!T.existsSync(n))try{T.existsSync(t)||T.mkdirSync(t,{recursive:!0}),T.writeFileSync(n,`{
1
+ import nt from"path";import{tool as $}from"@opencode-ai/plugin";import S from"path";import Mt from"os";import K from"fs";var $t=".haimati",Pt="\u7D22\u5F15.md";var bt="info";import N from"path";import ee from"os";import F from"fs";var ne=["haimati.jsonc","haimati.json"];function ie(t){let n="",e=0,r=!1;for(;e<t.length;){let i=t[e],o=t[e+1];if(r){if(i==="\\"){n+=i+o,e+=2;continue}i==='"'&&(r=!1),n+=i,e++;continue}if(i==='"'){r=!0,n+=i,e++;continue}if(i==="/"&&o==="/"){for(;e<t.length&&t[e]!==`
2
+ `;)e++;continue}if(i==="/"&&o==="*"){for(e+=2;e<t.length-1&&!(t[e]==="*"&&t[e+1]==="/");)e++;e+=2;continue}n+=i,e++}return n}function ot(t){let e=ie(t).replace(/,\s*([}\]])/g,"$1");return JSON.parse(e)}function it(t){for(let n of ne){let e=N.join(t,n);if(F.existsSync(e))return e}return null}function rt(t){try{let n=F.readFileSync(t,"utf-8"),e=ot(n);return typeof e=="object"&&e!==null?e:{}}catch{return{}}}function z(t,n){let e={...t};for(let r of Object.keys(n)){let i=e[r],o=n[r];i&&o&&typeof i=="object"&&typeof o=="object"&&!Array.isArray(i)&&!Array.isArray(o)?e[r]=z(i,o):o!==void 0&&(e[r]=o)}return e}function xt(){return N.join(ee.homedir(),".config","opencode")}function re(){return process.env.OPENCODE_CONFIG_DIR||null}function oe(t){return N.join(t,".opencode")}function ae(){let t=xt(),n=N.join(t,"haimati.jsonc");if(!F.existsSync(n))try{F.existsSync(t)||F.mkdirSync(t,{recursive:!0}),F.writeFileSync(n,`{
3
3
  // \u6D77\u9A6C\u4F53\u5B58\u50A8\u8DEF\u5F84\uFF08\u76F8\u5BF9\u4E8E\u9879\u76EE\u6839\u76EE\u5F55\uFF0C\u6216\u4F7F\u7528\u7EDD\u5BF9\u8DEF\u5F84\uFF09
4
4
  // "haimatiPath": ".haimati",
5
5
 
@@ -22,97 +22,103 @@ import{tool as $}from"@opencode-ai/plugin";import I from"path";import Mt from"os
22
22
  // \u542F\u52A8\u65F6\u68C0\u67E5 npm registry \u662F\u5426\u6709\u65B0\u7248\u672C
23
23
  // "autoUpdate": true
24
24
  }
25
- `,"utf-8")}catch{}}function z(t){re();let n={},e=nt(bt());if(e){let a=it(e);n=G(n,a)}let r=ne();if(r){let a=nt(r);if(a){let o=it(a);n=G(n,o)}}let i=nt(ie(t));if(i){let a=it(i);n=G(n,a)}return n}function xt(t,n,e){return t.haimatiPath?O.resolve(n,t.haimatiPath):e}function S(t){let n=z(t),e=I.join(t,wt);return xt(n,t,e)}function _(t){return I.join(S(t),$t)}function at(t){return I.join(S(t),".lock")}function st(t){return I.join(S(t),"\u4E66\u9875")}function ct(t,n){let e=parseInt(n,10),r=Math.floor((e-1)/50)*50+1,i=r+50-1,a=`${String(r).padStart(3,"0")}-${String(i).padStart(3,"0")}`;return I.join(st(t),a)}function K(t,n){let e=String(parseInt(n,10)).padStart(3,"0");return I.join(ct(t,n),`${e}.md`)}function lt(){let t=Mt.homedir();return I.join(t,".opencode-haimati","log")}function ut(){let t={level:Pt,logRetentionDays:180},n=I.join(Mt.homedir(),".config","opencode"),e=[I.join(n,"haimati.jsonc"),I.join(n,"haimati.json")].find(r=>J.existsSync(r));if(e)try{let r=J.readFileSync(e,"utf-8"),i=rt(r);if(i?.log)return{level:i.log.level||t.level,logRetentionDays:i.log.logRetentionDays??t.logRetentionDays}}catch{}return t}function E(t){return J.promises.mkdir(t,{recursive:!0}).then(()=>{})}function P(t){return J.promises.access(t).then(()=>!0).catch(()=>!1)}import Dt from"fs";import{promisify as Et}from"util";import Y from"fs";import ft from"path";import{promisify as Q}from"util";var se=Q(Y.appendFile),ce=Q(Y.readdir),le=Q(Y.unlink),ue=Q(Y.stat),_t={debug:0,info:1,warn:2,error:3};function fe(t){let n=t.getFullYear(),e=String(t.getMonth()+1).padStart(2,"0"),r=String(t.getDate()).padStart(2,"0");return`${n}-${e}-${r}`}function de(t){let n=t.getFullYear(),e=String(t.getMonth()+1).padStart(2,"0"),r=String(t.getDate()).padStart(2,"0"),i=String(t.getHours()).padStart(2,"0"),a=String(t.getMinutes()).padStart(2,"0"),o=String(t.getSeconds()).padStart(2,"0");return`${n}-${e}-${r} ${i}:${a}:${o}`}function me(){let t=fe(new Date);return ft.join(lt(),`${t}.log`)}async function ge(t,n){try{let e=ft.dirname(t);await P(e)||await E(e),await se(t,n+`
26
- `,"utf-8")}catch(e){console.error("[haimati] \u5199\u5165\u65E5\u5FD7\u6587\u4EF6\u5931\u8D25:",e)}}async function It(){try{let t=ut(),n=lt();if(!await P(n))return;let e=await ce(n),i=new Date().getTime()-t.logRetentionDays*24*60*60*1e3;for(let a of e){if(!a.match(/^\d{4}-\d{2}-\d{2}\.log$/))continue;let o=ft.join(n,a);(await ue(o)).mtime.getTime()<i&&await le(o)}}catch(t){console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",t)}}async function B(t,n,e){try{let r=ut();if(_t[t]<_t[r.level])return;let a=de(new Date),o=e?`[${e}] `:"",l=`[${a}] [${t.toUpperCase()}] ${o}${n}`,f=me();await ge(f,l),It().catch(u=>{console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",u)})}catch(r){console.error("[haimati] \u65E5\u5FD7\u8BB0\u5F55\u5931\u8D25:",r)}}var c={debug(t,n){return B("debug",t,n)},info(t,n){return B("info",t,n)},warn(t,n){return B("warn",t,n)},error(t,n){return B("error",t,n)}};async function St(){await It()}var kt=Et(Dt.readFile),pe=Et(Dt.writeFile);function V(t){let n=0,e=0,r=t.length;for(;e<r;)if(t[e]==="\u2502"&&e+3<r&&t.slice(e+1,e+4)===" ")n++,e+=4;else if(t.slice(e,e+4)===" ")n++,e+=4;else{if((t[e]==="\u251C"||t[e]==="\u2514")&&e+3<r&&t.slice(e+1,e+4)==="\u2500\u2500 ")break;break}return n}function X(t){let e=t.trim().replace(/^[│├└─\s]+/,"").trim();return e==="/"?"/":!e.endsWith("/")||(e=e.slice(0,-1),!e)?null:e}function he(t){let n=[],e=t.split(`
27
- `),r=[];for(let i of e){if(!i.trim())continue;let a=V(i),o=i.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(o){let l=o[1].trim(),f=String(parseInt(o[2],10)),s=r.slice(0,a).filter(d=>d!=="").join("/");n.push({id:f,category:s,title:l})}else{let l=X(i);if(l)if(l==="/"){r[a]="";for(let f=a+1;f<r.length;f++)delete r[f]}else{r[a]=l;for(let f=a+1;f<r.length;f++)delete r[f]}}}return n}function A(t,n){return t.find(e=>e.id===n)||null}function vt(t,n,e){return t.find(r=>r.category===n&&r.title===e)||null}function Ct(t,n){return t.filter(e=>e.id!==n)}function dt(t){if(t.length===0)return"";let n={name:"/",children:[],entry:null};for(let a of t){let o=a.category.split("/"),l=n;for(let u=0;u<o.length;u++){let s=o[u];if(!s)continue;let d=l.children.find(m=>m.name===s);d||(d={name:s,children:[],entry:null},l.children.push(d)),l=d}let f={name:a.id,children:[],entry:a};l.children.push(f)}function e(a){a.children.sort((o,l)=>o.name.localeCompare(l.name,void 0,{sensitivity:"base"}));for(let o of a.children)e(o)}e(n);function r(a,o,l){let f=[],u=o+(l?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "),s=a.name==="/"?"/":a.name+"/";f.push(`${u}${s}`),o=o+(l?" ":"\u2502 ");let d=a.children.filter(g=>g.entry===null),m=a.children.filter(g=>g.entry!==null),h=[...d,...m];for(let g=0;g<h.length;g++){let p=h[g],y=g===h.length-1;if(p.entry){let w=p.entry.id.padStart(3,"0"),b=o+(y?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ");f.push(`${b}${p.entry.title} - ${w}`)}else f.push(...r(p,o,y))}return f}return r(n,"",!0).join(`
28
- `)}async function D(t){let n=_(t);if(!await P(n))return[];let e=await kt(n,"utf-8");return he(e)}async function q(t,n){let e=S(t);await P(e)||await E(e);let r=dt(n),i=_(t);await pe(i,r,"utf-8"),await c.debug(`[writeIndex] \u5199\u5165\u7D22\u5F15: ${i}, \u5171${n.length}\u6761`)}async function Lt(t){let n=_(t);return await P(n)?await kt(n,"utf-8"):""}import Z from"fs";import{promisify as tt}from"util";var ye=tt(Z.readFile),we=tt(Z.writeFile),$e=tt(Z.unlink),Ft=tt(Z.mkdir);async function M(t,n){let e=K(t,n);if(!await P(e))return null;let i=(await ye(e,"utf-8")).split(`
29
- `),a="------system------",o=Math.max(0,i.length-5),l=-1;for(let s=i.length-1;s>=o;s--)if(i[s].trim()===a){l=s;break}if(l===-1)return{title:"",createdAt:"",content:i.join(`
30
- `)};let f=i.slice(0,l).join(`
31
- `),u=i[l+1]?.trim();if(!u)return await c.warn("[readPage] \u51FA\u53C2: \u5143\u6570\u636E\u884C\u4E3A\u7A7A"),null;if(u.startsWith("{"))try{let s=JSON.parse(u);return{title:s.title||"",createdAt:s.create_time||"",content:f}}catch{return await c.warn("[readPage] \u51FA\u53C2: JSON \u89E3\u6790\u5931\u8D25"),null}return l+3>=i.length?(await c.warn("[readPage] \u51FA\u53C2: \u65E7\u683C\u5F0F\u4E0D\u5B8C\u6574"),null):{title:u,createdAt:i[l+2]||"",content:f}}async function j(t,n,e,r,i){let a=st(t);await P(a)||await Ft(a,{recursive:!0});let o=ct(t,n);await P(o)||await Ft(o,{recursive:!0});let l=K(t,n),f="------system------",u=JSON.stringify({title:e,create_time:r}),s=`${f}
32
- ${u}`,d=i?`${i}
33
- ${s}`:s;await we(l,d,"utf-8"),await c.debug(`[writePage] \u5199\u5165\u4E66\u9875: ${l}`)}async function Tt(t,n){let e=K(t,n);return await P(e)?(await $e(e),await c.debug(`[deletePage] \u5220\u9664\u4E66\u9875: ${e}`),!0):!1}async function At(t,n,e,r,i=!1){let a=n.toLowerCase().split(/\s+/).filter(f=>f.length>0);if(a.length===0)return[];let o=[];for(let f of t){let u=f.title.toLowerCase(),s=f.category.toLowerCase(),d=f.id.toLowerCase(),m=new Set,h=0;for(let g of a)(u.includes(g)||s.includes(g)||d.includes(g))&&(h++,m.add(g));if(i&&r){let g=await M(r,f.id);if(g&&g.content){let p=g.content.toLowerCase();for(let y of a)p.includes(y)&&(h++,m.add(y))}}e==="and"?m.size===a.length&&o.push({entry:f,score:h}):m.size>0&&o.push({entry:f,score:h})}o.sort((f,u)=>u.score-f.score);let l=o.map(f=>f.entry);return await c.debug(`[searchEntries] \u641C\u7D22\u5B8C\u6210: \u5173\u952E\u5B57="${n}", \u6A21\u5F0F=${e}, \u7ED3\u679C\u6570=${l.length}`),l}import jt from"fs";import{promisify as Rt}from"util";var be=Rt(jt.writeFile),xe=Rt(jt.unlink);async function Wt(t){let n=S(t);await P(n)||await E(n);let e=at(t),r=Date.now(),i=50+Math.random()*20,a=0;for(;await P(e);){if(a++,Date.now()-r>5e3)return await c.warn(`[acquireLock] \u51FA\u53C2: \u9501\u83B7\u53D6\u8D85\u65F6 (\u91CD\u8BD5${a}\u6B21)`),!1;await new Promise(o=>setTimeout(o,i))}return await be(e,String(process.pid),"utf-8"),await c.debug(`[acquireLock] \u9501\u83B7\u53D6\u6210\u529F: ${e}`),!0}async function Nt(t){let n=at(t);await P(n)&&(await xe(n),await c.debug(`[releaseLock] \u9501\u91CA\u653E\u6210\u529F: ${n}`))}async function Ot(t,n,e,r,i,a=!1){if(/ - \d{3}$/.test(e))throw await c.warn(`[allocateIdWithLock] title \u683C\u5F0F\u4E0D\u5408\u89C4: "${e}", \u629B\u51FA\u9519\u8BEF`),new Error('\u6807\u9898\u4E0D\u80FD\u4EE5 " - \u5E8F\u53F7" \u683C\u5F0F\u7ED3\u5C3E\uFF0C\u5E8F\u53F7\u7531\u7CFB\u7EDF\u81EA\u52A8\u5206\u914D\uFF0C\u8BF7\u4FEE\u6539\u6807\u9898');if(await c.debug(`[allocateIdWithLock] \u5F00\u59CB\u5206\u914D\u5E8F\u53F7: category="${n}", title="${e}"`),!await Wt(t))return await c.warn(`[allocateIdWithLock] \u83B7\u53D6\u9501\u5931\u8D25: category="${n}", title="${e}"`),null;try{let o=await D(t),l=o.find(d=>d.category===n&&d.title===e);if(l){if(!a)throw new Error(`\u8BB0\u5FC6\u5DF2\u5B58\u5728: ${n}/${e}\uFF0C\u5982\u9700\u66F4\u65B0\u8BF7\u4F7F\u7528 haimati_edit \u5DE5\u5177`);let d=await M(t,l.id),m=d?d.createdAt:r;return await j(t,l.id,e,m,i),await c.debug(`[allocateIdWithLock] \u66F4\u65B0\u5DF2\u6709\u6761\u76EE: #${l.id} ${n}/${e}`),null}let f=0;for(let d of o){let m=parseInt(d.id,10);m>f&&(f=m)}let u=String(f+1).padStart(3,"0");await j(t,u,e,r,i);let s={id:u,category:n,title:e};return o.push(s),await q(t,o),await c.debug(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u6210\u529F: #${u} ${n}/${e}`),u}catch(o){let l=o instanceof Error?o.message:String(o);if(await c.error(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u5931\u8D25: ${l}`),l.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw o;return null}finally{await Nt(t)}}import qt from"fs";import et from"path";import{promisify as Ht}from"util";var Me=Ht(qt.readFile),_e=Ht(qt.writeFile);function Ut(t){return S(t).replace(/\\/g,"/")+"/memo-map.yaml"}function Ie(t){return t.startsWith('"')&&t.endsWith('"')||t.startsWith("'")&&t.endsWith("'")}function Se(t){return Ie(t)?t.slice(1,-1):t}function De(t){let n={},e=t.split(`
34
- `),r=null;for(let i of e){if(!i.trim()||i.trim().startsWith("#"))continue;if(!i.startsWith(" ")&&!i.startsWith(" ")){let l=i.indexOf(":");if(l===-1)continue;let f=i.slice(0,l).trim();r=Se(f);let u=i.slice(l+1).trim();if(u){if(u.match(/^\[\s*"([^"]*)"\s*(?:,\s*"([^"]*)"\s*)*\]$/)){n[r]=[];let d=u.match(/"([^"]*)"/g);d&&(n[r]=d.map(m=>m.slice(1,-1))),r=null}}else n[r]=[];continue}if(!r)continue;let o=i.trim().match(/^-\s*"([^"]*)"$/);o&&n[r].push(o[1])}return n}function Ee(t){if(Object.keys(t).length===0)return"";let n=`# \u8BB0\u5FC6\u4E0E\u9879\u76EE\u6587\u4EF6\u7684\u5173\u8054\u6620\u5C04
35
- `,e=Object.keys(t).sort();for(let r of e){let i=t[r];if(!i||i.length===0)continue;let o=r.includes(":")||r.includes("#")||r.includes(" ")||r.startsWith('"')?`"${r}"`:r;n+=`${o}:
36
- `;for(let l of i)n+=` - "${l}"
37
- `}return n}async function k(t){let n=Ut(t);if(!await P(n))return{};let e=await Me(n,"utf-8"),r=De(e);return await c.debug(`[memoMap] \u52A0\u8F7D\u6620\u5C04: ${n}, ${Object.keys(r).length} \u4E2A\u6587\u4EF6`),r}async function R(t,n){let e=S(t);await P(e)||await E(e);let r=Ut(t),i=Ee(n);await _e(r,i,"utf-8"),await c.debug(`[memoMap] \u4FDD\u5B58\u6620\u5C04: ${r}, ${Object.keys(n).length} \u4E2A\u6587\u4EF6`)}function W(t,n){let e=n.endsWith("/")||n.endsWith("\\"),r=et.isAbsolute(n)?n.replace(/[\\/]$/,""):et.resolve(t,n.replace(/[\\/]$/,"")),i=et.relative(t,r).replace(/\\/g,"/");return e?i+"/":i}function H(t){return String(parseInt(t,10))}function gt(t,n,e){let r=n.replace(/\\/g,"/"),i=H(e);return t[r]||(t[r]=[]),t[r].includes(i)||(t[r].push(i),t[r].sort((a,o)=>parseInt(a)-parseInt(o))),t}function Gt(t,n){let e=H(n);for(let r of Object.keys(t)){let i=t[r];if(!i)continue;let a=i.filter(o=>H(o)!==e);a.length===0?delete t[r]:a.length!==i.length&&(t[r]=a)}return t}function zt(t,n,e){let r=n.replace(/\\/g,"/"),i=H(e),a=t[r];if(!a)return t;let o=a.filter(l=>H(l)!==i);return o.length===0?delete t[r]:o.length!==a.length&&(t[r]=o),t}function mt(t){return t.endsWith("/")}function Jt(t,n){let e=n.replace(/\\/g,"/"),r=new Set;if(t[e]&&!mt(e))for(let o of t[e])r.add(o);let i=e.split("/");for(let o=i.length-1;o>=0;o--){let l=i.slice(0,o).join("/")+(o===0&&i[0]==="","/"),f=t[l];if(f)for(let u of f)r.add(u)}let a=Array.from(r);return a.sort((o,l)=>parseInt(o)-parseInt(l)),a}function ke(t,n){return et.resolve(t,n)}async function Kt(t){let n=await k(t);if(Object.keys(n).length===0)return 0;let e=0;for(let r of Object.keys(n)){let i=mt(r)?r.replace(/\/$/,""):r,a=ke(t,i);await P(a)||(delete n[r],e++,await c.info(`[memoMap] \u6E05\u7406\u4E0D\u5B58\u5728${mt(r)?"\u76EE\u5F55":"\u6587\u4EF6"}: ${r}`))}return e>0&&(await R(t,n),await c.info(`[memoMap] \u542F\u52A8\u6E05\u7406\u5B8C\u6210\uFF0C\u79FB\u9664 ${e} \u4E2A\u4E0D\u5B58\u5728\u6761\u76EE`)),e}function v(t){let n=t;return typeof n?.directory=="string"&&n.directory?n.directory:null}function ve(t){let n=t.trim().replace(/^#+/,"");if(!n)return null;if(/^\d+$/.test(n))return[String(parseInt(n,10))];let e=[],r=n.split(",");for(let i of r){let a=i.trim().replace(/^#+/,"");if(!a)return null;let o=a.match(/^(\d+)\s*-\s*(\d+)$/);if(o){let l=parseInt(o[1],10),f=parseInt(o[2],10);if(l>f||l<=0)return null;for(let u=l;u<=f;u++)e.push(String(u))}else if(/^\d+$/.test(a))e.push(String(parseInt(a,10)));else return null}return e}function U(t,n,e){let r=n.content.split(`
38
- `),i=[],a=e?.offset?Math.max(0,e.offset-1):0,o=e?.limit?Math.min(r.length,a+e.limit):r.length;for(let l=a;l<o;l++)i.push(`${l+1}|${r[l]}`);return i.push("------system------"),i.push(`\u6807\u9898:${t.title}`),i.push(`\u521B\u5EFA\u65F6\u95F4:${n.createdAt}`),i.join(`
39
- `)}async function C(t,n){let e=t instanceof Error?t.message:String(t),r=t instanceof Error?t.stack:"";return await c.error(`[${n}] \u51FA\u53C2: \u9519\u8BEF: ${e}
40
- \u5806\u6808: ${r}`),`\u9519\u8BEF: ${e}`}function pt(t){return/^\d+$/.test(t.trim())?String(parseInt(t.trim(),10)):null}function Bt(){return{haimati_read:$({description:`\u4ECE\u6D77\u9A6C\u4F53\u8BFB\u53D6\u8BB0\u5FC6\u3002\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\uFF0C\u81EA\u52A8\u8865\u5168\uFF08\u8F93\u5165'86'\u2192'086'\uFF09\u3002\u652F\u6301\u5355\u6761\u5206\u9875\uFF08offset/limit\uFF09\u548C\u6279\u91CF\u8BFB\u53D6\uFF08\u9017\u53F7\u5206\u9694\u5982'086,087'\uFF0C\u8303\u56F4\u5982'086-090'\uFF09\u3002\u8FD4\u56DE\u4EE5 "===== #N =====" \u5F00\u5934\uFF0C\u884C\u9996 "N|" \u4E3A\u884C\u53F7\u3002`,args:{query:$.schema.string().describe("\u5E8F\u53F7\u3002\u5355\u6761\u5982 '086'\uFF0C\u6279\u91CF\u652F\u6301\u9017\u53F7\u5206\u9694\u5982 '086,087,088' \u6216\u8303\u56F4 '086-090'"),offset:$.schema.number().optional().default(1).describe("\u8D77\u59CB\u884C\u53F7\uFF08\u9ED8\u8BA4 1\uFF0C\u4EC5\u5355\u6761\u8BFB\u53D6\u751F\u6548\uFF09"),limit:$.schema.number().optional().default(2e3).describe("\u6700\u5927\u8BFB\u53D6\u884C\u6570\uFF08\u9ED8\u8BA4 2000\uFF0C\u4EC5\u5355\u6761\u8BFB\u53D6\u751F\u6548\uFF09")},async execute(t,n){let e=v(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=_(e);if(await c.info(`[haimati_read] \u5F00\u59CB\u8BFB\u53D6 #${t.query}`),await c.debug(`[haimati_read] \u5165\u53C2: query="${t.query}", offset=${t.offset??1}, limit=${t.limit??2e3}`),!await P(r)){let i=`\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728\u4E8E ${r}`;return await c.debug(`[haimati_read] \u51FA\u53C2:
41
- ${i}`),i}try{let i=await D(e),a=t.query.trim(),o=ve(a);if(!o||o.length===0){let s=`\u9519\u8BEF\uFF1A\u65E0\u6548\u7684\u67E5\u8BE2\u683C\u5F0F "${a}"`;return await c.debug(`[haimati_read] \u51FA\u53C2:
42
- ${s}`),s}if(o.length===1){let s=o[0],d=A(i,s);if(!d)return await c.info(`[haimati_read] \u8BFB\u53D6\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;let m=await M(e,d.id);if(!m)return`\u672A\u627E\u5230\u4E66\u9875: #${d.id.padStart(3,"0")}`;let h=U(d,m,{offset:t.offset??1,limit:t.limit??2e3}),g=`===== #${d.id.padStart(3,"0")} =====
43
- ${h}`;return await c.debug(`[haimati_read] \u51FA\u53C2:
44
- ${g}`),await c.info(`[haimati_read] \u8BFB\u53D6\u6210\u529F: #${d.id} (${d.category}/${d.title})`),g}let l=[],f=0;for(let s of o){let d=A(i,s);if(!d){await c.warn(`[haimati_read] \u6279\u91CF: \u672A\u627E\u5230\u8BB0\u5FC6 #${s}`),l.push(`===== #${s.padStart(3,"0")} =====
45
- \u672A\u627E\u5230\u8BB0\u5FC6: ${s}`);continue}let m=await M(e,d.id);if(!m){await c.error(`[haimati_read] \u6279\u91CF: \u672A\u627E\u5230\u4E66\u9875 #${d.id}`),l.push(`===== #${d.id.padStart(3,"0")} =====
46
- \u672A\u627E\u5230\u4E66\u9875`);continue}let h=U(d,m);l.push(`===== #${d.id.padStart(3,"0")} =====
47
- ${h}`),f++}let u=l.join(`
48
-
49
- `);return await c.info(`[haimati_read] \u6279\u91CF\u8BFB\u53D6\u7ED3\u675F: \u5171 ${o.length} \u6761, \u6210\u529F ${f} \u6761`),u}catch(i){return await C(i,"haimati_read")}}}),haimati_write:$({description:'\u5199\u5165\u65B0\u8BB0\u5FC6\u3002\u81EA\u52A8\u5206\u914D\u5E8F\u53F7\uFF0C\u76F8\u540C\u5206\u7C7B+\u6807\u9898\u4E0D\u53EF\u91CD\u590D\u5199\u5165\uFF08\u9700\u7528 haimati_edit \u66F4\u65B0\uFF09\u3002filePath \u53EF\u9009\uFF1A\u5173\u8054\u9879\u76EE\u6587\u4EF6/\u76EE\u5F55\uFF08\u672B\u5C3E/\u8868\u793A\u76EE\u5F55\uFF0C\u5339\u914D\u8BE5\u76EE\u5F55\u4E0B\u6240\u6709\u6587\u4EF6\uFF09\uFF0C\u540E\u7EED\u8BFB\u53D6\u65F6\u81EA\u52A8\u63D0\u793A\u76F8\u5173\u8BB0\u5FC6\u3002title \u4E0D\u80FD\u4EE5 " - \u5E8F\u53F7" \u7ED3\u5C3E\u3002',args:{category:$.schema.string().describe("\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0' \u6216 '\u901A\u7528'"),title:$.schema.string().describe("\u8BB0\u5FC6\u6807\u9898\uFF0C\u5982 '\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236'"),content:$.schema.string().describe("\u8981\u5199\u5165\u7684\u8BE6\u7EC6\u5185\u5BB9"),filePath:$.schema.string().optional().describe("\u5173\u8054\u7684\u9879\u76EE\u6587\u4EF6\u76F8\u5BF9\u8DEF\u5F84\uFF0C\u5982 'src/index.ts'\u3002\u672B\u5C3E\u52A0 / \u8868\u793A\u76EE\u5F55\uFF0C\u5982 'src/' \u4F1A\u5339\u914D\u8BE5\u76EE\u5F55\u4E0B\u6240\u6709\u6587\u4EF6\uFF08\u542B\u5B50\u76EE\u5F55\uFF09\u3002\u4F20\u5165\u540E\u5728 .haimati/memo-map.yaml \u4E2D\u5EFA\u7ACB\u6587\u4EF6\u2192\u8BB0\u5FC6\u7684\u6620\u5C04\u5173\u7CFB\u3002\u6B64\u540E AI \u901A\u8FC7 read \u5DE5\u5177\u8BFB\u53D6\u8BE5\u6587\u4EF6\u6216\u76EE\u5F55\u4E0B\u7684\u6587\u4EF6\u65F6\uFF0C\u4F1A\u81EA\u52A8\u5728\u8F93\u51FA\u4E2D\u6CE8\u5165\u63D0\u793A\uFF1A'{\u6587\u4EF6}\u548C\u6D77\u9A6C\u4F53#N\u6709\u5173\uFF0C\u5EFA\u8BAE\u8BFB\u53D6\u8BB0\u5FC6'")},async execute(t,n){let e=v(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=t.filePath?.trim()||null;await c.info(`[haimati_write] \u5F00\u59CB\u5199\u5165 ${t.category}/${t.title}`),await c.debug(`[haimati_write] \u5165\u53C2: category="${t.category}", title="${t.title}", filePath="${r||"(\u65E0)"}", content=
50
- ${t.content}`);try{let i=new Date().toLocaleString("zh-CN",{hour12:!1}),a=null;for(let u=0;u<3;u++)try{if(a=await Ot(e,t.category,t.title,i,t.content,!1),a)break;await c.warn(`[haimati_write] \u9501\u83B7\u53D6\u5931\u8D25\uFF0C\u91CD\u8BD5\u7B2C ${u+1} \u6B21`)}catch(s){let d=s instanceof Error?s.message:String(s);if(d.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw s;await c.warn(`[haimati_write] \u83B7\u53D6\u9501\u5F02\u5E38: ${d}, \u91CD\u8BD5\u7B2C ${u+1} \u6B21`)}if(a){if(r){let s=await k(e),d=W(e,r);gt(s,d,a),await R(e,s),await c.info(`[haimati_write] \u5EFA\u7ACB\u6587\u4EF6\u5173\u8054: ${d} -> #${a}`)}let u=`\u5DF2\u5199\u5165\u6D77\u9A6C\u4F53 #${a}
25
+ `,"utf-8")}catch{}}function J(t){ae();let n={},e=it(xt());if(e){let o=rt(e);n=z(n,o)}let r=re();if(r){let o=it(r);if(o){let a=rt(o);n=z(n,a)}}let i=it(oe(t));if(i){let o=rt(i);n=z(n,o)}return n}function _t(t,n,e){return t.haimatiPath?N.resolve(n,t.haimatiPath):e}function I(t){let n=J(t),e=S.join(t,$t);return _t(n,t,e)}function M(t){return S.join(I(t),Pt)}function st(t){return S.join(I(t),".lock")}function ct(t){return S.join(I(t),"\u4E66\u9875")}function lt(t,n){let e=parseInt(n,10),r=Math.floor((e-1)/50)*50+1,i=r+50-1,o=`${String(r).padStart(3,"0")}-${String(i).padStart(3,"0")}`;return S.join(ct(t),o)}function B(t,n){let e=String(parseInt(n,10)).padStart(3,"0");return S.join(lt(t,n),`${e}.md`)}function ut(){let t=Mt.homedir();return S.join(t,".opencode-haimati","log")}function ft(){let t={level:bt,logRetentionDays:180},n=S.join(Mt.homedir(),".config","opencode"),e=[S.join(n,"haimati.jsonc"),S.join(n,"haimati.json")].find(r=>K.existsSync(r));if(e)try{let r=K.readFileSync(e,"utf-8"),i=ot(r);if(i?.log)return{level:i.log.level||t.level,logRetentionDays:i.log.logRetentionDays??t.logRetentionDays}}catch{}return t}function E(t){return K.promises.mkdir(t,{recursive:!0}).then(()=>{})}function P(t){return K.promises.access(t).then(()=>!0).catch(()=>!1)}import Et from"fs";import{promisify as vt}from"util";import Y from"fs";import dt from"path";import{promisify as V}from"util";var le=V(Y.appendFile),ue=V(Y.readdir),fe=V(Y.unlink),de=V(Y.stat),St={debug:0,info:1,warn:2,error:3};function me(t){let n=t.getFullYear(),e=String(t.getMonth()+1).padStart(2,"0"),r=String(t.getDate()).padStart(2,"0");return`${n}-${e}-${r}`}function ge(t){let n=t.getFullYear(),e=String(t.getMonth()+1).padStart(2,"0"),r=String(t.getDate()).padStart(2,"0"),i=String(t.getHours()).padStart(2,"0"),o=String(t.getMinutes()).padStart(2,"0"),a=String(t.getSeconds()).padStart(2,"0");return`${n}-${e}-${r} ${i}:${o}:${a}`}function pe(){let t=me(new Date);return dt.join(ut(),`${t}.log`)}async function he(t,n){try{let e=dt.dirname(t);await P(e)||await E(e),await le(t,n+`
26
+ `,"utf-8")}catch(e){console.error("[haimati] \u5199\u5165\u65E5\u5FD7\u6587\u4EF6\u5931\u8D25:",e)}}async function It(){try{let t=ft(),n=ut();if(!await P(n))return;let e=await ue(n),i=new Date().getTime()-t.logRetentionDays*24*60*60*1e3;for(let o of e){if(!o.match(/^\d{4}-\d{2}-\d{2}\.log$/))continue;let a=dt.join(n,o);(await de(a)).mtime.getTime()<i&&await fe(a)}}catch(t){console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",t)}}async function Q(t,n,e){try{let r=ft();if(St[t]<St[r.level])return;let o=ge(new Date),a=e?`[${e}] `:"",c=`[${o}] [${t.toUpperCase()}] ${a}${n}`,u=pe();await he(u,c),It().catch(d=>{console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",d)})}catch(r){console.error("[haimati] \u65E5\u5FD7\u8BB0\u5F55\u5931\u8D25:",r)}}var l={debug(t,n){return Q("debug",t,n)},info(t,n){return Q("info",t,n)},warn(t,n){return Q("warn",t,n)},error(t,n){return Q("error",t,n)}};async function Dt(){await It()}var kt=vt(Et.readFile),ye=vt(Et.writeFile);function X(t){let n=0,e=0,r=t.length;for(;e<r;)if(t[e]==="\u2502"&&e+3<r&&t.slice(e+1,e+4)===" ")n++,e+=4;else if(t.slice(e,e+4)===" ")n++,e+=4;else{if((t[e]==="\u251C"||t[e]==="\u2514")&&e+3<r&&t.slice(e+1,e+4)==="\u2500\u2500 ")break;break}return n}function Z(t){let e=t.trim().replace(/^[│├└─\s]+/,"").trim();return e==="/"?"/":!e.endsWith("/")||(e=e.slice(0,-1),!e)?null:e}function we(t){let n=[],e=t.split(`
27
+ `),r=[];for(let i of e){if(!i.trim())continue;let o=X(i),a=i.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(a){let c=a[1].trim(),u=String(parseInt(a[2],10)),s=r.slice(0,o).filter(f=>f!=="").join("/");n.push({id:u,category:s,title:c})}else{let c=Z(i);if(c)if(c==="/"){r[o]="";for(let u=o+1;u<r.length;u++)delete r[u]}else{r[o]=c;for(let u=o+1;u<r.length;u++)delete r[u]}}}return n}function T(t,n){return t.find(e=>e.id===n)||null}function Ct(t,n,e){return t.find(r=>r.category===n&&r.title===e)||null}function Lt(t,n){return t.filter(e=>e.id!==n)}function mt(t){if(t.length===0)return"";let n={name:"/",children:[],entry:null};for(let o of t){let a=o.category.split("/"),c=n;for(let d=0;d<a.length;d++){let s=a[d];if(!s)continue;let f=c.children.find(m=>m.name===s);f||(f={name:s,children:[],entry:null},c.children.push(f)),c=f}let u={name:o.id,children:[],entry:o};c.children.push(u)}function e(o){o.children.sort((a,c)=>a.name.localeCompare(c.name,void 0,{sensitivity:"base"}));for(let a of o.children)e(a)}e(n);function r(o,a,c){let u=[],d=a+(c?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "),s=o.name==="/"?"/":o.name+"/";u.push(`${d}${s}`),a=a+(c?" ":"\u2502 ");let f=o.children.filter(g=>g.entry===null),m=o.children.filter(g=>g.entry!==null),y=[...f,...m];for(let g=0;g<y.length;g++){let p=y[g],h=g===y.length-1;if(p.entry){let w=p.entry.id.padStart(3,"0"),b=a+(h?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ");u.push(`${b}${p.entry.title} - ${w}`)}else u.push(...r(p,a,h))}return u}return r(n,"",!0).join(`
28
+ `)}async function D(t){let n=M(t);if(!await P(n))return[];let e=await kt(n,"utf-8");return we(e)}async function O(t,n){let e=I(t);await P(e)||await E(e);let r=mt(n),i=M(t);await ye(i,r,"utf-8"),await l.debug(`[writeIndex] \u5199\u5165\u7D22\u5F15: ${i}, \u5171${n.length}\u6761`)}async function At(t){let n=M(t);return await P(n)?await kt(n,"utf-8"):""}import tt from"fs";import{promisify as et}from"util";var $e=et(tt.readFile),Pe=et(tt.writeFile),be=et(tt.unlink),Ft=et(tt.mkdir);async function _(t,n){let e=B(t,n);if(!await P(e))return null;let i=(await $e(e,"utf-8")).split(`
29
+ `),o="------system------",a=Math.max(0,i.length-5),c=-1;for(let s=i.length-1;s>=a;s--)if(i[s].trim()===o){c=s;break}if(c===-1)return{title:"",createdAt:"",updatedAt:"",content:i.join(`
30
+ `)};let u=i.slice(0,c).join(`
31
+ `),d=i[c+1]?.trim();if(!d)return await l.warn("[readPage] \u51FA\u53C2: \u5143\u6570\u636E\u884C\u4E3A\u7A7A"),null;if(d.startsWith("{"))try{let s=JSON.parse(d);return{title:s.title||"",createdAt:s.create_time||"",updatedAt:s.update_time||s.create_time||"",content:u}}catch{return await l.warn("[readPage] \u51FA\u53C2: JSON \u89E3\u6790\u5931\u8D25"),null}return c+3>=i.length?(await l.warn("[readPage] \u51FA\u53C2: \u65E7\u683C\u5F0F\u4E0D\u5B8C\u6574"),null):{title:d,createdAt:i[c+2]||"",updatedAt:"",content:u}}async function j(t,n,e,r,i,o){let a=ct(t);await P(a)||await Ft(a,{recursive:!0});let c=lt(t,n);await P(c)||await Ft(c,{recursive:!0});let u=B(t,n),d="------system------",s=JSON.stringify({title:e,create_time:r,update_time:i}),f=`${d}
32
+ ${s}`,m=o?`${o}
33
+ ${f}`:f;await Pe(u,m,"utf-8"),await l.debug(`[writePage] \u5199\u5165\u4E66\u9875: ${u}`)}async function Tt(t,n){let e=B(t,n);return await P(e)?(await be(e),await l.debug(`[deletePage] \u5220\u9664\u4E66\u9875: ${e}`),!0):!1}async function jt(t,n,e,r,i=!1){let o=n.toLowerCase().split(/\s+/).filter(u=>u.length>0);if(o.length===0)return[];let a=[];for(let u of t){let d=u.title.toLowerCase(),s=u.category.toLowerCase(),f=u.id.toLowerCase(),m=new Set,y=0;for(let g of o)(d.includes(g)||s.includes(g)||f.includes(g))&&(y++,m.add(g));if(i&&r){let g=await _(r,u.id);if(g&&g.content){let p=g.content.toLowerCase();for(let h of o)p.includes(h)&&(y++,m.add(h))}}e==="and"?m.size===o.length&&a.push({entry:u,score:y}):m.size>0&&a.push({entry:u,score:y})}a.sort((u,d)=>d.score-u.score);let c=a.map(u=>u.entry);return await l.debug(`[searchEntries] \u641C\u7D22\u5B8C\u6210: \u5173\u952E\u5B57="${n}", \u6A21\u5F0F=${e}, \u7ED3\u679C\u6570=${c.length}`),c}import Rt from"fs";import{promisify as Wt}from"util";var _e=Wt(Rt.writeFile),Me=Wt(Rt.unlink);async function Nt(t){let n=I(t);await P(n)||await E(n);let e=st(t),r=Date.now(),i=50+Math.random()*20,o=0;for(;await P(e);){if(o++,Date.now()-r>5e3)return await l.warn(`[acquireLock] \u51FA\u53C2: \u9501\u83B7\u53D6\u8D85\u65F6 (\u91CD\u8BD5${o}\u6B21)`),!1;await new Promise(a=>setTimeout(a,i))}return await _e(e,String(process.pid),"utf-8"),await l.debug(`[acquireLock] \u9501\u83B7\u53D6\u6210\u529F: ${e}`),!0}async function Ot(t){let n=st(t);await P(n)&&(await Me(n),await l.debug(`[releaseLock] \u9501\u91CA\u653E\u6210\u529F: ${n}`))}async function qt(t,n,e,r,i,o=!1){if(/ - \d{3}$/.test(e))throw await l.warn(`[allocateIdWithLock] title \u683C\u5F0F\u4E0D\u5408\u89C4: "${e}", \u629B\u51FA\u9519\u8BEF`),new Error('\u6807\u9898\u4E0D\u80FD\u4EE5 " - \u5E8F\u53F7" \u683C\u5F0F\u7ED3\u5C3E\uFF0C\u5E8F\u53F7\u7531\u7CFB\u7EDF\u81EA\u52A8\u5206\u914D\uFF0C\u8BF7\u4FEE\u6539\u6807\u9898');if(await l.debug(`[allocateIdWithLock] \u5F00\u59CB\u5206\u914D\u5E8F\u53F7: category="${n}", title="${e}"`),!await Nt(t))return await l.warn(`[allocateIdWithLock] \u83B7\u53D6\u9501\u5931\u8D25: category="${n}", title="${e}"`),null;try{let a=await D(t),c=a.find(f=>f.category===n&&f.title===e);if(c){if(!o)throw new Error(`\u8BB0\u5FC6\u5DF2\u5B58\u5728: ${n}/${e}\uFF0C\u5982\u9700\u66F4\u65B0\u8BF7\u4F7F\u7528 haimati_edit \u5DE5\u5177`);let f=await _(t,c.id),m=f?f.createdAt:r;return await j(t,c.id,e,m,r,i),await l.debug(`[allocateIdWithLock] \u66F4\u65B0\u5DF2\u6709\u6761\u76EE: #${c.id} ${n}/${e}`),null}let u=0;for(let f of a){let m=parseInt(f.id,10);m>u&&(u=m)}let d=String(u+1).padStart(3,"0");await j(t,d,e,r,r,i);let s={id:d,category:n,title:e};return a.push(s),await O(t,a),await l.debug(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u6210\u529F: #${d} ${n}/${e}`),d}catch(a){let c=a instanceof Error?a.message:String(a);if(await l.error(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u5931\u8D25: ${c}`),c.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw a;return null}finally{await Ot(t)}}import Ht from"fs";import q from"path";import{promisify as Ut}from"util";var Se=Ut(Ht.readFile),Ie=Ut(Ht.writeFile);function Gt(t){return I(t).replace(/\\/g,"/")+"/memo-map.yaml"}function De(t){return t.startsWith('"')&&t.endsWith('"')||t.startsWith("'")&&t.endsWith("'")}function Ee(t){return De(t)?t.slice(1,-1):t}function ve(t){let n={},e=t.split(`
34
+ `),r=null;for(let i of e){if(!i.trim()||i.trim().startsWith("#"))continue;if(!i.startsWith(" ")&&!i.startsWith(" ")){let c;if(i.startsWith('"')){let s=i.indexOf('"',1);if(s===-1)continue;c=i.indexOf(":",s)}else c=i.indexOf(":");if(c===-1)continue;let u=i.slice(0,c).trim();r=Ee(u);let d=i.slice(c+1).trim();if(d){if(/^\[\s*"[^"]*"(?:\s*,\s*"[^"]*"\s*)*\]$/.test(d)){n[r]=[];let f=d.match(/"([^"]*)"/g);f&&(n[r]=f.map(m=>m.slice(1,-1))),r=null}}else n[r]=[];continue}if(!r)continue;let a=i.trim().match(/^-\s*"([^"]*)"$/);a&&n[r].push(a[1])}return n}function ke(t){if(Object.keys(t).length===0)return"";let n=`# \u8BB0\u5FC6\u4E0E\u9879\u76EE\u6587\u4EF6\u7684\u5173\u8054\u6620\u5C04
35
+ `,e=Object.keys(t).sort();for(let r of e){let i=t[r];if(!i||i.length===0)continue;let a=r.includes(":")||r.includes("#")||r.includes(" ")||r.startsWith('"')?`"${r}"`:r;n+=`${a}:
36
+ `;for(let c of i)n+=` - "${c}"
37
+ `}return n}async function v(t){let n=Gt(t);if(!await P(n))return{};let e=await Se(n,"utf-8"),r=ve(e);return await l.debug(`[memoMap] \u52A0\u8F7D\u6620\u5C04: ${n}, ${Object.keys(r).length} \u4E2A\u6587\u4EF6`),r}async function U(t,n){let e=I(t);await P(e)||await E(e);let r=Gt(t),i=ke(n);await Ie(r,i,"utf-8"),await l.debug(`[memoMap] \u4FDD\u5B58\u6620\u5C04: ${r}, ${Object.keys(n).length} \u4E2A\u6587\u4EF6`)}function R(t,n){let e=n.endsWith("/")||n.endsWith("\\"),r=q.isAbsolute(n)?n.replace(/[\\/]$/,""):q.resolve(t,n.replace(/[\\/]$/,"")),i=q.relative(t,r).replace(/\\/g,"/");if(!i.startsWith("..")&&!q.isAbsolute(i))return e?i+"/":i;let a=r.replace(/\\/g,"/");return e?a+"/":a}function H(t){return String(parseInt(t,10))}function pt(t,n,e){let r=n.replace(/\\/g,"/"),i=H(e);return t[r]||(t[r]=[]),t[r].includes(i)||(t[r].push(i),t[r].sort((o,a)=>parseInt(o)-parseInt(a))),t}function zt(t,n){let e=H(n);for(let r of Object.keys(t)){let i=t[r];if(!i)continue;let o=i.filter(a=>H(a)!==e);o.length===0?delete t[r]:o.length!==i.length&&(t[r]=o)}return t}function Jt(t,n,e){let r=n.replace(/\\/g,"/"),i=H(e),o=t[r];if(!o)return t;let a=o.filter(c=>H(c)!==i);return a.length===0?delete t[r]:a.length!==o.length&&(t[r]=a),t}function gt(t){return t.endsWith("/")}function Kt(t,n){let e=n.replace(/\\/g,"/"),r=new Set,i=/^[A-Za-z]:\//.test(e);if(t[e]&&!gt(e))for(let c of t[e])r.add(c);let o=e.split("/");for(let c=o.length-1;c>=0&&!(c===0&&i);c--){let u=o.slice(0,c).join("/")+(c===0&&o[0]==="","/"),d=t[u];if(d)for(let s of d)r.add(s)}let a=Array.from(r);return a.sort((c,u)=>parseInt(c)-parseInt(u)),a}function Ce(t,n){return q.resolve(t,n)}async function Bt(t){let n=await v(t);if(Object.keys(n).length===0)return 0;let e=0;for(let r of Object.keys(n)){let i=gt(r)?r.replace(/\/$/,""):r,o=Ce(t,i);await P(o)||(delete n[r],e++,await l.info(`[memoMap] \u6E05\u7406\u4E0D\u5B58\u5728${gt(r)?"\u76EE\u5F55":"\u6587\u4EF6"}: ${r}`))}return e>0&&(await U(t,n),await l.info(`[memoMap] \u542F\u52A8\u6E05\u7406\u5B8C\u6210\uFF0C\u79FB\u9664 ${e} \u4E2A\u4E0D\u5B58\u5728\u6761\u76EE`)),e}function k(t){let n=t;return typeof n?.directory=="string"&&n.directory?n.directory:null}function Le(t){let n=t.trim().replace(/^#+/,"");if(!n)return null;if(/^\d+$/.test(n))return[String(parseInt(n,10))];let e=[],r=n.split(",");for(let i of r){let o=i.trim().replace(/^#+/,"");if(!o)return null;let a=o.match(/^(\d+)\s*-\s*(\d+)$/);if(a){let c=parseInt(a[1],10),u=parseInt(a[2],10);if(c>u||c<=0)return null;for(let d=c;d<=u;d++)e.push(String(d))}else if(/^\d+$/.test(o))e.push(String(parseInt(o,10)));else return null}return e}function G(t,n,e){let r=n.content.split(`
38
+ `),i=[],o=e?.offset?Math.max(0,e.offset-1):0,a=e?.limit?Math.min(r.length,o+e.limit):r.length;for(let c=o;c<a;c++)i.push(`${c+1}|${r[c]}`);return i.push("------system------"),i.push(`\u6807\u9898:${t.title}`),i.push(`\u521B\u5EFA\u65F6\u95F4:${n.createdAt}`),n.updatedAt&&i.push(`\u66F4\u65B0\u65F6\u95F4:${n.updatedAt}`),i.join(`
39
+ `)}async function C(t,n){let e=t instanceof Error?t.message:String(t),r=t instanceof Error?t.stack:"";return await l.error(`[${n}] \u51FA\u53C2: \u9519\u8BEF: ${e}
40
+ \u5806\u6808: ${r}`),`\u9519\u8BEF: ${e}`}function ht(t){return/^\d+$/.test(t.trim())?String(parseInt(t.trim(),10)):null}async function Qt(t,n){let e=[];for(let r of n){let i=r.endsWith("/")||r.endsWith("\\"),o=nt.isAbsolute(r)?nt.resolve(r):nt.resolve(t,r.replace(/[\\/]$/,""));if(!await P(o)){let c=nt.relative(t,o).replace(/\\/g,"/");e.push(i?c+"/":c)}}return e}function Yt(){return{haimati_read:$({description:`\u4ECE\u6D77\u9A6C\u4F53\u8BFB\u53D6\u8BB0\u5FC6\u3002\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\uFF0C\u81EA\u52A8\u8865\u5168\uFF08\u8F93\u5165'86'\u2192'086'\uFF09\u3002\u652F\u6301\u5355\u6761\u5206\u9875\uFF08offset/limit\uFF09\u548C\u6279\u91CF\u8BFB\u53D6\uFF08\u9017\u53F7\u5206\u9694\u5982'086,087'\uFF0C\u8303\u56F4\u5982'086-090'\uFF09\u3002\u8FD4\u56DE\u4EE5 "===== #N =====" \u5F00\u5934\uFF0C\u884C\u9996 "N|" \u4E3A\u884C\u53F7\u3002`,args:{query:$.schema.string().describe("\u5E8F\u53F7\u3002\u5355\u6761\u5982 '086'\uFF0C\u6279\u91CF\u652F\u6301\u9017\u53F7\u5206\u9694\u5982 '086,087,088' \u6216\u8303\u56F4 '086-090'"),offset:$.schema.number().optional().default(1).describe("\u8D77\u59CB\u884C\u53F7\uFF08\u9ED8\u8BA4 1\uFF0C\u4EC5\u5355\u6761\u8BFB\u53D6\u751F\u6548\uFF09"),limit:$.schema.number().optional().default(2e3).describe("\u6700\u5927\u8BFB\u53D6\u884C\u6570\uFF08\u9ED8\u8BA4 2000\uFF0C\u4EC5\u5355\u6761\u8BFB\u53D6\u751F\u6548\uFF09")},async execute(t,n){let e=k(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=M(e);if(await l.info(`[haimati_read] \u5F00\u59CB\u8BFB\u53D6 #${t.query}`),await l.debug(`[haimati_read] \u5165\u53C2: query="${t.query}", offset=${t.offset??1}, limit=${t.limit??2e3}`),!await P(r)){let i=`\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728\u4E8E ${r}`;return await l.debug(`[haimati_read] \u51FA\u53C2:
41
+ ${i}`),i}try{let i=await D(e),o=t.query.trim(),a=Le(o);if(!a||a.length===0){let s=`\u9519\u8BEF\uFF1A\u65E0\u6548\u7684\u67E5\u8BE2\u683C\u5F0F "${o}"`;return await l.debug(`[haimati_read] \u51FA\u53C2:
42
+ ${s}`),s}if(a.length===1){let s=a[0],f=T(i,s);if(!f)return await l.info(`[haimati_read] \u8BFB\u53D6\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;let m=await _(e,f.id);if(!m)return`\u672A\u627E\u5230\u4E66\u9875: #${f.id.padStart(3,"0")}`;let y=G(f,m,{offset:t.offset??1,limit:t.limit??2e3}),g=`===== #${f.id.padStart(3,"0")} =====
43
+ ${y}`;return await l.debug(`[haimati_read] \u51FA\u53C2:
44
+ ${g}`),await l.info(`[haimati_read] \u8BFB\u53D6\u6210\u529F: #${f.id} (${f.category}/${f.title})`),g}let c=[],u=0;for(let s of a){let f=T(i,s);if(!f){await l.warn(`[haimati_read] \u6279\u91CF: \u672A\u627E\u5230\u8BB0\u5FC6 #${s}`),c.push(`===== #${s.padStart(3,"0")} =====
45
+ \u672A\u627E\u5230\u8BB0\u5FC6: ${s}`);continue}let m=await _(e,f.id);if(!m){await l.error(`[haimati_read] \u6279\u91CF: \u672A\u627E\u5230\u4E66\u9875 #${f.id}`),c.push(`===== #${f.id.padStart(3,"0")} =====
46
+ \u672A\u627E\u5230\u4E66\u9875`);continue}let y=G(f,m);c.push(`===== #${f.id.padStart(3,"0")} =====
47
+ ${y}`),u++}let d=c.join(`
48
+
49
+ `);return await l.info(`[haimati_read] \u6279\u91CF\u8BFB\u53D6\u7ED3\u675F: \u5171 ${a.length} \u6761, \u6210\u529F ${u} \u6761`),d}catch(i){return await C(i,"haimati_read")}}}),haimati_write:$({description:'\u5199\u5165\u65B0\u8BB0\u5FC6\u3002\u81EA\u52A8\u5206\u914D\u5E8F\u53F7\uFF0C\u76F8\u540C\u5206\u7C7B+\u6807\u9898\u4E0D\u53EF\u91CD\u590D\u5199\u5165\uFF08\u9700\u7528 haimati_edit \u66F4\u65B0\uFF09\u3002filePath \u53EF\u9009\uFF1A\u5173\u8054\u9879\u76EE\u6587\u4EF6/\u76EE\u5F55\uFF08\u672B\u5C3E/\u8868\u793A\u76EE\u5F55\uFF0C\u5339\u914D\u8BE5\u76EE\u5F55\u4E0B\u6240\u6709\u6587\u4EF6\uFF09\uFF0C\u540E\u7EED\u8BFB\u53D6\u65F6\u81EA\u52A8\u63D0\u793A\u76F8\u5173\u8BB0\u5FC6\u3002\u652F\u6301\u591A\u8DEF\u5F84\u6570\u7EC4\u5B9E\u73B0\u591A\u5BF9\u591A\u5173\u8054\u3002title \u4E0D\u80FD\u4EE5 " - \u5E8F\u53F7" \u7ED3\u5C3E\u3002',args:{category:$.schema.string().describe("\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0' \u6216 '\u901A\u7528'"),title:$.schema.string().describe("\u8BB0\u5FC6\u6807\u9898\uFF0C\u5982 '\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236'"),content:$.schema.string().describe("\u8981\u5199\u5165\u7684\u8BE6\u7EC6\u5185\u5BB9"),filePath:$.schema.array($.schema.string()).optional().describe("\u5173\u8054\u7684\u9879\u76EE\u6587\u4EF6\u76F8\u5BF9\u8DEF\u5F84\u6570\u7EC4\uFF0C\u5982 ['src/index.ts', 'src/tools.ts']\u3002\u672B\u5C3E\u52A0 / \u8868\u793A\u76EE\u5F55\uFF0C\u5982 'src/' \u4F1A\u5339\u914D\u8BE5\u76EE\u5F55\u4E0B\u6240\u6709\u6587\u4EF6\uFF08\u542B\u5B50\u76EE\u5F55\uFF09\u3002\u4F20\u5165\u540E\u5728 .haimati/memo-map.yaml \u4E2D\u5EFA\u7ACB\u6587\u4EF6\u2192\u8BB0\u5FC6\u7684\u6620\u5C04\u5173\u7CFB\u3002\u6B64\u540E AI \u901A\u8FC7 read \u5DE5\u5177\u8BFB\u53D6\u8BE5\u6587\u4EF6\u6216\u76EE\u5F55\u4E0B\u7684\u6587\u4EF6\u65F6\uFF0C\u4F1A\u81EA\u52A8\u5728\u8F93\u51FA\u4E2D\u6CE8\u5165\u63D0\u793A\uFF1A'{\u6587\u4EF6}\u548C\u6D77\u9A6C\u4F53#N\u6709\u5173\uFF0C\u4F60\u8981\u8BFB\u53D6\u8BB0\u5FC6'")},async execute(t,n){let e=k(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=t.filePath||null;if(r&&r.length>0){let i=await Qt(e,r);if(i.length>0){let o=`\u9519\u8BEF\uFF1A\u4EE5\u4E0B\u6587\u4EF6/\u76EE\u5F55\u4E0D\u5B58\u5728\uFF0C\u8BF7\u786E\u8BA4\u8DEF\u5F84\u540E\u91CD\u8BD5
50
+ ${i.join(`
51
+ `)}`;return await l.debug(`[haimati_write] \u51FA\u53C2: \u8DEF\u5F84\u4E0D\u5B58\u5728
52
+ ${o}`),o}}await l.info(`[haimati_write] \u5F00\u59CB\u5199\u5165 ${t.category}/${t.title}`),await l.debug(`[haimati_write] \u5165\u53C2: category="${t.category}", title="${t.title}", filePath="${r?r.join(", "):"(\u65E0)"}", content=
53
+ ${t.content}`);try{let i=new Date().toLocaleString("zh-CN",{hour12:!1}),o=null;for(let d=0;d<3;d++)try{if(o=await qt(e,t.category,t.title,i,t.content,!1),o)break;await l.warn(`[haimati_write] \u9501\u83B7\u53D6\u5931\u8D25\uFF0C\u91CD\u8BD5\u7B2C ${d+1} \u6B21`)}catch(s){let f=s instanceof Error?s.message:String(s);if(f.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw s;await l.warn(`[haimati_write] \u83B7\u53D6\u9501\u5F02\u5E38: ${f}, \u91CD\u8BD5\u7B2C ${d+1} \u6B21`)}if(o){if(r&&r.length>0){let s=await v(e);for(let f of r){let m=R(e,f);pt(s,m,o),await l.info(`[haimati_write] \u5EFA\u7ACB\u6587\u4EF6\u5173\u8054: ${m} -> #${o}`)}await U(e,s)}let d=`\u5DF2\u5199\u5165\u6D77\u9A6C\u4F53 #${o}
51
54
  \u8DEF\u5F84: ${t.category}/${t.title}
52
- \u7248\u672C: 1`;return await c.debug(`[haimati_write] \u51FA\u53C2:
53
- ${u}`),await c.info(`[haimati_write] \u5199\u5165\u6210\u529F: #${a} (${t.category}/${t.title})`),u}let o=await D(e),l=vt(o,t.category,t.title);if(l){let u=`\u9519\u8BEF\uFF1A\u8BB0\u5FC6\u5DF2\u5B58\u5728 #${l.id} (${t.category}/${t.title})\uFF0C\u5982\u9700\u66F4\u65B0\u8BF7\u4F7F\u7528 haimati_edit \u5DE5\u5177`;return await c.debug(`[haimati_write] \u51FA\u53C2:
54
- ${u}`),u}let f="\u9519\u8BEF\uFF1A\u65E0\u6CD5\u5206\u914D\u5E8F\u53F7\uFF08\u9501\u7B49\u5F85\u8D85\u65F6\uFF09";return await c.debug(`[haimati_write] \u51FA\u53C2:
55
- ${f}`),f}catch(i){return await C(i,"haimati_write")}}}),haimati_search:$({description:'\u641C\u7D22\u8BB0\u5FC6\uFF08\u591A\u5173\u952E\u5B57\u7A7A\u683C\u5206\u9694\uFF09\u3002\u641C\u7D22\u8303\u56F4\uFF1A\u6807\u9898\uFF08\u6743\u91CD\u9AD8\uFF09\u3001\u5206\u7C7B\u3001\u5E8F\u53F7\u3001\u6B63\u6587\u3002match="and" \u9700\u5168\u90E8\u5339\u914D\uFF08\u7CBE\u786E\uFF09\uFF0Cmatch="or" \u4EFB\u610F\u5339\u914D\uFF08\u5E7F\u6CDB\uFF09\u3002\u6309\u5339\u914D\u5EA6\u6392\u5E8F\uFF0C\u7ED3\u679C\u542B\u6458\u8981\uFF0C\u652F\u6301 limit/offset \u5206\u9875\u3002',args:{keyword:$.schema.string().describe("\u641C\u7D22\u5173\u952E\u8BCD\uFF08\u652F\u6301\u591A\u5173\u952E\u5B57\uFF0C\u7528\u7A7A\u683C\u5206\u9694\uFF09"),match:$.schema.string().describe("\u5339\u914D\u6A21\u5F0F\uFF1Aand=\u6240\u6709\u5173\u952E\u5B57\u90FD\u5339\u914D\uFF0Cor=\u4EFB\u610F\u5173\u952E\u5B57\u5339\u914D"),limit:$.schema.number().default(10).describe("\u8FD4\u56DE\u7ED3\u679C\u6570\u91CF\u9650\u5236"),offset:$.schema.number().default(0).describe("\u5206\u9875\u504F\u79FB\u91CF\uFF0C\u7528\u4E8E\u83B7\u53D6\u540E\u7EED\u9875\u9762")},async execute(t,n){let e=v(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=_(e);if(await c.info(`[haimati_search] \u5F00\u59CB\u641C\u7D22 "${t.keyword}"`),await c.debug(`[haimati_search] \u5165\u53C2: keyword="${t.keyword}", match="${t.match}", limit=${t.limit??10}, offset=${t.offset??0}`),!await P(r)){let i="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await c.debug(`[haimati_search] \u51FA\u53C2:
56
- ${i}`),await c.info("[haimati_search] \u641C\u7D22\u5931\u8D25: \u7D22\u5F15\u4E0D\u5B58\u5728"),i}try{let i=await D(e),a=t.keyword.trim(),o=t.match,l=t.limit??10,f=t.offset??0,u=await At(i,a,o,e,!0),s=u.length,d=u.slice(f,f+l);if(d.length===0){let y=`\u672A\u627E\u5230\u5305\u542B '${a}' \u7684\u8BB0\u5FC6`;return await c.debug(`[haimati_search] \u51FA\u53C2:
57
- ${y}`),await c.info("[haimati_search] \u641C\u7D22\u5B8C\u6210: \u672A\u627E\u5230\u5339\u914D"),y}let m=[],h=f+d.length<s,g=h?`${f+1}-${f+d.length}/${s}`:`${f+1}-${f+d.length}/${s}`;m.push(`\u627E\u5230 ${g} \u6761\u5339\u914D\uFF1A
58
- `),h&&m.push(`\uFF08\u5982\u9700\u83B7\u53D6\u66F4\u591A\uFF0C\u8BF7\u4F7F\u7528 offset=${f+l} \u7EE7\u7EED\u7FFB\u9875\uFF09
59
- `);for(let y of d){let w=await M(e,y.id),b=`${y.category}/${y.title}`,x="";w&&(x=w.content.split(`
60
- `).filter(Xt=>Xt.trim()).slice(0,3).join(" | ").substring(0,150),x.length===150&&(x+="...")),m.push(`## ${b} [${y.id}]`),x&&m.push(`> ${x}`),m.push("")}let p=m.join(`
61
- `);return await c.debug(`[haimati_search] \u51FA\u53C2:
62
- ${p}`),await c.info(`[haimati_search] \u641C\u7D22\u5B8C\u6210: \u627E\u5230 ${s} \u6761\u5339\u914D`),p}catch(i){return await C(i,"haimati_search")}}}),haimati_edit:$({description:"\u5B57\u7B26\u4E32\u66FF\u6362\u7F16\u8F91\u8BB0\u5FC6\u3002oldString\u2192newString\uFF08\u533A\u5206\u5927\u5C0F\u5199\uFF09\uFF0CreplaceAll \u53EF\u9009\u5168\u5C40\u66FF\u6362\u3002\u65E7\u6587\u672C\u4E0D\u5339\u914D\u8BF4\u660E\u5185\u5BB9\u5DF2\u88AB\u4FEE\u6539\u9700\u91CD\u8BFB\u3002filePath/removeFilePath \u53EF\u9009\u589E\u51CF\u6587\u4EF6\u5173\u8054\u3002",args:{query:$.schema.string().describe("\u5E8F\u53F7\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u66F4\u65B0\u7684\u8BB0\u5FC6"),oldString:$.schema.string().describe("\u8981\u641C\u7D22\u7684\u65E7\u6587\u672C\uFF08\u533A\u5206\u5927\u5C0F\u5199\uFF09"),newString:$.schema.string().describe("\u66FF\u6362\u540E\u7684\u65B0\u6587\u672C"),replaceAll:$.schema.boolean().optional().describe("\u662F\u5426\u66FF\u6362\u6240\u6709\u5339\u914D\u9879\uFF0C\u9ED8\u8BA4\u4E3A false\uFF08\u53EA\u66FF\u6362\u7B2C\u4E00\u4E2A\uFF09"),filePath:$.schema.string().optional().describe("\u5173\u8054\u7684\u9879\u76EE\u6587\u4EF6\u76F8\u5BF9\u8DEF\u5F84\uFF0C\u5982 'src/index.ts'\u3002\u672B\u5C3E\u52A0 / \u8868\u793A\u76EE\u5F55\uFF0C\u5982 'src/' \u4F1A\u5339\u914D\u8BE5\u76EE\u5F55\u4E0B\u6240\u6709\u6587\u4EF6\uFF08\u542B\u5B50\u76EE\u5F55\uFF09\u3002\u4F20\u5165\u540E\u5728 .haimati/memo-map.yaml \u4E2D\u5EFA\u7ACB\u6587\u4EF6\u2192\u8BB0\u5FC6\u7684\u6620\u5C04\u5173\u7CFB\u3002\u6B64\u540E AI \u901A\u8FC7 read \u5DE5\u5177\u8BFB\u53D6\u8BE5\u6587\u4EF6\u6216\u76EE\u5F55\u4E0B\u7684\u6587\u4EF6\u65F6\uFF0C\u4F1A\u81EA\u52A8\u5728\u8F93\u51FA\u4E2D\u6CE8\u5165\u63D0\u793A\uFF1A'{\u6587\u4EF6}\u548C\u6D77\u9A6C\u4F53#N\u6709\u5173\uFF0C\u5EFA\u8BAE\u8BFB\u53D6\u8BB0\u5FC6'"),removeFilePath:$.schema.string().optional().describe("\u8981\u79FB\u9664\u5173\u8054\u7684\u9879\u76EE\u6587\u4EF6\u76F8\u5BF9\u8DEF\u5F84\uFF0C\u5982 'src/index.ts'\u3002\u4F20\u5165\u540E\u4F1A\u4ECE memo-map.yaml \u4E2D\u79FB\u9664\u8BE5\u6587\u4EF6\u4E0E\u6B64\u8BB0\u5FC6\u7684\u5173\u8054")},async execute(t,n){let e=v(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=_(e),i=t.replaceAll===!0,a=t.filePath?.trim()||null,o=t.removeFilePath?.trim()||null;if(await c.info(`[haimati_edit] \u5F00\u59CB\u7F16\u8F91 #${t.query}`),await c.debug(`[haimati_edit] \u5165\u53C2: query="${t.query}", replaceAll=${i}, filePath="${a||"(\u65E0)"}", removeFilePath="${o||"(\u65E0)"}", oldString="${t.oldString}", newString="${t.newString}"`),!t.oldString)return await c.debug("[haimati_edit] \u51FA\u53C2: oldString\u4E3A\u7A7A"),"\u9519\u8BEF\uFF1AoldString \u4E0D\u80FD\u4E3A\u7A7A";if(!await P(r))return await c.debug("[haimati_edit] \u51FA\u53C2: \u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728"),"\u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728";try{let l=await D(e),f=pt(t.query);if(!f)return"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let u=A(l,f);if(!u)return await c.info("[haimati_edit] \u7F16\u8F91\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6"),`\u672A\u627E\u5230\u4E0E '${t.query}' \u76F8\u5173\u7684\u8BB0\u5FC6`;let s=await M(e,u.id);if(!s)return await c.debug("[haimati_edit] \u51FA\u53C2: \u4E66\u9875\u4E0D\u5B58\u5728"),`\u672A\u627E\u5230\u4E66\u9875: #${u.id.padStart(3,"0")}`;if(!s.content.includes(t.oldString))return await c.debug("[haimati_edit] \u51FA\u53C2: \u672A\u627E\u5230\u5339\u914D\u6587\u672C"),`\u9519\u8BEF\uFF1A\u5728\u8BB0\u5FC6 #${u.id.padStart(3,"0")} \u4E2D\u672A\u627E\u5230\u5339\u914D\u7684\u6587\u672C\uFF0C\u5185\u5BB9\u53EF\u80FD\u5DF2\u88AB\u5176\u4ED6\u4FEE\u6539\u53D8\u66F4\uFF0C\u8BF7\u91CD\u65B0\u8BFB\u53D6\u540E\u91CD\u8BD5`;let d=i?s.content.replaceAll(t.oldString,t.newString):s.content.replace(t.oldString,t.newString);if(await j(e,u.id,u.title,s.createdAt,d),a){let g=await k(e),p=W(e,a);gt(g,p,u.id),await R(e,g),await c.info(`[haimati_edit] \u5EFA\u7ACB\u6587\u4EF6\u5173\u8054: ${p} -> #${u.id}`)}if(o){let g=await k(e),p=W(e,o);zt(g,p,u.id),await R(e,g),await c.info(`[haimati_edit] \u79FB\u9664\u6587\u4EF6\u5173\u8054: ${p} x #${u.id}`)}let m=`${u.category}/${u.title}`,h=`\u5DF2\u66F4\u65B0\u6D77\u9A6C\u4F53 #${u.id.padStart(3,"0")}
63
- \u8DEF\u5F84: ${m}`;return await c.debug(`[haimati_edit] \u51FA\u53C2:
64
- ${h}`),await c.info(`[haimati_edit] \u7F16\u8F91\u6210\u529F: #${u.id.padStart(3,"0")}`),h}catch(l){return await C(l,"haimati_edit")}}}),haimati_delete:$({description:"\u5220\u9664\u8BB0\u5FC6\uFF0C\u4E0D\u53EF\u9006\u3002\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\uFF0C\u81EA\u52A8\u8865\u5168\u3002\u5220\u9664\u540E\u5E8F\u53F7\u4E0D\u590D\u7528\uFF0C\u540C\u65F6\u6E05\u7406 memo-map \u4E2D\u7684\u6587\u4EF6\u5173\u8054\u3002\u5EFA\u8BAE\u5148 haimati_read \u786E\u8BA4\u5185\u5BB9\u3002",args:{query:$.schema.string().describe("\u5E8F\u53F7\u3002\u4F8B\u5982\uFF1A'086'")},async execute(t,n){let e=v(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=_(e);if(await c.info(`[haimati_delete] \u5F00\u59CB\u5220\u9664 #${t.query}`),await c.debug(`[haimati_delete] \u5165\u53C2: query="${t.query}"`),!await P(r)){let i="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await c.debug(`[haimati_delete] \u51FA\u53C2:
65
- ${i}`),i}try{let i=await D(e),a=pt(t.query);if(!a)return"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let o=A(i,a);if(!o)return await c.info(`[haimati_delete] \u5220\u9664\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;await Tt(e,o.id);let l=Ct(i,o.id);await q(e,l);let f=await k(e);Gt(f,o.id),await R(e,f),await c.info(`[haimati_delete] \u6E05\u7406\u6587\u4EF6\u5173\u8054: #${o.id}`);let u=`${o.category}/${o.title}`,s=`\u5DF2\u5220\u9664\u6D77\u9A6C\u4F53 #${o.id.padStart(3,"0")}
66
- \u8DEF\u5F84: ${u}`;return await c.debug(`[haimati_delete] \u51FA\u53C2:
67
- ${s}`),await c.info(`[haimati_delete] \u5220\u9664\u6210\u529F: #${o.id.padStart(3,"0")} (${u})`),s}catch(i){return await C(i,"haimati_delete")}}}),haimati_move:$({description:"\u4FEE\u6539\u8BB0\u5FC6\u7684\u5206\u7C7B\u548C/\u6216\u6807\u9898\u3002\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\uFF0CnewCategory/newTitle \u81F3\u5C11\u63D0\u4F9B\u4E00\u4E2A\u3002\u5E8F\u53F7\u548C\u5185\u5BB9\u4E0D\u53D8\u3002",args:{query:$.schema.string().describe("\u5E8F\u53F7\u3002\u4F8B\u5982\uFF1A'086'"),newCategory:$.schema.string().optional().describe("\u65B0\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u5BA2\u6237\u7AEF' \u6216 '\u901A\u7528'"),newTitle:$.schema.string().optional().describe("\u65B0\u7684\u6807\u9898\uFF0C\u5982 '\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236v2'")},async execute(t,n){let e=v(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=_(e);if(await c.info(`[haimati_move] \u5F00\u59CB\u79FB\u52A8 ${t.query}`),await c.debug(`[haimati_move] \u5165\u53C2: query="${t.query}", newCategory="${t.newCategory}", newTitle="${t.newTitle}"`),!await P(r)){let i="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await c.debug(`[haimati_move] \u51FA\u53C2:
68
- ${i}`),i}try{let i=await D(e),a=pt(t.query);if(!a)return"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let o=A(i,a);if(!o)return await c.info(`[haimati_move] \u79FB\u52A8\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;let l=t.newCategory?.trim(),f=t.newTitle?.trim();if(f&&/ - \d{3}$/.test(f)){let w='\u9519\u8BEF\uFF1A\u6807\u9898\u4E0D\u80FD\u4EE5 " - \u5E8F\u53F7" \u683C\u5F0F\u7ED3\u5C3E\uFF0C\u5E8F\u53F7\u7531\u7CFB\u7EDF\u81EA\u52A8\u5206\u914D\uFF0C\u8BF7\u4FEE\u6539\u6807\u9898';return await c.debug(`[haimati_move] \u51FA\u53C2:
69
- ${w}`),w}if(!l&&!f){let w="\u9519\u8BEF\uFF1A\u81F3\u5C11\u9700\u8981\u63D0\u4F9B newCategory \u6216 newTitle \u4E2D\u7684\u4E00\u4E2A";return await c.debug(`[haimati_move] \u51FA\u53C2:
70
- ${w}`),w}let u=o.category,s=o.title,d=l||u,m=f||s,h=`${u}/${s}`,g=`${d}/${m}`,p=i.map(w=>w.id===o.id?{...w,category:d,title:m}:w);if(await q(e,p),f){let w=await M(e,o.id);w&&await j(e,o.id,m,w.createdAt,w.content)}let y=`\u5DF2\u79FB\u52A8\u6D77\u9A6C\u4F53 #${o.id}
71
- \u65E7\u8DEF\u5F84: ${h}
72
- \u65B0\u8DEF\u5F84: ${g}`;return await c.debug(`[haimati_move] \u51FA\u53C2:
73
- ${y}`),await c.info(`[haimati_move] \u79FB\u52A8\u6210\u529F: #${o.id} ${h} -> ${g}`),y}catch(i){return await C(i,"haimati_move")}}}),haimati_list:$({description:"\u5217\u51FA\u6D77\u9A6C\u4F53\u7D22\u5F15\u3002\u65E0\u53C2\u6570\uFF1A\u5B8C\u6574\u6811\u5F62\u7ED3\u6784\uFF1Bcategory\uFF1A\u6307\u5B9A\u5206\u7C7B\uFF1Brecursive=true\uFF1A\u9012\u5F52\u5B50\u5206\u7C7B\uFF1Bdetail=true\uFF1A\u540C\u65F6\u663E\u793A\u6B63\u6587\u3002\u5EFA\u8BAE\u5DE5\u4F5C\u4E2D\u5148 list/search \u6D4F\u89C8\u5DF2\u6709\u8BB0\u5FC6\u3002",args:{category:$.schema.string().optional().describe("\u53EF\u9009\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5217\u51FA\u8BE5\u5206\u7C7B\u4E0B\u7684\u6761\u76EE"),recursive:$.schema.boolean().optional().default(!1).describe("\u662F\u5426\u9012\u5F52\u904D\u5386\u5B50\u5206\u7C7B\uFF0C\u9ED8\u8BA4false"),detail:$.schema.boolean().optional().default(!1).describe("\u662F\u5426\u663E\u793A\u8BB0\u5FC6\u7684\u8BE6\u7EC6\u5185\u5BB9\uFF0C\u9ED8\u8BA4false")},async execute(t,n){let e=v(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=_(e);if(await c.info(`[haimati_list] \u5F00\u59CB\u5217\u51FA${t.category?` ${t.category}`:" \u5168\u90E8"}${t.detail?" (\u8BE6\u7EC6\u6A21\u5F0F)":""}`),await c.debug(`[haimati_list] \u5165\u53C2: category="${t.category||"(\u65E0)"}, recursive=${t.recursive}, detail=${t.detail}`),!await P(r)){let i="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await c.debug(`[haimati_list] \u51FA\u53C2:
74
- ${i}`),i}try{let i=await D(e);if(t.category){let f=(await Lt(e)).split(`
75
- `),u=0,s=[];for(let g of f){if(!g.trim())continue;let p=V(g);if(g.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/))continue;let w=X(g);if(w&&(w==="/"?s[p]="":s[p]=w,s=s.slice(0,p+1),s.filter(Boolean).join("/")===t.category)){u=p;break}}let d=[],m=[];s=[];for(let g of f){if(!g.trim())continue;let p=V(g),y=g.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(y){let b=y[1].trim(),x=y[2];if(p===u+1){let F=s.slice(1,p).filter(Boolean).join("/");F===t.category&&m.push({category:F,title:b,id:x})}continue}let w=X(g);w&&(w==="/"?s[p]="":s[p]=w,s=s.slice(0,p+1),p===u+1&&s.filter(Boolean).join("/")===t.category&&d.push(w))}let h=`## ${t.category}
76
-
77
- `;if(t.recursive){let g=i.filter(y=>y.category===t.category||y.category.startsWith(t.category+"/")),p=new Map;for(let y of g){let b=y.category.slice(t.category.length+1).split("/")[0]||"(\u76F4\u63A5)";p.has(b)||p.set(b,[]),p.get(b).push(y)}for(let[y,w]of p)h+=`### ${y}/
78
- `,h+=w.map(b=>`- ${b.title} - ${b.id.padStart(3,"0")}`).join(`
55
+ \u7248\u672C: 1`;return await l.debug(`[haimati_write] \u51FA\u53C2:
56
+ ${d}`),await l.info(`[haimati_write] \u5199\u5165\u6210\u529F: #${o} (${t.category}/${t.title})`),d}let a=await D(e),c=Ct(a,t.category,t.title);if(c){let d=`\u9519\u8BEF\uFF1A\u8BB0\u5FC6\u5DF2\u5B58\u5728 #${c.id} (${t.category}/${t.title})\uFF0C\u5982\u9700\u66F4\u65B0\u8BF7\u4F7F\u7528 haimati_edit \u5DE5\u5177`;return await l.debug(`[haimati_write] \u51FA\u53C2:
57
+ ${d}`),d}let u="\u9519\u8BEF\uFF1A\u65E0\u6CD5\u5206\u914D\u5E8F\u53F7\uFF08\u9501\u7B49\u5F85\u8D85\u65F6\uFF09";return await l.debug(`[haimati_write] \u51FA\u53C2:
58
+ ${u}`),u}catch(i){return await C(i,"haimati_write")}}}),haimati_search:$({description:'\u641C\u7D22\u8BB0\u5FC6\uFF08\u591A\u5173\u952E\u5B57\u7A7A\u683C\u5206\u9694\uFF09\u3002\u641C\u7D22\u8303\u56F4\uFF1A\u6807\u9898\uFF08\u6743\u91CD\u9AD8\uFF09\u3001\u5206\u7C7B\u3001\u5E8F\u53F7\u3001\u6B63\u6587\u3002match="and" \u9700\u5168\u90E8\u5339\u914D\uFF08\u7CBE\u786E\uFF09\uFF0Cmatch="or" \u4EFB\u610F\u5339\u914D\uFF08\u5E7F\u6CDB\uFF09\u3002\u6309\u5339\u914D\u5EA6\u6392\u5E8F\uFF0C\u7ED3\u679C\u542B\u6458\u8981\uFF0C\u652F\u6301 limit/offset \u5206\u9875\u3002',args:{keyword:$.schema.string().describe("\u641C\u7D22\u5173\u952E\u8BCD\uFF08\u652F\u6301\u591A\u5173\u952E\u5B57\uFF0C\u7528\u7A7A\u683C\u5206\u9694\uFF09"),match:$.schema.string().describe("\u5339\u914D\u6A21\u5F0F\uFF1Aand=\u6240\u6709\u5173\u952E\u5B57\u90FD\u5339\u914D\uFF0Cor=\u4EFB\u610F\u5173\u952E\u5B57\u5339\u914D"),limit:$.schema.number().default(10).describe("\u8FD4\u56DE\u7ED3\u679C\u6570\u91CF\u9650\u5236"),offset:$.schema.number().default(0).describe("\u5206\u9875\u504F\u79FB\u91CF\uFF0C\u7528\u4E8E\u83B7\u53D6\u540E\u7EED\u9875\u9762")},async execute(t,n){let e=k(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=M(e);if(await l.info(`[haimati_search] \u5F00\u59CB\u641C\u7D22 "${t.keyword}"`),await l.debug(`[haimati_search] \u5165\u53C2: keyword="${t.keyword}", match="${t.match}", limit=${t.limit??10}, offset=${t.offset??0}`),!await P(r)){let i="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await l.debug(`[haimati_search] \u51FA\u53C2:
59
+ ${i}`),await l.info("[haimati_search] \u641C\u7D22\u5931\u8D25: \u7D22\u5F15\u4E0D\u5B58\u5728"),i}try{let i=await D(e),o=t.keyword.trim(),a=t.match,c=t.limit??10,u=t.offset??0,d=await jt(i,o,a,e,!0),s=d.length,f=d.slice(u,u+c);if(f.length===0){let h=`\u672A\u627E\u5230\u5305\u542B '${o}' \u7684\u8BB0\u5FC6`;return await l.debug(`[haimati_search] \u51FA\u53C2:
60
+ ${h}`),await l.info("[haimati_search] \u641C\u7D22\u5B8C\u6210: \u672A\u627E\u5230\u5339\u914D"),h}let m=[],y=u+f.length<s,g=y?`${u+1}-${u+f.length}/${s}`:`${u+1}-${u+f.length}/${s}`;m.push(`\u627E\u5230 ${g} \u6761\u5339\u914D\uFF1A
61
+ `),y&&m.push(`\uFF08\u5982\u9700\u83B7\u53D6\u66F4\u591A\uFF0C\u8BF7\u4F7F\u7528 offset=${u+c} \u7EE7\u7EED\u7FFB\u9875\uFF09
62
+ `);for(let h of f){let w=await _(e,h.id),b=`${h.category}/${h.title}`,x="";w&&(x=w.content.split(`
63
+ `).filter(te=>te.trim()).slice(0,3).join(" | ").substring(0,150),x.length===150&&(x+="...")),m.push(`## ${b} [${h.id}]`),x&&m.push(`> ${x}`),m.push("")}let p=m.join(`
64
+ `);return await l.debug(`[haimati_search] \u51FA\u53C2:
65
+ ${p}`),await l.info(`[haimati_search] \u641C\u7D22\u5B8C\u6210: \u627E\u5230 ${s} \u6761\u5339\u914D`),p}catch(i){return await C(i,"haimati_search")}}}),haimati_edit:$({description:"\u7F16\u8F91\u8BB0\u5FC6\u3002\u652F\u6301\u4E09\u79CD\u6A21\u5F0F\uFF1A1) \u5185\u5BB9\u66FF\u6362\uFF1AoldString\u2192newString\uFF08\u533A\u5206\u5927\u5C0F\u5199\uFF09\uFF0CreplaceAll \u53EF\u9009\u5168\u5C40\u66FF\u6362\uFF1B2) \u5173\u8054\u53D8\u66F4\uFF1AfilePath/removeFilePath \u6570\u7EC4\u589E\u51CF\u6587\u4EF6\u5173\u8054\uFF1B3) \u540C\u65F6\u6267\u884C\u4E24\u8005\u3002oldString \u548C newString \u5FC5\u987B\u540C\u65F6\u5B58\u5728\u624D\u6267\u884C\u5185\u5BB9\u66FF\u6362\u3002\u81F3\u5C11\u9700\u8981\u63D0\u4F9B\u5185\u5BB9\u66FF\u6362\u6216\u5173\u8054\u53D8\u66F4\u4E4B\u4E00\u3002",args:{query:$.schema.string().describe("\u5E8F\u53F7\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u66F4\u65B0\u7684\u8BB0\u5FC6"),oldString:$.schema.string().optional().describe("\u8981\u641C\u7D22\u7684\u65E7\u6587\u672C\uFF08\u533A\u5206\u5927\u5C0F\u5199\uFF09\uFF0C\u4E0E newString \u540C\u65F6\u5B58\u5728\u65F6\u624D\u6267\u884C\u5185\u5BB9\u66FF\u6362"),newString:$.schema.string().optional().describe("\u66FF\u6362\u540E\u7684\u65B0\u6587\u672C\uFF0C\u4E0E oldString \u540C\u65F6\u5B58\u5728\u65F6\u624D\u6267\u884C\u5185\u5BB9\u66FF\u6362"),replaceAll:$.schema.boolean().optional().describe("\u662F\u5426\u66FF\u6362\u6240\u6709\u5339\u914D\u9879\uFF0C\u9ED8\u8BA4\u4E3A false\uFF08\u53EA\u66FF\u6362\u7B2C\u4E00\u4E2A\uFF09"),filePath:$.schema.array($.schema.string()).optional().describe("\u5173\u8054\u7684\u9879\u76EE\u6587\u4EF6\u76F8\u5BF9\u8DEF\u5F84\u6570\u7EC4\uFF0C\u5982 ['src/index.ts', 'src/tools.ts']\u3002\u672B\u5C3E\u52A0 / \u8868\u793A\u76EE\u5F55\uFF0C\u5982 'src/' \u4F1A\u5339\u914D\u8BE5\u76EE\u5F55\u4E0B\u6240\u6709\u6587\u4EF6\uFF08\u542B\u5B50\u76EE\u5F55\uFF09\u3002\u4F20\u5165\u540E\u5728 .haimati/memo-map.yaml \u4E2D\u5EFA\u7ACB\u6587\u4EF6\u2192\u8BB0\u5FC6\u7684\u6620\u5C04\u5173\u7CFB\u3002\u6B64\u540E AI \u901A\u8FC7 read \u5DE5\u5177\u8BFB\u53D6\u8BE5\u6587\u4EF6\u6216\u76EE\u5F55\u4E0B\u7684\u6587\u4EF6\u65F6\uFF0C\u4F1A\u81EA\u52A8\u5728\u8F93\u51FA\u4E2D\u6CE8\u5165\u63D0\u793A\uFF1A'{\u6587\u4EF6}\u548C\u6D77\u9A6C\u4F53#N\u6709\u5173\uFF0C\u4F60\u8981\u8BFB\u53D6\u8BB0\u5FC6'"),removeFilePath:$.schema.array($.schema.string()).optional().describe("\u8981\u79FB\u9664\u5173\u8054\u7684\u9879\u76EE\u6587\u4EF6\u76F8\u5BF9\u8DEF\u5F84\u6570\u7EC4\uFF0C\u5982 ['src/index.ts', 'src/tools.ts']\u3002\u4F20\u5165\u540E\u4F1A\u4ECE memo-map.yaml \u4E2D\u79FB\u9664\u8BE5\u6587\u4EF6\u4E0E\u6B64\u8BB0\u5FC6\u7684\u5173\u8054")},async execute(t,n){let e=k(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=M(e),i=t.replaceAll===!0,o=t.filePath||null,a=t.removeFilePath||null,c=!!t.oldString&&!!t.newString,u=o&&o.length>0||a&&a.length>0;if(!c&&!u)return await l.debug("[haimati_edit] \u51FA\u53C2: \u672A\u63D0\u4F9B\u4EFB\u4F55\u7F16\u8F91\u64CD\u4F5C"),"\u9519\u8BEF\uFF1A\u81F3\u5C11\u9700\u8981\u63D0\u4F9B\u5185\u5BB9\u66FF\u6362\uFF08oldString+newString\uFF09\u6216\u6587\u4EF6\u5173\u8054\u53D8\u66F4\uFF08filePath/removeFilePath\uFF09";if(c&&i!==!0&&!t.oldString)return"\u9519\u8BEF\uFF1AoldString \u4E0D\u80FD\u4E3A\u7A7A";if(o&&o.length>0){let d=await Qt(e,o);if(d.length>0){let s=`\u9519\u8BEF\uFF1A\u4EE5\u4E0B\u6587\u4EF6/\u76EE\u5F55\u4E0D\u5B58\u5728\uFF0C\u8BF7\u786E\u8BA4\u8DEF\u5F84\u540E\u91CD\u8BD5
66
+ ${d.join(`
67
+ `)}`;return await l.debug(`[haimati_edit] \u51FA\u53C2: \u8DEF\u5F84\u4E0D\u5B58\u5728
68
+ ${s}`),s}}if(await l.info(`[haimati_edit] \u5F00\u59CB\u7F16\u8F91 #${t.query}`),await l.debug(`[haimati_edit] \u5165\u53C2: query="${t.query}", replaceAll=${i}, filePath="${o?o.join(", "):"(\u65E0)"}", removeFilePath="${a?a.join(", "):"(\u65E0)"}", oldString="${t.oldString||"(\u65E0)"}", newString="${t.newString||"(\u65E0)"}"`),!await P(r))return await l.debug("[haimati_edit] \u51FA\u53C2: \u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728"),"\u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728";try{let d=await D(e),s=ht(t.query);if(!s)return"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let f=T(d,s);if(!f)return await l.info("[haimati_edit] \u7F16\u8F91\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6"),`\u672A\u627E\u5230\u4E0E '${t.query}' \u76F8\u5173\u7684\u8BB0\u5FC6`;if(c){let g=await _(e,f.id);if(!g)return await l.debug("[haimati_edit] \u51FA\u53C2: \u4E66\u9875\u4E0D\u5B58\u5728"),`\u672A\u627E\u5230\u4E66\u9875: #${f.id.padStart(3,"0")}`;if(!g.content.includes(t.oldString))return await l.debug("[haimati_edit] \u51FA\u53C2: \u672A\u627E\u5230\u5339\u914D\u6587\u672C"),`\u9519\u8BEF\uFF1A\u5728\u8BB0\u5FC6 #${f.id.padStart(3,"0")} \u4E2D\u672A\u627E\u5230\u5339\u914D\u7684\u6587\u672C\uFF0C\u5185\u5BB9\u53EF\u80FD\u5DF2\u88AB\u5176\u4ED6\u4FEE\u6539\u53D8\u66F4\uFF0C\u8BF7\u91CD\u65B0\u8BFB\u53D6\u540E\u91CD\u8BD5`;let p=i?g.content.replaceAll(t.oldString,t.newString):g.content.replace(t.oldString,t.newString),h=new Date().toLocaleString("zh-CN",{hour12:!1});await j(e,f.id,f.title,g.createdAt,h,p)}if(u){let g=await v(e);if(o&&o.length>0)for(let p of o){let h=R(e,p);pt(g,h,f.id),await l.info(`[haimati_edit] \u5EFA\u7ACB\u6587\u4EF6\u5173\u8054: ${h} -> #${f.id}`)}if(a&&a.length>0)for(let p of a){let h=R(e,p);Jt(g,h,f.id),await l.info(`[haimati_edit] \u79FB\u9664\u6587\u4EF6\u5173\u8054: ${h} x #${f.id}`)}await U(e,g)}let m=`${f.category}/${f.title}`,y=`\u5DF2\u66F4\u65B0\u6D77\u9A6C\u4F53 #${f.id.padStart(3,"0")}
69
+ \u8DEF\u5F84: ${m}`;return await l.debug(`[haimati_edit] \u51FA\u53C2:
70
+ ${y}`),await l.info(`[haimati_edit] \u7F16\u8F91\u6210\u529F: #${f.id.padStart(3,"0")}`),y}catch(d){return await C(d,"haimati_edit")}}}),haimati_delete:$({description:"\u5220\u9664\u8BB0\u5FC6\uFF0C\u4E0D\u53EF\u9006\u3002\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\uFF0C\u81EA\u52A8\u8865\u5168\u3002\u5220\u9664\u540E\u5E8F\u53F7\u4E0D\u590D\u7528\uFF0C\u540C\u65F6\u6E05\u7406 memo-map \u4E2D\u7684\u6587\u4EF6\u5173\u8054\u3002\u5EFA\u8BAE\u5148 haimati_read \u786E\u8BA4\u5185\u5BB9\u3002",args:{query:$.schema.string().describe("\u5E8F\u53F7\u3002\u4F8B\u5982\uFF1A'086'")},async execute(t,n){let e=k(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=M(e);if(await l.info(`[haimati_delete] \u5F00\u59CB\u5220\u9664 #${t.query}`),await l.debug(`[haimati_delete] \u5165\u53C2: query="${t.query}"`),!await P(r)){let i="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await l.debug(`[haimati_delete] \u51FA\u53C2:
71
+ ${i}`),i}try{let i=await D(e),o=ht(t.query);if(!o)return"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let a=T(i,o);if(!a)return await l.info(`[haimati_delete] \u5220\u9664\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;await Tt(e,a.id);let c=Lt(i,a.id);await O(e,c);let u=await v(e);zt(u,a.id),await U(e,u),await l.info(`[haimati_delete] \u6E05\u7406\u6587\u4EF6\u5173\u8054: #${a.id}`);let d=`${a.category}/${a.title}`,s=`\u5DF2\u5220\u9664\u6D77\u9A6C\u4F53 #${a.id.padStart(3,"0")}
72
+ \u8DEF\u5F84: ${d}`;return await l.debug(`[haimati_delete] \u51FA\u53C2:
73
+ ${s}`),await l.info(`[haimati_delete] \u5220\u9664\u6210\u529F: #${a.id.padStart(3,"0")} (${d})`),s}catch(i){return await C(i,"haimati_delete")}}}),haimati_move:$({description:"\u4FEE\u6539\u8BB0\u5FC6\u7684\u5206\u7C7B\u548C/\u6216\u6807\u9898\u3002\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\uFF0CnewCategory/newTitle \u81F3\u5C11\u63D0\u4F9B\u4E00\u4E2A\u3002\u5E8F\u53F7\u548C\u5185\u5BB9\u4E0D\u53D8\u3002",args:{query:$.schema.string().describe("\u5E8F\u53F7\u3002\u4F8B\u5982\uFF1A'086'"),newCategory:$.schema.string().optional().describe("\u65B0\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u5BA2\u6237\u7AEF' \u6216 '\u901A\u7528'"),newTitle:$.schema.string().optional().describe("\u65B0\u7684\u6807\u9898\uFF0C\u5982 '\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236v2'")},async execute(t,n){let e=k(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=M(e);if(await l.info(`[haimati_move] \u5F00\u59CB\u79FB\u52A8 ${t.query}`),await l.debug(`[haimati_move] \u5165\u53C2: query="${t.query}", newCategory="${t.newCategory}", newTitle="${t.newTitle}"`),!await P(r)){let i="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await l.debug(`[haimati_move] \u51FA\u53C2:
74
+ ${i}`),i}try{let i=await D(e),o=ht(t.query);if(!o)return"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let a=T(i,o);if(!a)return await l.info(`[haimati_move] \u79FB\u52A8\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;let c=t.newCategory?.trim(),u=t.newTitle?.trim();if(u&&/ - \d{3}$/.test(u)){let w='\u9519\u8BEF\uFF1A\u6807\u9898\u4E0D\u80FD\u4EE5 " - \u5E8F\u53F7" \u683C\u5F0F\u7ED3\u5C3E\uFF0C\u5E8F\u53F7\u7531\u7CFB\u7EDF\u81EA\u52A8\u5206\u914D\uFF0C\u8BF7\u4FEE\u6539\u6807\u9898';return await l.debug(`[haimati_move] \u51FA\u53C2:
75
+ ${w}`),w}if(!c&&!u){let w="\u9519\u8BEF\uFF1A\u81F3\u5C11\u9700\u8981\u63D0\u4F9B newCategory \u6216 newTitle \u4E2D\u7684\u4E00\u4E2A";return await l.debug(`[haimati_move] \u51FA\u53C2:
76
+ ${w}`),w}let d=a.category,s=a.title,f=c||d,m=u||s,y=`${d}/${s}`,g=`${f}/${m}`,p=i.map(w=>w.id===a.id?{...w,category:f,title:m}:w);if(await O(e,p),u){let w=await _(e,a.id);if(w){let b=new Date().toLocaleString("zh-CN",{hour12:!1});await j(e,a.id,m,w.createdAt,b,w.content)}}let h=`\u5DF2\u79FB\u52A8\u6D77\u9A6C\u4F53 #${a.id}
77
+ \u65E7\u8DEF\u5F84: ${y}
78
+ \u65B0\u8DEF\u5F84: ${g}`;return await l.debug(`[haimati_move] \u51FA\u53C2:
79
+ ${h}`),await l.info(`[haimati_move] \u79FB\u52A8\u6210\u529F: #${a.id} ${y} -> ${g}`),h}catch(i){return await C(i,"haimati_move")}}}),haimati_list:$({description:"\u5217\u51FA\u6D77\u9A6C\u4F53\u7D22\u5F15\u3002\u65E0\u53C2\u6570\uFF1A\u5B8C\u6574\u6811\u5F62\u7ED3\u6784\uFF1Bcategory\uFF1A\u6307\u5B9A\u5206\u7C7B\uFF1Brecursive=true\uFF1A\u9012\u5F52\u5B50\u5206\u7C7B\uFF1Bdetail=true\uFF1A\u540C\u65F6\u663E\u793A\u6B63\u6587\u3002\u5EFA\u8BAE\u5DE5\u4F5C\u4E2D\u5148 list/search \u6D4F\u89C8\u5DF2\u6709\u8BB0\u5FC6\u3002",args:{category:$.schema.string().optional().describe("\u53EF\u9009\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5217\u51FA\u8BE5\u5206\u7C7B\u4E0B\u7684\u6761\u76EE"),recursive:$.schema.boolean().optional().default(!1).describe("\u662F\u5426\u9012\u5F52\u904D\u5386\u5B50\u5206\u7C7B\uFF0C\u9ED8\u8BA4false"),detail:$.schema.boolean().optional().default(!1).describe("\u662F\u5426\u663E\u793A\u8BB0\u5FC6\u7684\u8BE6\u7EC6\u5185\u5BB9\uFF0C\u9ED8\u8BA4false")},async execute(t,n){let e=k(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=M(e);if(await l.info(`[haimati_list] \u5F00\u59CB\u5217\u51FA${t.category?` ${t.category}`:" \u5168\u90E8"}${t.detail?" (\u8BE6\u7EC6\u6A21\u5F0F)":""}`),await l.debug(`[haimati_list] \u5165\u53C2: category="${t.category||"(\u65E0)"}, recursive=${t.recursive}, detail=${t.detail}`),!await P(r)){let i="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await l.debug(`[haimati_list] \u51FA\u53C2:
80
+ ${i}`),i}try{let i=await D(e);if(t.category){let u=(await At(e)).split(`
81
+ `),d=0,s=[];for(let g of u){if(!g.trim())continue;let p=X(g);if(g.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/))continue;let w=Z(g);if(w&&(w==="/"?s[p]="":s[p]=w,s=s.slice(0,p+1),s.filter(Boolean).join("/")===t.category)){d=p;break}}let f=[],m=[];s=[];for(let g of u){if(!g.trim())continue;let p=X(g),h=g.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(h){let b=h[1].trim(),x=h[2];if(p===d+1){let A=s.slice(1,p).filter(Boolean).join("/");A===t.category&&m.push({category:A,title:b,id:x})}continue}let w=Z(g);w&&(w==="/"?s[p]="":s[p]=w,s=s.slice(0,p+1),p===d+1&&s.filter(Boolean).join("/")===t.category&&f.push(w))}let y=`## ${t.category}
82
+
83
+ `;if(t.recursive){let g=i.filter(h=>h.category===t.category||h.category.startsWith(t.category+"/")),p=new Map;for(let h of g){let b=h.category.slice(t.category.length+1).split("/")[0]||"(\u76F4\u63A5)";p.has(b)||p.set(b,[]),p.get(b).push(h)}for(let[h,w]of p)y+=`### ${h}/
84
+ `,y+=w.map(b=>`- ${b.title} - ${b.id.padStart(3,"0")}`).join(`
79
85
  `)+`
80
86
 
81
- `}else d.length>0&&(h+=`**\u5B50\u5206\u7C7B\uFF1A**
82
- `+d.map(g=>`- ${g}/`).join(`
87
+ `}else f.length>0&&(y+=`**\u5B50\u5206\u7C7B\uFF1A**
88
+ `+f.map(g=>`- ${g}/`).join(`
83
89
  `)+`
84
90
 
85
- `),m.length>0&&(h+=`**\u76F4\u63A5\u6761\u76EE\uFF1A**
91
+ `),m.length>0&&(y+=`**\u76F4\u63A5\u6761\u76EE\uFF1A**
86
92
  `+m.map(g=>`- ${g.title} - ${g.id.padStart(3,"0")}`).join(`
87
93
  `));if(t.detail){let g=t.recursive?i.filter(p=>p.category===t.category||p.category.startsWith(t.category+"/")):i.filter(p=>p.category===t.category);if(g.length>0)if(t.recursive){let p=`## ${t.category}
88
94
 
89
- `,y=new Map;for(let w of g){let b=w.category.slice(t.category.length+1).split("/")[0]||"(\u76F4\u63A5)";y.has(b)||y.set(b,[]),y.get(b).push(w)}for(let[w,b]of y){p+=`### ${w}/
90
- `;for(let x of b){let F=await M(e,x.id);if(!F){p+=`- ${x.title} - ${x.id.padStart(3,"0")} (\u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728)
95
+ `,h=new Map;for(let w of g){let b=w.category.slice(t.category.length+1).split("/")[0]||"(\u76F4\u63A5)";h.has(b)||h.set(b,[]),h.get(b).push(w)}for(let[w,b]of h){p+=`### ${w}/
96
+ `;for(let x of b){let A=await _(e,x.id);if(!A){p+=`- ${x.title} - ${x.id.padStart(3,"0")} (\u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728)
91
97
 
92
98
  `;continue}p+=`#### ${x.title} - ${x.id.padStart(3,"0")}
93
- `,p+=U(x,F)+`
99
+ `,p+=G(x,A)+`
94
100
 
95
- `}}h=p}else{h+=`
101
+ `}}y=p}else{y+=`
96
102
  **\u8BE6\u7EC6\u5185\u5BB9\uFF1A**
97
103
 
98
- `;for(let p of g){let y=await M(e,p.id);if(!y){h+=`- ${p.title} - ${p.id.padStart(3,"0")} (\u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728)
104
+ `;for(let p of g){let h=await _(e,p.id);if(!h){y+=`- ${p.title} - ${p.id.padStart(3,"0")} (\u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728)
99
105
 
100
- `;continue}h+=`#### ${p.title} - ${p.id.padStart(3,"0")}
101
- `,h+=U(p,y)+`
106
+ `;continue}y+=`#### ${p.title} - ${p.id.padStart(3,"0")}
107
+ `,y+=G(p,h)+`
102
108
 
103
- `}}}return await c.debug(`[haimati_list] \u51FA\u53C2:
104
- ${h}`),await c.info(`[haimati_list] \u5217\u51FA\u6210\u529F: ${t.category}${t.detail?" (\u8BE6\u7EC6\u6A21\u5F0F)":""}`),h}if(t.detail){let l=`## \u6D77\u9A6C\u4F53\u7D22\u5F15\u8BE6\u60C5
109
+ `}}}return await l.debug(`[haimati_list] \u51FA\u53C2:
110
+ ${y}`),await l.info(`[haimati_list] \u5217\u51FA\u6210\u529F: ${t.category}${t.detail?" (\u8BE6\u7EC6\u6A21\u5F0F)":""}`),y}if(t.detail){let c=`## \u6D77\u9A6C\u4F53\u7D22\u5F15\u8BE6\u60C5
105
111
 
106
- `,f=new Map;for(let s of i){let d=s.category.split("/")[0]||"(\u65E0\u5206\u7C7B)";f.has(d)||f.set(d,[]),f.get(d).push(s)}for(let[s,d]of f){l+=`### ${s}/
112
+ `,u=new Map;for(let s of i){let f=s.category.split("/")[0]||"(\u65E0\u5206\u7C7B)";u.has(f)||u.set(f,[]),u.get(f).push(s)}for(let[s,f]of u){c+=`### ${s}/
107
113
 
108
- `;for(let m of d){let h=await M(e,m.id);if(!h){await c.warn(`[haimati_list] detail: #${m.id} (${m.title}) \u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728`);continue}l+=`#### ${m.category}/${m.title} - ${m.id.padStart(3,"0")}
109
- `,l+=U(m,h)+`
114
+ `;for(let m of f){let y=await _(e,m.id);if(!y){await l.warn(`[haimati_list] detail: #${m.id} (${m.title}) \u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728`);continue}c+=`#### ${m.category}/${m.title} - ${m.id.padStart(3,"0")}
115
+ `,c+=G(m,y)+`
110
116
 
111
- `}}let u=l;return await c.debug(`[haimati_list] \u51FA\u53C2:
112
- ${u}`),await c.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8 (\u8BE6\u7EC6\u6A21\u5F0F)"),u}let o=`## \u6D77\u9A6C\u4F53\u7D22\u5F15
117
+ `}}let d=c;return await l.debug(`[haimati_list] \u51FA\u53C2:
118
+ ${d}`),await l.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8 (\u8BE6\u7EC6\u6A21\u5F0F)"),d}let a=`## \u6D77\u9A6C\u4F53\u7D22\u5F15
113
119
 
114
- ${dt(i)||"(\u7A7A)"}`;return await c.debug(`[haimati_list] \u51FA\u53C2:
115
- ${o}`),await c.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8"),o}catch(i){return await C(i,"haimati_list")}}})}}import{readFile as Ce,rm as Le}from"node:fs/promises";import{basename as N,dirname as L,join as ht}from"node:path";import{fileURLToPath as Fe}from"node:url";var Te="opencode-haimati";function Qt(t,n){if(!n)return;let e=new AbortController,r=setTimeout(()=>e.abort(),1e4);Ae(e.signal).then(i=>{i.updated&&(c.info(`[autoUpdate] \u53D1\u73B0\u65B0\u7248\u672C: ${i.current} \u2192 ${i.latest}`),setTimeout(()=>{t.client.tui.showToast({body:{title:"\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u63D2\u4EF6\u66F4\u65B0",message:`${i.name} \u5DF2\u4ECE ${i.current} \u66F4\u65B0\u5230 ${i.latest}\uFF0C\u91CD\u542F OpenCode \u5B8C\u6210\u66F4\u65B0`,variant:"info"}})},5e3))}).catch(()=>{}).finally(()=>clearTimeout(r))}async function Ae(t){let n=await je(Te);if(!n)return{updated:!1};let e=await yt(ht(n,"package.json"));if(!e?.name||!e.version)return{updated:!1};let r=await Oe(e.name,t);if(!r||!qe(r,e.version))return{updated:!1};let i=await Re(n,e.name);if(!i)return{updated:!1};try{await Le(i,{recursive:!0,force:!0})}catch{return{updated:!1,error:"remove_failed",name:e.name,current:e.version,latest:r}}return{updated:!0,name:e.name,current:e.version,latest:r}}async function je(t){let n=L(Fe(import.meta.url));for(;;){if((await yt(ht(n,"package.json")))?.name===t)return N(n)==="dist"?L(n):n;let r=L(n);if(r===n)return;n=r}}async function Re(t,n){let e=L(t),r=N(e).startsWith("@")?L(e):e;if(N(r)!=="node_modules")return;let i=L(r),a=await yt(ht(i,"package.json")),o=We(i,n)??a?.dependencies?.[n];if(!(!o||!Ne(o)))return i}function We(t,n){if(n.startsWith("@")){let[i,a]=n.split("/");if(!i||!a||N(L(t))!==i)return;let o=`${a}@`,l=N(t);return l.startsWith(o)?l.slice(o.length):void 0}let e=`${n}@`,r=N(t);return r.startsWith(e)?r.slice(e.length):void 0}function Ne(t){let n=t.trim();return n?!!(n==="latest"||n==="*"||/^[~^]/.test(n)||/^(?:>=|>|<=|<)/.test(n)||/\s+(?:\|\||-|[<>=])\s+/.test(n)):!1}async function yt(t){try{let n=JSON.parse(await Ce(t,"utf-8"));return n&&typeof n=="object"?n:void 0}catch{return}}async function Oe(t,n){try{let e=await fetch(`https://registry.npmjs.org/${encodeURIComponent(t)}/latest`,{signal:n});if(!e.ok)return;let r=await e.json();if(!r||typeof r!="object")return;let i=r.version;return typeof i=="string"?i:void 0}catch{return}}function qe(t,n){let e=Yt(t),r=Yt(n);if(!e||!r)return!1;for(let i=0;i<3;i++)if(e.parts[i]!==r.parts[i])return e.parts[i]>r.parts[i];if(!e.pre.length&&r.pre.length)return!0;if(e.pre.length&&!r.pre.length)return!1;for(let i=0;i<Math.max(e.pre.length,r.pre.length);i++){let a=e.pre[i],o=r.pre[i];if(a===void 0)return!1;if(o===void 0)return!0;if(a===o)continue;let l=/^\d+$/.test(a)?Number(a):void 0,f=/^\d+$/.test(o)?Number(o):void 0;return l!==void 0&&f!==void 0?l>f:l!==void 0?!1:f!==void 0?!0:a>o}return!1}function Yt(t){let n=t.match(/^v?(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z.-]+))?(?:\+.+)?$/);if(n)return{parts:[Number(n[1]),Number(n[2]),Number(n[3])],pre:n[4]?.split(".")??[]}}var He="2026-06-02 17:00:00",Vt=!1;function Ue(t){return t.type==="text"&&t.ignored!==!0}var ri=async t=>{await St(),Vt||(Vt=!0,await c.debug(`[HaimatiPlugin] \u4EE3\u7801\u6700\u540E\u4FEE\u6539\u65E5\u671F: ${He}`));let n=z(t.directory),e=Bt(),r=new Set,i=new Set,a=new Set,o=new Map,l=1e4,f=new Set;return Qt(t,n.autoUpdate!==!1),Kt(t.directory).then(u=>{u>0&&c.info(`[HaimatiPlugin] \u542F\u52A8\u65F6\u6E05\u7406\u4E86 ${u} \u4E2A\u4E0D\u5B58\u5728\u7684\u6587\u4EF6\u5173\u8054`)}).catch(u=>{c.warn(`[HaimatiPlugin] \u6E05\u7406\u8FC7\u671F\u6587\u4EF6\u5173\u8054\u5931\u8D25: ${u instanceof Error?u.message:String(u)}`)}),{tool:e,event:async({event:u})=>{if(u.type==="message.updated"&&u.properties.info.role==="assistant"){let s=u.properties.info;if(s.finish==="stop"&&!r.has(s.id)){if(r.add(s.id),a.has(s.id)){a.delete(s.id);return}if(i.has(s.sessionID))return;let d=o.get(s.sessionID);if(d&&Date.now()<d)return;n.autoWrite===!0&&(i.add(s.sessionID),c.info(`[autoWrite] \u5F00\u59CB\u5F02\u6B65\u8BB0\u5FC6\u5199\u5165 session=${s.sessionID}`),t.client.session.prompt({path:{id:s.sessionID},body:{parts:[{type:"text",text:`\u56DE\u987E\u5F53\u524D\u4F1A\u8BDD\uFF0C\u5BF9\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u8FDB\u884C\u7EF4\u62A4\u3002
120
+ ${mt(i)||"(\u7A7A)"}`;return await l.debug(`[haimati_list] \u51FA\u53C2:
121
+ ${a}`),await l.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8"),a}catch(i){return await C(i,"haimati_list")}}})}}import{readFile as Ae,rm as Fe}from"node:fs/promises";import{basename as W,dirname as L,join as yt}from"node:path";import{fileURLToPath as Te}from"node:url";var je="opencode-haimati";function Xt(t,n){if(!n)return;let e=new AbortController,r=setTimeout(()=>e.abort(),1e4);Re(e.signal).then(i=>{i.updated&&(l.info(`[autoUpdate] \u53D1\u73B0\u65B0\u7248\u672C: ${i.current} \u2192 ${i.latest}`),setTimeout(()=>{t.client.tui.showToast({body:{title:"\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u63D2\u4EF6\u66F4\u65B0",message:`${i.name} \u5DF2\u4ECE ${i.current} \u66F4\u65B0\u5230 ${i.latest}\uFF0C\u91CD\u542F OpenCode \u5B8C\u6210\u66F4\u65B0`,variant:"info"}})},5e3))}).catch(()=>{}).finally(()=>clearTimeout(r))}async function Re(t){let n=await We(je);if(!n)return{updated:!1};let e=await wt(yt(n,"package.json"));if(!e?.name||!e.version)return{updated:!1};let r=await He(e.name,t);if(!r||!Ue(r,e.version))return{updated:!1};let i=await Ne(n,e.name);if(!i)return{updated:!1};try{await Fe(i,{recursive:!0,force:!0})}catch{return{updated:!1,error:"remove_failed",name:e.name,current:e.version,latest:r}}return{updated:!0,name:e.name,current:e.version,latest:r}}async function We(t){let n=L(Te(import.meta.url));for(;;){if((await wt(yt(n,"package.json")))?.name===t)return W(n)==="dist"?L(n):n;let r=L(n);if(r===n)return;n=r}}async function Ne(t,n){let e=L(t),r=W(e).startsWith("@")?L(e):e;if(W(r)!=="node_modules")return;let i=L(r),o=await wt(yt(i,"package.json")),a=Oe(i,n)??o?.dependencies?.[n];if(!(!a||!qe(a)))return i}function Oe(t,n){if(n.startsWith("@")){let[i,o]=n.split("/");if(!i||!o||W(L(t))!==i)return;let a=`${o}@`,c=W(t);return c.startsWith(a)?c.slice(a.length):void 0}let e=`${n}@`,r=W(t);return r.startsWith(e)?r.slice(e.length):void 0}function qe(t){let n=t.trim();return n?!!(n==="latest"||n==="*"||/^[~^]/.test(n)||/^(?:>=|>|<=|<)/.test(n)||/\s+(?:\|\||-|[<>=])\s+/.test(n)):!1}async function wt(t){try{let n=JSON.parse(await Ae(t,"utf-8"));return n&&typeof n=="object"?n:void 0}catch{return}}async function He(t,n){try{let e=await fetch(`https://registry.npmjs.org/${encodeURIComponent(t)}/latest`,{signal:n});if(!e.ok)return;let r=await e.json();if(!r||typeof r!="object")return;let i=r.version;return typeof i=="string"?i:void 0}catch{return}}function Ue(t,n){let e=Vt(t),r=Vt(n);if(!e||!r)return!1;for(let i=0;i<3;i++)if(e.parts[i]!==r.parts[i])return e.parts[i]>r.parts[i];if(!e.pre.length&&r.pre.length)return!0;if(e.pre.length&&!r.pre.length)return!1;for(let i=0;i<Math.max(e.pre.length,r.pre.length);i++){let o=e.pre[i],a=r.pre[i];if(o===void 0)return!1;if(a===void 0)return!0;if(o===a)continue;let c=/^\d+$/.test(o)?Number(o):void 0,u=/^\d+$/.test(a)?Number(a):void 0;return c!==void 0&&u!==void 0?c>u:c!==void 0?!1:u!==void 0?!0:o>a}return!1}function Vt(t){let n=t.match(/^v?(\d+)\.(\d+)\.(\d+)(?:-([0-9A-Za-z.-]+))?(?:\+.+)?$/);if(n)return{parts:[Number(n[1]),Number(n[2]),Number(n[3])],pre:n[4]?.split(".")??[]}}var Ge="2026-06-02 19:13:02",Zt=!1;function ze(t){return t.type==="text"&&t.ignored!==!0}var si=async t=>{await Dt(),Zt||(Zt=!0,await l.debug(`[HaimatiPlugin] \u4EE3\u7801\u6700\u540E\u4FEE\u6539\u65E5\u671F: ${Ge}`));let n=J(t.directory),e=Yt(),r=new Set,i=new Set,o=new Set,a=new Map,c=1e4,u=new Set;return Xt(t,n.autoUpdate!==!1),Bt(t.directory).then(d=>{d>0&&l.info(`[HaimatiPlugin] \u542F\u52A8\u65F6\u6E05\u7406\u4E86 ${d} \u4E2A\u4E0D\u5B58\u5728\u7684\u6587\u4EF6\u5173\u8054`)}).catch(d=>{l.warn(`[HaimatiPlugin] \u6E05\u7406\u8FC7\u671F\u6587\u4EF6\u5173\u8054\u5931\u8D25: ${d instanceof Error?d.message:String(d)}`)}),{tool:e,event:async({event:d})=>{if(d.type==="message.updated"&&d.properties.info.role==="assistant"){let s=d.properties.info;if(s.finish==="stop"&&!r.has(s.id)){if(r.add(s.id),o.has(s.id)){o.delete(s.id);return}if(i.has(s.sessionID))return;let f=a.get(s.sessionID);if(f&&Date.now()<f)return;n.autoWrite===!0&&(i.add(s.sessionID),l.info(`[autoWrite] \u5F00\u59CB\u5F02\u6B65\u8BB0\u5FC6\u5199\u5165 session=${s.sessionID}`),t.client.session.prompt({path:{id:s.sessionID},body:{parts:[{type:"text",text:`\u56DE\u987E\u5F53\u524D\u4F1A\u8BDD\uFF0C\u5BF9\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u8FDB\u884C\u7EF4\u62A4\u3002
116
122
 
117
123
  \u4F60\u7684\u804C\u8D23\uFF1A
118
124
  1. \u5199\u5165\u65B0\u77E5\u8BC6 - \u67B6\u6784\u51B3\u7B56\u3001API\u7528\u6CD5\u3001Bug\u6839\u56E0\u4E0E\u4FEE\u590D\u3001\u914D\u7F6E\u65B9\u6CD5\u3001\u5F00\u53D1\u89C4\u8303\u7B49\u503C\u5F97\u957F\u671F\u8BB0\u5F55\u7684\u77E5\u8BC6
@@ -128,9 +134,9 @@ ${o}`),await c.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8"),o}c
128
134
  - \u9519\u8BEF\u6216\u8FC7\u671F\u7684\u4FE1\u606F\u76F4\u63A5\u5220\u9664\u6216\u4FEE\u6539
129
135
  - \u4E0D\u786E\u5B9A\u5206\u7C7B\u65F6\uFF0C\u5148\u7528 haimati_list \u67E5\u770B\u73B0\u6709\u7ED3\u6784
130
136
 
131
- \u5982\u679C\u6CA1\u4EC0\u4E48\u53EF\u505A\u7684\uFF0C\u56DE\u590D"\u65E0"`}]}}).then(m=>{let h=m?.data?.info?.id;h&&a.add(h),i.delete(s.sessionID),o.set(s.sessionID,Date.now()+l),c.info(`[autoWrite] AI\u8BB0\u5FC6\u5199\u5165\u5B8C\u6210 session=${s.sessionID}`)}).catch(m=>{i.delete(s.sessionID),o.set(s.sessionID,Date.now()+l);let h=m instanceof Error?m.message:String(m);c.error(`[autoWrite] \u5931\u8D25: ${h}`)})),await c.debug(`[message.updated] AI\u56DE\u590D\u7ED3\u675F messageID=${s.id}`)}}},"chat.message":async(u,s)=>{let d=s.parts.filter(Ue);if(d.length!==0){if(f.has(s.message.sessionID)){s.parts.unshift({id:`prt_auto_reminder_${Date.now()}`,sessionID:d[0].sessionID??s.message.sessionID,messageID:d[0].messageID??s.message.id,type:"text",text:`<\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>
137
+ \u5982\u679C\u6CA1\u4EC0\u4E48\u53EF\u505A\u7684\uFF0C\u56DE\u590D"\u65E0"`}]}}).then(m=>{let y=m?.data?.info?.id;y&&o.add(y),i.delete(s.sessionID),a.set(s.sessionID,Date.now()+c),l.info(`[autoWrite] AI\u8BB0\u5FC6\u5199\u5165\u5B8C\u6210 session=${s.sessionID}`)}).catch(m=>{i.delete(s.sessionID),a.set(s.sessionID,Date.now()+c);let y=m instanceof Error?m.message:String(m);l.error(`[autoWrite] \u5931\u8D25: ${y}`)})),await l.debug(`[message.updated] AI\u56DE\u590D\u7ED3\u675F messageID=${s.id}`)}}},"chat.message":async(d,s)=>{let f=s.parts.filter(ze);if(f.length!==0){if(u.has(s.message.sessionID)){s.parts.unshift({id:`prt_auto_reminder_${Date.now()}`,sessionID:f[0].sessionID??s.message.sessionID,messageID:f[0].messageID??s.message.id,type:"text",text:`<\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>
132
138
  1\u3001\u5DE5\u4F5C\u524D\u8BFB\u53D6\u6240\u6709\u76F8\u5173\u7684\u6D77\u9A6C\u4F53\u8BB0\u5FC6\uFF1B2\u3001\u5DE5\u4F5C\u540E\u603B\u7ED3\u8BB0\u5FC6
133
- </\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>`,synthetic:!0}),await c.debug("[chat.message] \u6CE8\u5165\u7B80\u77ED\u786E\u8BA4\u63D0\u793A");return}f.add(s.message.sessionID),s.parts.unshift({id:`prt_auto_reminder_${Date.now()}`,sessionID:d[0].sessionID??s.message.sessionID,messageID:d[0].messageID??s.message.id,type:"text",text:`<\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>
139
+ </\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>`,synthetic:!0}),await l.debug("[chat.message] \u6CE8\u5165\u7B80\u77ED\u786E\u8BA4\u63D0\u793A");return}u.add(s.message.sessionID),s.parts.unshift({id:`prt_auto_reminder_${Date.now()}`,sessionID:f[0].sessionID??s.message.sessionID,messageID:f[0].messageID??s.message.id,type:"text",text:`<\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>
134
140
  \u4F60\u6709\u4E00\u5957\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u63D2\u4EF6\u53EF\u7528
135
141
 
136
142
  1\u3001\u5DE5\u4F5C\u524D\u8BFB\u53D6\u6240\u6709\u76F8\u5173\u7684\u6D77\u9A6C\u4F53\u8BB0\u5FC6
@@ -146,8 +152,8 @@ ${o}`),await c.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8"),o}c
146
152
  - \u6574\u5408\u91CD\u590D\u7684\u8BB0\u5FC6
147
153
  - \u5982\u679C\u5B58\u5728\u5206\u7C7B\u4E0D\u5408\u7406\u7684\uFF0C\u5219\u8C03\u6574
148
154
  - \u5728\u8282\u7EA6TOKEN\u7684\u60C5\u51B5\u4E0B\uFF0C\u7CBE\u7B80\u6D77\u9A6C\u4F53\u8BB0\u5FC6
149
- </\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>`,synthetic:!0}),await c.debug("[chat.message] \u6CE8\u5165\u5DE5\u4F5C\u89C4\u5219\u63D0\u793A")}},"tool.execute.after":async(u,s)=>{if(u.tool!=="read")return;let d=u.args?.filePath;if(!(!d||typeof d!="string"))try{let m=t.directory,h=await k(m);if(Object.keys(h).length===0)return;let g=W(m,d),p=Jt(h,g);if(p.length>0){let y=p.map(b=>`#${b}`).join("\u3001"),w=`${g}\u548C\u6D77\u9A6C\u4F53${y}\u6709\u5173\uFF0C\u5EFA\u8BAE\u8BFB\u53D6\u8BB0\u5FC6`;s.output+=`
155
+ </\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>`,synthetic:!0}),await l.debug("[chat.message] \u6CE8\u5165\u5DE5\u4F5C\u89C4\u5219\u63D0\u793A")}},"tool.execute.after":async(d,s)=>{if(d.tool!=="read")return;let f=d.args?.filePath;if(!(!f||typeof f!="string"))try{let m=t.directory,y=await v(m);if(Object.keys(y).length===0)return;let g=R(m,f),p=Kt(y,g);if(p.length>0){let h=p.map(b=>`#${b}`).join("\u3001"),w=`${g}\u548C\u6D77\u9A6C\u4F53${h}\u6709\u5173\uFF0C\u4F60\u8981\u8BFB\u53D6\u8BB0\u5FC6`;s.output+=`
150
156
 
151
157
  <system-reminder>
152
158
  ${w}
153
- </system-reminder>`,await c.debug(`[tool.execute.after] \u6CE8\u5165\u6587\u4EF6\u5173\u8054\u63D0\u793A: ${g} -> ${p.join(",")}`)}}catch(m){await c.warn(`[tool.execute.after] \u68C0\u67E5\u6587\u4EF6\u5173\u8054\u5931\u8D25: ${m instanceof Error?m.message:String(m)}`)}}}};export{ri as HaimatiPlugin};
159
+ </system-reminder>`,await l.debug(`[tool.execute.after] \u6CE8\u5165\u6587\u4EF6\u5173\u8054\u63D0\u793A: ${g} -> ${p.join(",")}`)}}catch(m){await l.warn(`[tool.execute.after] \u68C0\u67E5\u6587\u4EF6\u5173\u8054\u5931\u8D25: ${m instanceof Error?m.message:String(m)}`)}}}};export{si as HaimatiPlugin};
package/dist/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "opencode-haimati",
3
- "version": "1.6.1",
3
+ "version": "1.6.3",
4
4
  "description": "OpenCode plugin for a file-based memory system inspired by the hippocampus, providing long-term memory storage and retrieval across sessions.",
5
5
  "main": "./dist/index.js",
6
6
  "type": "module",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "opencode-haimati",
3
- "version": "1.6.1",
3
+ "version": "1.6.3",
4
4
  "description": "OpenCode plugin for a file-based memory system inspired by the hippocampus, providing long-term memory storage and retrieval across sessions.",
5
5
  "main": "./dist/index.js",
6
6
  "type": "module",