opencode-haimati 1.6.3 → 2.0.0
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 +17 -4
- package/dist/index.js +92 -89
- package/dist/package.json +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
- 版本并发控制:基于 version 的乐观锁
|
|
12
12
|
- 文件锁机制:支持网络共享挂载多用户并发写入
|
|
13
13
|
- 自动工作规则提示:会话首条消息时自动注入工作流程提醒
|
|
14
|
-
- memo-map
|
|
14
|
+
- memo-map 文件关联:记忆与项目文件/目录建立关联(多路径数组支持),读取文件时自动注入关联记忆的完整正文
|
|
15
15
|
- 文件路径校验:filePath 自动检查路径是否存在,项目内用相对路径、项目外用绝对路径
|
|
16
16
|
- 自动关联记忆检索(auto-read):关键词提取 → 搜索 → 注入 Top 3 相关记忆到消息上下文
|
|
17
17
|
- 自动记忆写入(autoWrite,默认关闭):AI 回复完成后异步触发 AI 自主审查并写入有价值的知识
|
|
@@ -85,7 +85,7 @@ bun add -g opencode-haimati
|
|
|
85
85
|
|
|
86
86
|
| 工具 | 说明 |
|
|
87
87
|
|------|------|
|
|
88
|
-
| `haimati_read` |
|
|
88
|
+
| `haimati_read` | 读取记忆(单条/批量,支持分页,正文后展示系统元数据) |
|
|
89
89
|
| `haimati_write` | 写入新记忆,可选 filePath 数组建立文件关联 |
|
|
90
90
|
| `haimati_search` | 搜索(标题/分类/内容,match必填) |
|
|
91
91
|
| `haimati_edit` | 部分修改(字符串替换 + 增减文件关联数组) |
|
|
@@ -155,18 +155,31 @@ haimati_list({ category: "xxx项目", recursive: true, detail: true })
|
|
|
155
155
|
|
|
156
156
|
### memo-map 文件关联
|
|
157
157
|
|
|
158
|
-
记忆可与项目文件/目录建立关联。AI 通过 `read`
|
|
158
|
+
记忆可与项目文件/目录建立关联。AI 通过 `read` 工具读取文件时,自动在输出末尾注入关联记忆的完整正文:
|
|
159
159
|
|
|
160
160
|
```
|
|
161
|
-
|
|
161
|
+
<system-reminder>
|
|
162
|
+
文件 src/index.ts 关联了以下海马体记忆:
|
|
163
|
+
|
|
164
|
+
===== #043 =====
|
|
165
|
+
1|记忆正文内容...
|
|
166
|
+
------system------
|
|
167
|
+
title:xxx
|
|
168
|
+
create_time:xxx
|
|
169
|
+
update_time:xxx
|
|
170
|
+
file_paths: src/index.ts, src/tools.ts, docs/
|
|
171
|
+
</system-reminder>
|
|
162
172
|
```
|
|
163
173
|
|
|
164
174
|
- `filePath: ["src/index.ts"]` — 精确文件关联(数组支持多路径)
|
|
165
175
|
- `filePath: ["src/"]` — 目录关联(末尾 `/`,匹配该目录下所有文件及子目录)
|
|
176
|
+
- `filePath: ["./"]` — 项目根目录关联,读取任何项目文件时均触发(key 存为 `./`,避免 Linux 上 `/` 与系统根冲突)
|
|
166
177
|
- `filePath: ["src/index.ts", "C:/external/file.txt"]` — 项目内文件用相对路径,项目外文件用绝对路径
|
|
167
178
|
- 路径失效校验:filePath 中不存在的路径会报错提示
|
|
168
179
|
- 关联关系记录在 `.haimati/memo-map.yaml`
|
|
169
180
|
- 插件启动时自动清理已不存在的文件/目录条目
|
|
181
|
+
- 去重机制:按记忆 ID + update_time 跟踪,无变化不重复注入;haimati_read 读取过的记忆也不会重复注入;记忆编辑后自动重新注入
|
|
182
|
+
- 输出系统区域包含 `file_paths` 行,列出该记忆关联的所有文件/目录路径(字典序),无关联时不显示
|
|
170
183
|
|
|
171
184
|
### haimati_edit 使用说明
|
|
172
185
|
|
package/dist/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import
|
|
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
|
|
1
|
+
import rt from"path";import{tool as $}from"@opencode-ai/plugin";import D from"path";import Et from"os";import Q from"fs";var Mt=".haimati",_t="\u7D22\u5F15.md";var St="info";import H from"path";import oe from"os";import W from"fs";var ae=["haimati.jsonc","haimati.json"];function se(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 st(t){let e=se(t).replace(/,\s*([}\]])/g,"$1");return JSON.parse(e)}function ot(t){for(let n of ae){let e=H.join(t,n);if(W.existsSync(e))return e}return null}function at(t){try{let n=W.readFileSync(t,"utf-8"),e=st(n);return typeof e=="object"&&e!==null?e:{}}catch{return{}}}function K(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]=K(i,o):o!==void 0&&(e[r]=o)}return e}function It(){return H.join(oe.homedir(),".config","opencode")}function ce(){return process.env.OPENCODE_CONFIG_DIR||null}function le(t){return H.join(t,".opencode")}function fe(){let t=It(),n=H.join(t,"haimati.jsonc");if(!W.existsSync(n))try{W.existsSync(t)||W.mkdirSync(t,{recursive:!0}),W.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,103 +22,103 @@ import nt from"path";import{tool as $}from"@opencode-ai/plugin";import S from"pa
|
|
|
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
|
|
26
|
-
`,"utf-8")}catch(e){console.error("[haimati] \u5199\u5165\u65E5\u5FD7\u6587\u4EF6\u5931\u8D25:",e)}}async function
|
|
27
|
-
`),r=[];for(let i of e){if(!i.trim())continue;let o=
|
|
28
|
-
`)}async function
|
|
29
|
-
`),o="------system------",a=Math.max(0,i.length-5),
|
|
30
|
-
`)};let u=i.slice(0,
|
|
31
|
-
`),d=i[
|
|
32
|
-
${
|
|
33
|
-
${
|
|
34
|
-
`),r=null;for(let i of e){if(!i.trim()||i.trim().startsWith("#"))continue;if(!i.startsWith(" ")&&!i.startsWith(" ")){let
|
|
25
|
+
`,"utf-8")}catch{}}function B(t){fe();let n={},e=ot(It());if(e){let o=at(e);n=K(n,o)}let r=ce();if(r){let o=ot(r);if(o){let a=at(o);n=K(n,a)}}let i=ot(le(t));if(i){let o=at(i);n=K(n,o)}return n}function Dt(t,n,e){return t.haimatiPath?H.resolve(n,t.haimatiPath):e}function E(t){let n=B(t),e=D.join(t,Mt);return Dt(n,t,e)}function I(t){return D.join(E(t),_t)}function lt(t){return D.join(E(t),".lock")}function ft(t){return D.join(E(t),"\u4E66\u9875")}function ut(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 D.join(ft(t),o)}function Y(t,n){let e=String(parseInt(n,10)).padStart(3,"0");return D.join(ut(t,n),`${e}.md`)}function dt(){let t=Et.homedir();return D.join(t,".opencode-haimati","log")}function mt(){let t={level:St,logRetentionDays:180},n=D.join(Et.homedir(),".config","opencode"),e=[D.join(n,"haimati.jsonc"),D.join(n,"haimati.json")].find(r=>Q.existsSync(r));if(e)try{let r=Q.readFileSync(e,"utf-8"),i=st(r);if(i?.log)return{level:i.log.level||t.level,logRetentionDays:i.log.logRetentionDays??t.logRetentionDays}}catch{}return t}function C(t){return Q.promises.mkdir(t,{recursive:!0}).then(()=>{})}function P(t){return Q.promises.access(t).then(()=>!0).catch(()=>!1)}import Ft from"fs";import{promisify as Lt}from"util";import X from"fs";import gt from"path";import{promisify as Z}from"util";var me=Z(X.appendFile),ge=Z(X.readdir),pe=Z(X.unlink),he=Z(X.stat),kt={debug:0,info:1,warn:2,error:3};function ye(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 we(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 $e(){let t=ye(new Date);return gt.join(dt(),`${t}.log`)}async function Pe(t,n){try{let e=gt.dirname(t);await P(e)||await C(e),await me(t,n+`
|
|
26
|
+
`,"utf-8")}catch(e){console.error("[haimati] \u5199\u5165\u65E5\u5FD7\u6587\u4EF6\u5931\u8D25:",e)}}async function vt(){try{let t=mt(),n=dt();if(!await P(n))return;let e=await ge(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=gt.join(n,o);(await he(a)).mtime.getTime()<i&&await pe(a)}}catch(t){console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",t)}}async function V(t,n,e){try{let r=mt();if(kt[t]<kt[r.level])return;let o=we(new Date),a=e?`[${e}] `:"",s=`[${o}] [${t.toUpperCase()}] ${a}${n}`,u=$e();await Pe(u,s),vt().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 c={debug(t,n){return V("debug",t,n)},info(t,n){return V("info",t,n)},warn(t,n){return V("warn",t,n)},error(t,n){return V("error",t,n)}};async function Ct(){await vt()}var At=Lt(Ft.readFile),be=Lt(Ft.writeFile);function tt(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 et(t){let e=t.trim().replace(/^[│├└─\s]+/,"").trim();return e==="/"?"/":!e.endsWith("/")||(e=e.slice(0,-1),!e)?null:e}function xe(t){let n=[],e=t.split(`
|
|
27
|
+
`),r=[];for(let i of e){if(!i.trim())continue;let o=tt(i),a=i.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(a){let s=a[1].trim(),u=String(parseInt(a[2],10)),f=r.slice(0,o).filter(l=>l!=="").join("/");n.push({id:u,category:f,title:s})}else{let s=et(i);if(s)if(s==="/"){r[o]="";for(let u=o+1;u<r.length;u++)delete r[u]}else{r[o]=s;for(let u=o+1;u<r.length;u++)delete r[u]}}}return n}function F(t,n){return t.find(e=>e.id===n)||null}function jt(t,n,e){return t.find(r=>r.category===n&&r.title===e)||null}function Tt(t,n){return t.filter(e=>e.id!==n)}function pt(t){if(t.length===0)return"";let n={name:"/",children:[],entry:null};for(let o of t){let a=o.category.split("/"),s=n;for(let d=0;d<a.length;d++){let f=a[d];if(!f)continue;let l=s.children.find(m=>m.name===f);l||(l={name:f,children:[],entry:null},s.children.push(l)),s=l}let u={name:o.id,children:[],entry:o};s.children.push(u)}function e(o){o.children.sort((a,s)=>a.name.localeCompare(s.name,void 0,{sensitivity:"base"}));for(let a of o.children)e(a)}e(n);function r(o,a,s){let u=[],d=a+(s?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "),f=o.name==="/"?"/":o.name+"/";u.push(`${d}${f}`),a=a+(s?" ":"\u2502 ");let l=o.children.filter(g=>g.entry===null),m=o.children.filter(g=>g.entry!==null),p=[...l,...m];for(let g=0;g<p.length;g++){let h=p[g],y=g===p.length-1;if(h.entry){let w=h.entry.id.padStart(3,"0"),b=a+(y?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ");u.push(`${b}${h.entry.title} - ${w}`)}else u.push(...r(h,a,y))}return u}return r(n,"",!0).join(`
|
|
28
|
+
`)}async function S(t){let n=I(t);if(!await P(n))return[];let e=await At(n,"utf-8");return xe(e)}async function U(t,n){let e=E(t);await P(e)||await C(e);let r=pt(n),i=I(t);await be(i,r,"utf-8"),await c.debug(`[writeIndex] \u5199\u5165\u7D22\u5F15: ${i}, \u5171${n.length}\u6761`)}async function Rt(t){let n=I(t);return await P(n)?await At(n,"utf-8"):""}import nt from"fs";import{promisify as it}from"util";var Me=it(nt.readFile),_e=it(nt.writeFile),Se=it(nt.unlink),Wt=it(nt.mkdir);async function M(t,n){let e=Y(t,n);if(!await P(e))return null;let i=(await Me(e,"utf-8")).split(`
|
|
29
|
+
`),o="------system------",a=Math.max(0,i.length-5),s=-1;for(let f=i.length-1;f>=a;f--)if(i[f].trim()===o){s=f;break}if(s===-1)return{title:"",createdAt:"",updatedAt:"",content:i.join(`
|
|
30
|
+
`)};let u=i.slice(0,s).join(`
|
|
31
|
+
`),d=i[s+1]?.trim();if(!d)return await c.warn("[readPage] \u51FA\u53C2: \u5143\u6570\u636E\u884C\u4E3A\u7A7A"),null;if(d.startsWith("{"))try{let f=JSON.parse(d);return{title:f.title||"",createdAt:f.create_time||"",updatedAt:f.update_time||f.create_time||"",content:u,systemMeta:f}}catch{return await c.warn("[readPage] \u51FA\u53C2: JSON \u89E3\u6790\u5931\u8D25"),null}return s+3>=i.length?(await c.warn("[readPage] \u51FA\u53C2: \u65E7\u683C\u5F0F\u4E0D\u5B8C\u6574"),null):{title:d,createdAt:i[s+2]||"",updatedAt:"",content:u,systemMeta:{title:d,create_time:i[s+2]||""}}}async function N(t,n,e,r,i,o){let a=ft(t);await P(a)||await Wt(a,{recursive:!0});let s=ut(t,n);await P(s)||await Wt(s,{recursive:!0});let u=Y(t,n),d="------system------",f=JSON.stringify({title:e,create_time:r,update_time:i}),l=`${d}
|
|
32
|
+
${f}`,m=o?`${o}
|
|
33
|
+
${l}`:l;await _e(u,m,"utf-8"),await c.debug(`[writePage] \u5199\u5165\u4E66\u9875: ${u}`)}async function Nt(t,n){let e=Y(t,n);return await P(e)?(await Se(e),await c.debug(`[deletePage] \u5220\u9664\u4E66\u9875: ${e}`),!0):!1}async function Ot(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(),f=u.category.toLowerCase(),l=u.id.toLowerCase(),m=new Set,p=0;for(let g of o)(d.includes(g)||f.includes(g)||l.includes(g))&&(p++,m.add(g));if(i&&r){let g=await M(r,u.id);if(g&&g.content){let h=g.content.toLowerCase();for(let y of o)h.includes(y)&&(p++,m.add(y))}}e==="and"?m.size===o.length&&a.push({entry:u,score:p}):m.size>0&&a.push({entry:u,score:p})}a.sort((u,d)=>d.score-u.score);let s=a.map(u=>u.entry);return await c.debug(`[searchEntries] \u641C\u7D22\u5B8C\u6210: \u5173\u952E\u5B57="${n}", \u6A21\u5F0F=${e}, \u7ED3\u679C\u6570=${s.length}`),s}import qt from"fs";import{promisify as Ht}from"util";var De=Ht(qt.writeFile),Ee=Ht(qt.unlink);async function Ut(t){let n=E(t);await P(n)||await C(n);let e=lt(t),r=Date.now(),i=50+Math.random()*20,o=0;for(;await P(e);){if(o++,Date.now()-r>5e3)return await c.warn(`[acquireLock] \u51FA\u53C2: \u9501\u83B7\u53D6\u8D85\u65F6 (\u91CD\u8BD5${o}\u6B21)`),!1;await new Promise(a=>setTimeout(a,i))}return await De(e,String(process.pid),"utf-8"),await c.debug(`[acquireLock] \u9501\u83B7\u53D6\u6210\u529F: ${e}`),!0}async function Gt(t){let n=lt(t);await P(n)&&(await Ee(n),await c.debug(`[releaseLock] \u9501\u91CA\u653E\u6210\u529F: ${n}`))}async function zt(t,n,e,r,i,o=!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 Ut(t))return await c.warn(`[allocateIdWithLock] \u83B7\u53D6\u9501\u5931\u8D25: category="${n}", title="${e}"`),null;try{let a=await S(t),s=a.find(l=>l.category===n&&l.title===e);if(s){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 l=await M(t,s.id),m=l?l.createdAt:r;return await N(t,s.id,e,m,r,i),await c.debug(`[allocateIdWithLock] \u66F4\u65B0\u5DF2\u6709\u6761\u76EE: #${s.id} ${n}/${e}`),null}let u=0;for(let l of a){let m=parseInt(l.id,10);m>u&&(u=m)}let d=String(u+1).padStart(3,"0");await N(t,d,e,r,r,i);let f={id:d,category:n,title:e};return a.push(f),await U(t,a),await c.debug(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u6210\u529F: #${d} ${n}/${e}`),d}catch(a){let s=a instanceof Error?a.message:String(a);if(await c.error(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u5931\u8D25: ${s}`),s.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw a;return null}finally{await Gt(t)}}import Jt from"fs";import G from"path";import{promisify as Kt}from"util";var ke=Kt(Jt.readFile),ve=Kt(Jt.writeFile);function Bt(t){return E(t).replace(/\\/g,"/")+"/memo-map.yaml"}function Ce(t){return t.startsWith('"')&&t.endsWith('"')||t.startsWith("'")&&t.endsWith("'")}function Fe(t){return Ce(t)?t.slice(1,-1):t}function Le(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 s;if(i.startsWith('"')){let f=i.indexOf('"',1);if(f===-1)continue;s=i.indexOf(":",f)}else s=i.indexOf(":");if(s===-1)continue;let u=i.slice(0,s).trim();r=Fe(u);let d=i.slice(s+1).trim();if(d){if(/^\[\s*"[^"]*"(?:\s*,\s*"[^"]*"\s*)*\]$/.test(d)){n[r]=[];let l=d.match(/"([^"]*)"/g);l&&(n[r]=l.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 Ae(t){if(Object.keys(t).length===0)return"";let n=`# \u8BB0\u5FC6\u4E0E\u9879\u76EE\u6587\u4EF6\u7684\u5173\u8054\u6620\u5C04
|
|
35
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
|
|
37
|
-
`}return n}async function
|
|
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
|
|
39
|
-
`)}async function
|
|
40
|
-
\u5806\u6808: ${r}`),`\u9519\u8BEF: ${e}`}function
|
|
41
|
-
${i}`),i}try{let i=await
|
|
42
|
-
${
|
|
43
|
-
${y}`;return await
|
|
44
|
-
${
|
|
45
|
-
\u672A\u627E\u5230\u8BB0\u5FC6: ${
|
|
46
|
-
\u672A\u627E\u5230\u4E66\u9875`);continue}let
|
|
47
|
-
${
|
|
48
|
-
|
|
49
|
-
`);return await
|
|
36
|
+
`;for(let s of i)n+=` - "${s}"
|
|
37
|
+
`}return n}async function k(t){let n=Bt(t);if(!await P(n))return{};let e=await ke(n,"utf-8"),r=Le(e);return await c.debug(`[memoMap] \u52A0\u8F7D\u6620\u5C04: ${n}, ${Object.keys(r).length} \u4E2A\u6587\u4EF6`),r}async function z(t,n){let e=E(t);await P(e)||await C(e);let r=Bt(t),i=Ae(n);await ve(r,i,"utf-8"),await c.debug(`[memoMap] \u4FDD\u5B58\u6620\u5C04: ${r}, ${Object.keys(n).length} \u4E2A\u6587\u4EF6`)}function O(t,n){let e=n.endsWith("/")||n.endsWith("\\"),r=G.isAbsolute(n)?n.replace(/[\\/]$/,""):G.resolve(t,n.replace(/[\\/]$/,"")),i=G.relative(t,r).replace(/\\/g,"/");if(!i.startsWith("..")&&!G.isAbsolute(i))return i===""?e?"./":".":e?i+"/":i;let a=r.replace(/\\/g,"/");return e?a+"/":a}function L(t){return String(parseInt(t,10))}function yt(t,n,e){let r=n.replace(/\\/g,"/"),i=L(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 Qt(t,n){let e=L(n);for(let r of Object.keys(t)){let i=t[r];if(!i)continue;let o=i.filter(a=>L(a)!==e);o.length===0?delete t[r]:o.length!==i.length&&(t[r]=o)}return t}function Yt(t,n,e){let r=n.replace(/\\/g,"/"),i=L(e),o=t[r];if(!o)return t;let a=o.filter(s=>L(s)!==i);return a.length===0?delete t[r]:a.length!==o.length&&(t[r]=a),t}function J(t,n){let e=L(n),r=[];for(let[i,o]of Object.entries(t))o.some(a=>L(a)===e)&&r.push(i);return r.sort()}function ht(t){return t.endsWith("/")}function Vt(t,n){let e=n.replace(/\\/g,"/"),r=new Set,i=/^[A-Za-z]:\//.test(e);if(t[e]&&!ht(e))for(let s of t[e])r.add(s);let o=e.split("/");for(let s=o.length-1;s>=0&&!(s===0&&i);s--){let u=o.slice(0,s).join("/")+(s===0&&o[0]==="","/"),d=t[u];if(d)for(let f of d)r.add(f);if(s===0&&o[0]!==""&&!i){let f=t["./"];if(f)for(let l of f)r.add(l)}}let a=Array.from(r);return a.sort((s,u)=>parseInt(s)-parseInt(u)),a}function je(t,n){return G.resolve(t,n)}async function Xt(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=ht(r)?r.replace(/\/$/,""):r,o=je(t,i);await P(o)||(delete n[r],e++,await c.info(`[memoMap] \u6E05\u7406\u4E0D\u5B58\u5728${ht(r)?"\u76EE\u5F55":"\u6587\u4EF6"}: ${r}`))}return e>0&&(await z(t,n),await c.info(`[memoMap] \u542F\u52A8\u6E05\u7406\u5B8C\u6210\uFF0C\u79FB\u9664 ${e} \u4E2A\u4E0D\u5B58\u5728\u6761\u76EE`)),e}function A(t){let n=t;return typeof n?.directory=="string"&&n.directory?n.directory:null}function $t(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 s=parseInt(a[1],10),u=parseInt(a[2],10);if(s>u||s<=0)return null;for(let d=s;d<=u;d++)e.push(String(d))}else if(/^\d+$/.test(o))e.push(String(parseInt(o,10)));else return null}return e}function T(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 s=o;s<a;s++)i.push(`${s+1}|${r[s]}`);if(i.push("------system------"),n.systemMeta)for(let[s,u]of Object.entries(n.systemMeta))i.push(`${s}:${u}`);else i.push(`title:${t.title}`),i.push(`create_time:${n.createdAt}`),n.updatedAt&&i.push(`update_time:${n.updatedAt}`);return i.join(`
|
|
39
|
+
`)}async function j(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 wt(t){return/^\d+$/.test(t.trim())?String(parseInt(t.trim(),10)):null}async function Zt(t,n){let e=[];for(let r of n){let i=r.endsWith("/")||r.endsWith("\\"),o=rt.isAbsolute(r)?rt.resolve(r):rt.resolve(t,r.replace(/[\\/]$/,""));if(!await P(o)){let s=rt.relative(t,o).replace(/\\/g,"/");e.push(i?s+"/":s)}}return e}function te(){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=A(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=I(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 S(e),o=t.query.trim(),a=$t(o);if(!a||a.length===0){let l=`\u9519\u8BEF\uFF1A\u65E0\u6548\u7684\u67E5\u8BE2\u683C\u5F0F "${o}"`;return await c.debug(`[haimati_read] \u51FA\u53C2:
|
|
42
|
+
${l}`),l}if(a.length===1){let l=a[0],m=F(i,l);if(!m)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 p=await M(e,m.id);if(!p)return`\u672A\u627E\u5230\u4E66\u9875: #${m.id.padStart(3,"0")}`;let g=await k(e),h=J(g,m.id);h.length>0&&(p.systemMeta={...p.systemMeta,file_paths:h.join(", ")});let y=T(m,p,{offset:t.offset??1,limit:t.limit??2e3}),w=`===== #${m.id.padStart(3,"0")} =====
|
|
43
|
+
${y}`;return await c.debug(`[haimati_read] \u51FA\u53C2:
|
|
44
|
+
${w}`),await c.info(`[haimati_read] \u8BFB\u53D6\u6210\u529F: #${m.id} (${m.category}/${m.title})`),w}let s=[],u=0,d=await k(e);for(let l of a){let m=F(i,l);if(!m){await c.warn(`[haimati_read] \u6279\u91CF: \u672A\u627E\u5230\u8BB0\u5FC6 #${l}`),s.push(`===== #${l.padStart(3,"0")} =====
|
|
45
|
+
\u672A\u627E\u5230\u8BB0\u5FC6: ${l}`);continue}let p=await M(e,m.id);if(!p){await c.error(`[haimati_read] \u6279\u91CF: \u672A\u627E\u5230\u4E66\u9875 #${m.id}`),s.push(`===== #${m.id.padStart(3,"0")} =====
|
|
46
|
+
\u672A\u627E\u5230\u4E66\u9875`);continue}let g=J(d,m.id);g.length>0&&(p.systemMeta={...p.systemMeta,file_paths:g.join(", ")});let h=T(m,p);s.push(`===== #${m.id.padStart(3,"0")} =====
|
|
47
|
+
${h}`),u++}let f=s.join(`
|
|
48
|
+
|
|
49
|
+
`);return await c.info(`[haimati_read] \u6279\u91CF\u8BFB\u53D6\u7ED3\u675F: \u5171 ${a.length} \u6761, \u6210\u529F ${u} \u6761`),f}catch(i){return await j(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\u6CE8\u5165\u5173\u8054\u8BB0\u5FC6\u7684\u5B8C\u6574\u6B63\u6587\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\u5173\u8054\u8BB0\u5FC6\u7684\u5B8C\u6574\u6B63\u6587")},async execute(t,n){let e=A(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 Zt(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
50
|
${i.join(`
|
|
51
|
-
`)}`;return await
|
|
52
|
-
${o}`),o}}await
|
|
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
|
|
51
|
+
`)}`;return await c.debug(`[haimati_write] \u51FA\u53C2: \u8DEF\u5F84\u4E0D\u5B58\u5728
|
|
52
|
+
${o}`),o}}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?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 zt(e,t.category,t.title,i,t.content,!1),o)break;await c.warn(`[haimati_write] \u9501\u83B7\u53D6\u5931\u8D25\uFF0C\u91CD\u8BD5\u7B2C ${d+1} \u6B21`)}catch(f){let l=f instanceof Error?f.message:String(f);if(l.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw f;await c.warn(`[haimati_write] \u83B7\u53D6\u9501\u5F02\u5E38: ${l}, \u91CD\u8BD5\u7B2C ${d+1} \u6B21`)}if(o){if(r&&r.length>0){let f=await k(e);for(let l of r){let m=O(e,l);yt(f,m,o),await c.info(`[haimati_write] \u5EFA\u7ACB\u6587\u4EF6\u5173\u8054: ${m} -> #${o}`)}await z(e,f)}let d=`\u5DF2\u5199\u5165\u6D77\u9A6C\u4F53 #${o}
|
|
54
54
|
\u8DEF\u5F84: ${t.category}/${t.title}
|
|
55
|
-
\u7248\u672C: 1`;return await
|
|
56
|
-
${d}`),await
|
|
57
|
-
${d}`),d}let u="\u9519\u8BEF\uFF1A\u65E0\u6CD5\u5206\u914D\u5E8F\u53F7\uFF08\u9501\u7B49\u5F85\u8D85\u65F6\uFF09";return await
|
|
58
|
-
${u}`),u}catch(i){return await
|
|
59
|
-
${i}`),await
|
|
60
|
-
${
|
|
61
|
-
`),
|
|
62
|
-
`);for(let
|
|
63
|
-
`).filter(
|
|
64
|
-
`);return await
|
|
65
|
-
${
|
|
55
|
+
\u7248\u672C: 1`;return await c.debug(`[haimati_write] \u51FA\u53C2:
|
|
56
|
+
${d}`),await c.info(`[haimati_write] \u5199\u5165\u6210\u529F: #${o} (${t.category}/${t.title})`),d}let a=await S(e),s=jt(a,t.category,t.title);if(s){let d=`\u9519\u8BEF\uFF1A\u8BB0\u5FC6\u5DF2\u5B58\u5728 #${s.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:
|
|
57
|
+
${d}`),d}let u="\u9519\u8BEF\uFF1A\u65E0\u6CD5\u5206\u914D\u5E8F\u53F7\uFF08\u9501\u7B49\u5F85\u8D85\u65F6\uFF09";return await c.debug(`[haimati_write] \u51FA\u53C2:
|
|
58
|
+
${u}`),u}catch(i){return await j(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=A(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=I(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:
|
|
59
|
+
${i}`),await c.info("[haimati_search] \u641C\u7D22\u5931\u8D25: \u7D22\u5F15\u4E0D\u5B58\u5728"),i}try{let i=await S(e),o=t.keyword.trim(),a=t.match,s=t.limit??10,u=t.offset??0,d=await Ot(i,o,a,e,!0),f=d.length,l=d.slice(u,u+s);if(l.length===0){let y=`\u672A\u627E\u5230\u5305\u542B '${o}' \u7684\u8BB0\u5FC6`;return await c.debug(`[haimati_search] \u51FA\u53C2:
|
|
60
|
+
${y}`),await c.info("[haimati_search] \u641C\u7D22\u5B8C\u6210: \u672A\u627E\u5230\u5339\u914D"),y}let m=[],p=u+l.length<f,g=p?`${u+1}-${u+l.length}/${f}`:`${u+1}-${u+l.length}/${f}`;m.push(`\u627E\u5230 ${g} \u6761\u5339\u914D\uFF1A
|
|
61
|
+
`),p&&m.push(`\uFF08\u5982\u9700\u83B7\u53D6\u66F4\u591A\uFF0C\u8BF7\u4F7F\u7528 offset=${u+s} \u7EE7\u7EED\u7FFB\u9875\uFF09
|
|
62
|
+
`);for(let y of l){let w=await M(e,y.id),b=`${y.category}/${y.title}`,x="";w&&(x=w.content.split(`
|
|
63
|
+
`).filter(v=>v.trim()).slice(0,3).join(" | ").substring(0,150),x.length===150&&(x+="...")),m.push(`## ${b} [${y.id}]`),x&&m.push(`> ${x}`),m.push("")}let h=m.join(`
|
|
64
|
+
`);return await c.debug(`[haimati_search] \u51FA\u53C2:
|
|
65
|
+
${h}`),await c.info(`[haimati_search] \u641C\u7D22\u5B8C\u6210: \u627E\u5230 ${f} \u6761\u5339\u914D`),h}catch(i){return await j(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\u5173\u8054\u8BB0\u5FC6\u7684\u5B8C\u6574\u6B63\u6587"),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=A(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=I(e),i=t.replaceAll===!0,o=t.filePath||null,a=t.removeFilePath||null,s=!!t.oldString&&!!t.newString,u=o&&o.length>0||a&&a.length>0;if(!s&&!u)return await c.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(s&&i!==!0&&!t.oldString)return"\u9519\u8BEF\uFF1AoldString \u4E0D\u80FD\u4E3A\u7A7A";if(o&&o.length>0){let d=await Zt(e,o);if(d.length>0){let f=`\u9519\u8BEF\uFF1A\u4EE5\u4E0B\u6587\u4EF6/\u76EE\u5F55\u4E0D\u5B58\u5728\uFF0C\u8BF7\u786E\u8BA4\u8DEF\u5F84\u540E\u91CD\u8BD5
|
|
66
66
|
${d.join(`
|
|
67
|
-
`)}`;return await
|
|
68
|
-
${
|
|
69
|
-
\u8DEF\u5F84: ${m}`;return await
|
|
70
|
-
${
|
|
71
|
-
${i}`),i}try{let i=await
|
|
72
|
-
\u8DEF\u5F84: ${d}`;return await
|
|
73
|
-
${
|
|
74
|
-
${i}`),i}try{let i=await
|
|
75
|
-
${w}`),w}if(!
|
|
76
|
-
${w}`),w}let d=a.category,
|
|
77
|
-
\u65E7\u8DEF\u5F84: ${
|
|
78
|
-
\u65B0\u8DEF\u5F84: ${g}`;return await
|
|
79
|
-
${
|
|
80
|
-
${i}`),i}try{let i=await
|
|
81
|
-
`),d=0,
|
|
82
|
-
|
|
83
|
-
`;if(t.recursive){let g=i.filter(
|
|
84
|
-
`,
|
|
67
|
+
`)}`;return await c.debug(`[haimati_edit] \u51FA\u53C2: \u8DEF\u5F84\u4E0D\u5B58\u5728
|
|
68
|
+
${f}`),f}}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="${o?o.join(", "):"(\u65E0)"}", removeFilePath="${a?a.join(", "):"(\u65E0)"}", oldString="${t.oldString||"(\u65E0)"}", newString="${t.newString||"(\u65E0)"}"`),!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 d=await S(e),f=wt(t.query);if(!f)return"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let l=F(d,f);if(!l)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`;if(s){let g=await M(e,l.id);if(!g)return await c.debug("[haimati_edit] \u51FA\u53C2: \u4E66\u9875\u4E0D\u5B58\u5728"),`\u672A\u627E\u5230\u4E66\u9875: #${l.id.padStart(3,"0")}`;if(!g.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 #${l.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 h=i?g.content.replaceAll(t.oldString,t.newString):g.content.replace(t.oldString,t.newString),y=new Date().toLocaleString("zh-CN",{hour12:!1});await N(e,l.id,l.title,g.createdAt,y,h)}if(u){let g=await k(e);if(o&&o.length>0)for(let h of o){let y=O(e,h);yt(g,y,l.id),await c.info(`[haimati_edit] \u5EFA\u7ACB\u6587\u4EF6\u5173\u8054: ${y} -> #${l.id}`)}if(a&&a.length>0)for(let h of a){let y=O(e,h);Yt(g,y,l.id),await c.info(`[haimati_edit] \u79FB\u9664\u6587\u4EF6\u5173\u8054: ${y} x #${l.id}`)}await z(e,g)}let m=`${l.category}/${l.title}`,p=`\u5DF2\u66F4\u65B0\u6D77\u9A6C\u4F53 #${l.id.padStart(3,"0")}
|
|
69
|
+
\u8DEF\u5F84: ${m}`;return await c.debug(`[haimati_edit] \u51FA\u53C2:
|
|
70
|
+
${p}`),await c.info(`[haimati_edit] \u7F16\u8F91\u6210\u529F: #${l.id.padStart(3,"0")}`),p}catch(d){return await j(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=A(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=I(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:
|
|
71
|
+
${i}`),i}try{let i=await S(e),o=wt(t.query);if(!o)return"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let a=F(i,o);if(!a)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 Nt(e,a.id);let s=Tt(i,a.id);await U(e,s);let u=await k(e);Qt(u,a.id),await z(e,u),await c.info(`[haimati_delete] \u6E05\u7406\u6587\u4EF6\u5173\u8054: #${a.id}`);let d=`${a.category}/${a.title}`,f=`\u5DF2\u5220\u9664\u6D77\u9A6C\u4F53 #${a.id.padStart(3,"0")}
|
|
72
|
+
\u8DEF\u5F84: ${d}`;return await c.debug(`[haimati_delete] \u51FA\u53C2:
|
|
73
|
+
${f}`),await c.info(`[haimati_delete] \u5220\u9664\u6210\u529F: #${a.id.padStart(3,"0")} (${d})`),f}catch(i){return await j(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=A(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=I(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:
|
|
74
|
+
${i}`),i}try{let i=await S(e),o=wt(t.query);if(!o)return"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let a=F(i,o);if(!a)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 s=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 c.debug(`[haimati_move] \u51FA\u53C2:
|
|
75
|
+
${w}`),w}if(!s&&!u){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:
|
|
76
|
+
${w}`),w}let d=a.category,f=a.title,l=s||d,m=u||f,p=`${d}/${f}`,g=`${l}/${m}`,h=i.map(w=>w.id===a.id?{...w,category:l,title:m}:w);if(await U(e,h),u){let w=await M(e,a.id);if(w){let b=new Date().toLocaleString("zh-CN",{hour12:!1});await N(e,a.id,m,w.createdAt,b,w.content)}}let y=`\u5DF2\u79FB\u52A8\u6D77\u9A6C\u4F53 #${a.id}
|
|
77
|
+
\u65E7\u8DEF\u5F84: ${p}
|
|
78
|
+
\u65B0\u8DEF\u5F84: ${g}`;return await c.debug(`[haimati_move] \u51FA\u53C2:
|
|
79
|
+
${y}`),await c.info(`[haimati_move] \u79FB\u52A8\u6210\u529F: #${a.id} ${p} -> ${g}`),y}catch(i){return await j(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=A(n);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let r=I(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:
|
|
80
|
+
${i}`),i}try{let i=await S(e);if(t.category){let u=(await Rt(e)).split(`
|
|
81
|
+
`),d=0,f=[];for(let g of u){if(!g.trim())continue;let h=tt(g);if(g.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/))continue;let w=et(g);if(w&&(w==="/"?f[h]="":f[h]=w,f=f.slice(0,h+1),f.filter(Boolean).join("/")===t.category)){d=h;break}}let l=[],m=[];f=[];for(let g of u){if(!g.trim())continue;let h=tt(g),y=g.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(y){let b=y[1].trim(),x=y[2];if(h===d+1){let _=f.slice(1,h).filter(Boolean).join("/");_===t.category&&m.push({category:_,title:b,id:x})}continue}let w=et(g);w&&(w==="/"?f[h]="":f[h]=w,f=f.slice(0,h+1),h===d+1&&f.filter(Boolean).join("/")===t.category&&l.push(w))}let p=`## ${t.category}
|
|
82
|
+
|
|
83
|
+
`;if(t.recursive){let g=i.filter(y=>y.category===t.category||y.category.startsWith(t.category+"/")),h=new Map;for(let y of g){let b=y.category.slice(t.category.length+1).split("/")[0]||"(\u76F4\u63A5)";h.has(b)||h.set(b,[]),h.get(b).push(y)}for(let[y,w]of h)p+=`### ${y}/
|
|
84
|
+
`,p+=w.map(b=>`- ${b.title} - ${b.id.padStart(3,"0")}`).join(`
|
|
85
85
|
`)+`
|
|
86
86
|
|
|
87
|
-
`}else
|
|
88
|
-
`+
|
|
87
|
+
`}else l.length>0&&(p+=`**\u5B50\u5206\u7C7B\uFF1A**
|
|
88
|
+
`+l.map(g=>`- ${g}/`).join(`
|
|
89
89
|
`)+`
|
|
90
90
|
|
|
91
|
-
`),m.length>0&&(
|
|
91
|
+
`),m.length>0&&(p+=`**\u76F4\u63A5\u6761\u76EE\uFF1A**
|
|
92
92
|
`+m.map(g=>`- ${g.title} - ${g.id.padStart(3,"0")}`).join(`
|
|
93
|
-
`));if(t.detail){let g=t.recursive?i.filter(
|
|
93
|
+
`));if(t.detail){let g=t.recursive?i.filter(h=>h.category===t.category||h.category.startsWith(t.category+"/")):i.filter(h=>h.category===t.category);if(g.length>0)if(t.recursive){let h=`## ${t.category}
|
|
94
94
|
|
|
95
|
-
`,
|
|
96
|
-
`;for(let x of b){let
|
|
95
|
+
`,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){h+=`### ${w}/
|
|
96
|
+
`;for(let x of b){let _=await M(e,x.id);if(!_){h+=`- ${x.title} - ${x.id.padStart(3,"0")} (\u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728)
|
|
97
97
|
|
|
98
|
-
`;continue}
|
|
99
|
-
`,
|
|
98
|
+
`;continue}h+=`#### ${x.title} - ${x.id.padStart(3,"0")}
|
|
99
|
+
`,h+=T(x,_)+`
|
|
100
100
|
|
|
101
|
-
`}}
|
|
101
|
+
`}}p=h}else{p+=`
|
|
102
102
|
**\u8BE6\u7EC6\u5185\u5BB9\uFF1A**
|
|
103
103
|
|
|
104
|
-
`;for(let
|
|
104
|
+
`;for(let h of g){let y=await M(e,h.id);if(!y){p+=`- ${h.title} - ${h.id.padStart(3,"0")} (\u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728)
|
|
105
105
|
|
|
106
|
-
`;continue}
|
|
107
|
-
`,
|
|
106
|
+
`;continue}p+=`#### ${h.title} - ${h.id.padStart(3,"0")}
|
|
107
|
+
`,p+=T(h,y)+`
|
|
108
108
|
|
|
109
|
-
`}}}return await
|
|
110
|
-
${
|
|
109
|
+
`}}}return await c.debug(`[haimati_list] \u51FA\u53C2:
|
|
110
|
+
${p}`),await c.info(`[haimati_list] \u5217\u51FA\u6210\u529F: ${t.category}${t.detail?" (\u8BE6\u7EC6\u6A21\u5F0F)":""}`),p}if(t.detail){let s=`## \u6D77\u9A6C\u4F53\u7D22\u5F15\u8BE6\u60C5
|
|
111
111
|
|
|
112
|
-
`,u=new Map;for(let
|
|
112
|
+
`,u=new Map;for(let f of i){let l=f.category.split("/")[0]||"(\u65E0\u5206\u7C7B)";u.has(l)||u.set(l,[]),u.get(l).push(f)}for(let[f,l]of u){s+=`### ${f}/
|
|
113
113
|
|
|
114
|
-
`;for(let m of
|
|
115
|
-
`,
|
|
114
|
+
`;for(let m of l){let p=await M(e,m.id);if(!p){await c.warn(`[haimati_list] detail: #${m.id} (${m.title}) \u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728`);continue}s+=`#### ${m.category}/${m.title} - ${m.id.padStart(3,"0")}
|
|
115
|
+
`,s+=T(m,p)+`
|
|
116
116
|
|
|
117
|
-
`}}let d=
|
|
118
|
-
${d}`),await
|
|
117
|
+
`}}let d=s;return await c.debug(`[haimati_list] \u51FA\u53C2:
|
|
118
|
+
${d}`),await c.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8 (\u8BE6\u7EC6\u6A21\u5F0F)"),d}let a=`## \u6D77\u9A6C\u4F53\u7D22\u5F15
|
|
119
119
|
|
|
120
|
-
${
|
|
121
|
-
${a}`),await
|
|
120
|
+
${pt(i)||"(\u7A7A)"}`;return await c.debug(`[haimati_list] \u51FA\u53C2:
|
|
121
|
+
${a}`),await c.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8"),a}catch(i){return await j(i,"haimati_list")}}})}}import{readFile as Te,rm as Re}from"node:fs/promises";import{basename as q,dirname as R,join as Pt}from"node:path";import{fileURLToPath as We}from"node:url";var Ne="opencode-haimati";function ne(t,n){if(!n)return;let e=new AbortController,r=setTimeout(()=>e.abort(),1e4);Oe(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 Oe(t){let n=await qe(Ne);if(!n)return{updated:!1};let e=await bt(Pt(n,"package.json"));if(!e?.name||!e.version)return{updated:!1};let r=await ze(e.name,t);if(!r||!Je(r,e.version))return{updated:!1};let i=await He(n,e.name);if(!i)return{updated:!1};try{await Re(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 qe(t){let n=R(We(import.meta.url));for(;;){if((await bt(Pt(n,"package.json")))?.name===t)return q(n)==="dist"?R(n):n;let r=R(n);if(r===n)return;n=r}}async function He(t,n){let e=R(t),r=q(e).startsWith("@")?R(e):e;if(q(r)!=="node_modules")return;let i=R(r),o=await bt(Pt(i,"package.json")),a=Ue(i,n)??o?.dependencies?.[n];if(!(!a||!Ge(a)))return i}function Ue(t,n){if(n.startsWith("@")){let[i,o]=n.split("/");if(!i||!o||q(R(t))!==i)return;let a=`${o}@`,s=q(t);return s.startsWith(a)?s.slice(a.length):void 0}let e=`${n}@`,r=q(t);return r.startsWith(e)?r.slice(e.length):void 0}function Ge(t){let n=t.trim();return n?!!(n==="latest"||n==="*"||/^[~^]/.test(n)||/^(?:>=|>|<=|<)/.test(n)||/\s+(?:\|\||-|[<>=])\s+/.test(n)):!1}async function bt(t){try{let n=JSON.parse(await Te(t,"utf-8"));return n&&typeof n=="object"?n:void 0}catch{return}}async function ze(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 Je(t,n){let e=ee(t),r=ee(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 s=/^\d+$/.test(o)?Number(o):void 0,u=/^\d+$/.test(a)?Number(a):void 0;return s!==void 0&&u!==void 0?s>u:s!==void 0?!1:u!==void 0?!0:o>a}return!1}function ee(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 Ke="2026-06-02 23:56:01",ie=!1;function Be(t){return t.type==="text"&&t.ignored!==!0}var di=async t=>{await Ct(),ie||(ie=!0,await c.debug(`[HaimatiPlugin] \u4EE3\u7801\u6700\u540E\u4FEE\u6539\u65E5\u671F: ${Ke}`));let n=B(t.directory),e=te(),r=new Set,i=new Set,o=new Set,a=new Map,s=1e4,u=new Set,d=new Map;return ne(t,n.autoUpdate!==!1),Xt(t.directory).then(f=>{f>0&&c.info(`[HaimatiPlugin] \u542F\u52A8\u65F6\u6E05\u7406\u4E86 ${f} \u4E2A\u4E0D\u5B58\u5728\u7684\u6587\u4EF6\u5173\u8054`)}).catch(f=>{c.warn(`[HaimatiPlugin] \u6E05\u7406\u8FC7\u671F\u6587\u4EF6\u5173\u8054\u5931\u8D25: ${f instanceof Error?f.message:String(f)}`)}),{tool:e,event:async({event:f})=>{if(f.type==="message.updated"&&f.properties.info.role==="assistant"){let l=f.properties.info;if(l.finish==="stop"&&!r.has(l.id)){if(r.add(l.id),o.has(l.id)){o.delete(l.id);return}if(i.has(l.sessionID))return;let m=a.get(l.sessionID);if(m&&Date.now()<m)return;n.autoWrite===!0&&(i.add(l.sessionID),c.info(`[autoWrite] \u5F00\u59CB\u5F02\u6B65\u8BB0\u5FC6\u5199\u5165 session=${l.sessionID}`),t.client.session.prompt({path:{id:l.sessionID},body:{parts:[{type:"text",text:`\u56DE\u987E\u5F53\u524D\u4F1A\u8BDD\uFF0C\u5BF9\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u8FDB\u884C\u7EF4\u62A4\u3002
|
|
122
122
|
|
|
123
123
|
\u4F60\u7684\u804C\u8D23\uFF1A
|
|
124
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
|
|
@@ -134,26 +134,29 @@ ${a}`),await l.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8"),a}c
|
|
|
134
134
|
- \u9519\u8BEF\u6216\u8FC7\u671F\u7684\u4FE1\u606F\u76F4\u63A5\u5220\u9664\u6216\u4FEE\u6539
|
|
135
135
|
- \u4E0D\u786E\u5B9A\u5206\u7C7B\u65F6\uFF0C\u5148\u7528 haimati_list \u67E5\u770B\u73B0\u6709\u7ED3\u6784
|
|
136
136
|
|
|
137
|
-
\u5982\u679C\u6CA1\u4EC0\u4E48\u53EF\u505A\u7684\uFF0C\u56DE\u590D"\u65E0"`}]}}).then(
|
|
137
|
+
\u5982\u679C\u6CA1\u4EC0\u4E48\u53EF\u505A\u7684\uFF0C\u56DE\u590D"\u65E0"`}]}}).then(p=>{let g=p?.data?.info?.id;g&&o.add(g),i.delete(l.sessionID),a.set(l.sessionID,Date.now()+s),c.info(`[autoWrite] AI\u8BB0\u5FC6\u5199\u5165\u5B8C\u6210 session=${l.sessionID}`)}).catch(p=>{i.delete(l.sessionID),a.set(l.sessionID,Date.now()+s);let g=p instanceof Error?p.message:String(p);c.error(`[autoWrite] \u5931\u8D25: ${g}`)})),await c.debug(`[message.updated] AI\u56DE\u590D\u7ED3\u675F messageID=${l.id}`)}}},"chat.message":async(f,l)=>{let m=l.parts.filter(Be);if(m.length!==0){if(u.has(l.message.sessionID)){l.parts.unshift({id:`prt_auto_reminder_${Date.now()}`,sessionID:m[0].sessionID??l.message.sessionID,messageID:m[0].messageID??l.message.id,type:"text",text:`<\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>
|
|
138
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
|
|
139
|
-
</\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>`,synthetic:!0}),await
|
|
139
|
+
</\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>`,synthetic:!0}),await c.debug("[chat.message] \u6CE8\u5165\u7B80\u77ED\u786E\u8BA4\u63D0\u793A");return}u.add(l.message.sessionID),l.parts.unshift({id:`prt_auto_reminder_${Date.now()}`,sessionID:m[0].sessionID??l.message.sessionID,messageID:m[0].messageID??l.message.id,type:"text",text:`<\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>
|
|
140
140
|
\u4F60\u6709\u4E00\u5957\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u63D2\u4EF6\u53EF\u7528
|
|
141
141
|
|
|
142
142
|
1\u3001\u5DE5\u4F5C\u524D\u8BFB\u53D6\u6240\u6709\u76F8\u5173\u7684\u6D77\u9A6C\u4F53\u8BB0\u5FC6
|
|
143
143
|
- \u786E\u8BA4\u6D77\u9A6C\u4F53\u4E2D\u662F\u5426\u5B58\u5728\u76F8\u5173\u8BB0\u5FC6\uFF0C\u5982\u679C\u5B58\u5728\uFF0C\u5219\u8BFB\u53D6\u5168\u90E8\u6D77\u9A6C\u4F53\u4E2D\u7684\u76F8\u5173\u8BB0\u5FC6
|
|
144
144
|
|
|
145
|
-
2\u3001\
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
- \u5C06\u5DE5\u4F5C\u4E2D\u5B66\u4E60\u7684\u65B0\u77E5\u8BC6\u3001\u7ECF\u9A8C\u548C\u9879\u76EE\u6587\u4EF6\u5173\u8054\u5728\u4E00\u8D77\u5199\u5165\u6D77\u9A6C\u4F53\u8BB0\u5FC6
|
|
149
|
-
- \u7F16\u8F91\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u65F6\uFF0C\u68C0\u67E5\u8BB0\u5FC6\u662F\u5426\u548C\u9879\u76EE\u6587\u4EF6\u5173\u8054\u5728\u4E00\u8D77\uFF0C\u5982\u679C\u6CA1\u6709\u5C31\u8981\u8C03\u6574
|
|
145
|
+
2\u3001\u5DE5\u4F5C\u7ED3\u675F\u540E\u603B\u7ED3\u8BB0\u5FC6\uFF1A
|
|
146
|
+
- \u5C06\u5DE5\u4F5C\u4E2D\u5B66\u4E60\u7684\u65B0\u77E5\u8BC6\u65B0\u7ECF\u9A8C\u548C\u76F8\u5173\u6587\u4EF6\u5173\u8054\u5728\u4E00\u8D77\u5199\u5165\u6D77\u9A6C\u4F53\u8BB0\u5FC6
|
|
147
|
+
- \u7F16\u8F91\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u65F6\uFF0C\u68C0\u67E5\u8BB0\u5FC6\u662F\u5426\u548C\u76F8\u5173\u6587\u4EF6\u5173\u8054\u5728\u4E00\u8D77\uFF0C\u5982\u679C\u6CA1\u6709\u5C31\u8981\u8C03\u6574
|
|
150
148
|
- \u4FEE\u6539\u9519\u8BEF\u7684\u6D77\u9A6C\u4F53\u8BB0\u5FC6
|
|
151
149
|
- \u5220\u9664\u8FC7\u671F\u7684\u4FE1\u606F
|
|
152
150
|
- \u6574\u5408\u91CD\u590D\u7684\u8BB0\u5FC6
|
|
153
151
|
- \u5982\u679C\u5B58\u5728\u5206\u7C7B\u4E0D\u5408\u7406\u7684\uFF0C\u5219\u8C03\u6574
|
|
154
152
|
- \u5728\u8282\u7EA6TOKEN\u7684\u60C5\u51B5\u4E0B\uFF0C\u7CBE\u7B80\u6D77\u9A6C\u4F53\u8BB0\u5FC6
|
|
155
|
-
</\u6D77\u9A6C\u4F53\u81EA\u52A8\u63D0\u793A>`,synthetic:!0}),await
|
|
153
|
+
</\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(f,l)=>{if(f.tool==="haimati_read"){try{let p=f.args?.query;if(typeof p!="string")return;let g=$t(p);if(!g)return;let h=t.directory;for(let y of g){let w=await M(h,y);w&&d.set(y,w.updatedAt)}await c.debug(`[tool.execute.after] \u8BB0\u5F55 haimati_read \u7248\u672C: ${g.join(",")}`)}catch(p){await c.error(`[tool.execute.after] haimati_read \u8BB0\u5F55\u7248\u672C\u5931\u8D25: ${p instanceof Error?p.message:String(p)}`)}return}if(f.tool!=="read")return;let m=f.args?.filePath;if(!(!m||typeof m!="string"))try{let p=t.directory,g=O(p,m),h=await k(p);if(Object.keys(h).length===0)return;let y=Vt(h,g);if(y.length===0)return;let w=await S(p),b=[];for(let x of y){let _=F(w,x);if(!_)continue;let v=await M(p,_.id);if(!v)continue;let xt=J(h,_.id);if(xt.length>0&&(v.systemMeta={...v.systemMeta,file_paths:xt.join(", ")}),d.get(x)===v.updatedAt)continue;let re=T(_,v);b.push(`===== #${_.id.padStart(3,"0")} =====
|
|
154
|
+
${re}`),d.set(x,v.updatedAt)}b.length>0&&(l.output+=`
|
|
156
155
|
|
|
157
156
|
<system-reminder>
|
|
158
|
-
${
|
|
159
|
-
|
|
157
|
+
\u6587\u4EF6 ${g} \u5173\u8054\u4E86\u4EE5\u4E0B\u6D77\u9A6C\u4F53\u8BB0\u5FC6\uFF1A
|
|
158
|
+
|
|
159
|
+
${b.join(`
|
|
160
|
+
|
|
161
|
+
`)}
|
|
162
|
+
</system-reminder>`,await c.debug(`[tool.execute.after] \u6CE8\u5165${b.length}\u6761\u8BB0\u5FC6: ${g}`))}catch(p){await c.warn(`[tool.execute.after] \u68C0\u67E5\u6587\u4EF6\u5173\u8054\u5931\u8D25: ${p instanceof Error?p.message:String(p)}`)}}}};export{di as HaimatiPlugin};
|
package/dist/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "opencode-haimati",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "2.0.0",
|
|
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": "
|
|
3
|
+
"version": "2.0.0",
|
|
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",
|