opencode-haimati 1.2.2 → 1.2.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -30,12 +30,28 @@ bun add -g opencode-haimati
30
30
  }
31
31
  ```
32
32
 
33
- 在项目根目录创建 `opencode-haimati.conf`(可选):
33
+ 支持三级配置(优先级从低到高):
34
34
 
35
- ```ini
36
- haimati-path: .haimati
35
+ 1. **全局**:`~/.config/opencode/haimati.jsonc` 或 `haimati.json`
36
+ 2. **自定义**:`$OPENCODE_CONFIG_DIR/haimati.jsonc` 或 `haimati.json`(如果环境变量存在)
37
+ 3. **项目**:`.opencode/haimati.jsonc` 或 `haimati.json`
38
+
39
+ 配置示例(haimati.jsonc):
40
+ ```jsonc
41
+ {
42
+ // 海马体存储路径(相对项目根目录,或绝对路径)
43
+ "haimatiPath": ".haimati",
44
+
45
+ // 日志配置(仅全局配置有效)
46
+ "log": {
47
+ "level": "info", // debug、info、warn、error
48
+ "logRetentionDays": 180 // 日志保留天数
49
+ }
50
+ }
37
51
  ```
38
52
 
53
+ 首次运行时自动创建全局配置模板。
54
+
39
55
  ## 目录结构
40
56
 
41
57
  ```
@@ -50,13 +66,13 @@ haimati-path: .haimati
50
66
 
51
67
  | 工具 | 说明 |
52
68
  |------|------|
53
- | `haimati_read` | 读取记忆(序号查询,支持分页) |
69
+ | `haimati_read` | 读取记忆(单条/批量,支持分页) |
54
70
  | `haimati_write` | 写入记忆(不允许覆盖已存在) |
55
71
  | `haimati_search` | 搜索(标题/分类/内容,match必填) |
56
- | `haimati_edit` | 部分修改(需 version 并发控制) |
57
- | `haimati_move` | 修改分类路径 |
72
+ | `haimati_edit` | 部分修改(支持批量,需 version 并发控制) |
73
+ | `haimati_move` | 修改分类路径和/或标题 |
58
74
  | `haimati_delete` | 删除记忆 |
59
- | `haimati_list` | 列出索引 |
75
+ | `haimati_list` | 列出索引(按分类浏览,支持详细内容) |
60
76
 
61
77
  ## 使用示例
62
78
 
@@ -64,14 +80,33 @@ haimati-path: .haimati
64
80
  // 写入(title 不能以 " - 序号" 结尾)
65
81
  haimati_write({ category: "xxx项目/签章", title: "签章服务WS通信机制", content: "..." })
66
82
 
67
- // 读取
83
+ // 读取(单条)
68
84
  haimati_read({ query: "086" })
69
85
 
86
+ // 读取(批量:逗号分隔或范围)
87
+ haimati_read({ query: "086,087,088" })
88
+ haimati_read({ query: "086-090" })
89
+
70
90
  // 搜索
71
91
  haimati_search({ keyword: "WebSocket", match: "or" })
72
92
 
73
93
  // 修改(先 read 获取 version)
74
- haimati_edit({ query: "086", offsetBegin: 3, offsetEnd: 5, content: "新内容", version: 1 })
94
+ // 单处修改
95
+ haimati_edit({
96
+ query: "086",
97
+ version: 1,
98
+ edits: [{ offsetBegin: 3, offsetEnd: 5, content: "新内容" }]
99
+ })
100
+
101
+ // 批量修改多处(自动从后往前执行,避免行号变化影响)
102
+ haimati_edit({
103
+ query: "086",
104
+ version: 1,
105
+ edits: [
106
+ { offsetBegin: 3, offsetEnd: 5, content: "新内容1" },
107
+ { offsetBegin: 10, offsetEnd: 15, content: "新内容2" }
108
+ ]
109
+ })
75
110
 
76
111
  // 移动
77
112
  haimati_move({ query: "086", newCategory: "xxx项目/客户端" })
@@ -79,19 +114,35 @@ haimati_move({ query: "086", newCategory: "xxx项目/客户端" })
79
114
  // 删除
80
115
  haimati_delete({ query: "086" })
81
116
 
82
- // 列出
83
- haimati_list({ category: "xxx项目", recursive: true })
117
+ // 列出(树形索引)
118
+ haimati_list()
119
+
120
+ // 列出(指定分类,含详细内容)
121
+ haimati_list({ category: "xxx项目", recursive: true, detail: true })
84
122
  ```
85
123
 
124
+ ### haimati_edit 使用说明
125
+
126
+ **关键特性**:
127
+ - 支持单处和批量修改,统一使用 `edits` 数组参数
128
+ - 自动按行号从后往前执行,避免行号变化影响
129
+ - 版本并发控制,防止冲突
130
+
131
+ **参数验证**:
132
+ - `edits` 数组不能为空
133
+ - 行号范围不能重叠(例如 `[3,5]` 和 `[4,6]` 重叠)
134
+ - 行号范围必须在有效范围内(1 到总行数)
135
+
136
+ **执行顺序**:
137
+ - 系统自动按 `offsetBegin` 降序执行(从后往前)
138
+ - 例如:`edits=[{offsetBegin:3,offsetEnd:5},{offsetBegin:10,offsetEnd:15}]`
139
+ - 实际执行顺序:先修改第 10-15 行,再修改第 3-5 行
140
+
86
141
  ## 日志
87
142
 
88
143
  日志位于:`~/.opencode-haimati/log/{yyyy-MM-dd}.log`(按天轮转)
89
144
 
90
- 日志配置位于:`~/.opencode-haimati/log.conf`
91
- ```
92
- level: info # 日志级别:debug、info、warn、error
93
- log_retention_days: 180 # 日志保留天数
94
- ```
145
+ 日志配置整合在 `~/.config/opencode/haimati.jsonc` 的 `log` 字段中。
95
146
 
96
147
  ## 依赖
97
148
 
package/dist/index.js CHANGED
@@ -1,36 +1,62 @@
1
- import{tool as x}from"@opencode-ai/plugin";import P from"path";import st from"os";import S from"fs";var A=".haimati",nt="\u7D22\u5F15.md";var it="next-id.txt",rt="log.conf";var ot="opencode-haimati.conf",at="haimati-path";function Mt(t){let i=P.join(t,ot);if(!S.existsSync(i))return null;try{let a=S.readFileSync(i,"utf-8").split(`
2
- `);for(let e of a){let r=e.trim();if(!r||r.startsWith("#"))continue;let c=r.match(/^([^:]+):\s*(.+)$/);if(c){let o=c[1].trim(),f=c[2].trim();if(o===at&&f){let u=f.match(/^\$\{(\w+)\}$/);if(u){let l=process.env[u[1]];return l?P.resolve(t,l):(console.warn(`[haimati] \u73AF\u5883\u53D8\u91CF ${u[1]} \u672A\u5B9A\u4E49\u6216\u503C\u4E3A\u7A7A`),null)}return P.resolve(t,f)}}}}catch(n){console.error("[haimati] \u8BFB\u53D6\u914D\u7F6E\u6587\u4EF6\u5931\u8D25:",n)}return null}function L(t){let i=Mt(t);return i||P.join(t,A)}function I(t){return P.join(L(t),nt)}function q(t){return P.join(L(t),it)}function V(t){return P.join(L(t),".lock")}function Y(t){return P.join(L(t),"\u4E66\u9875")}function M(t,i){let n=parseInt(i,10),a=Math.floor((n-1)/50)*50+1,e=a+50-1,r=`${String(a).padStart(3,"0")}-${String(e).padStart(3,"0")}`;return P.join(Y(t),r)}function N(t,i){let n=String(parseInt(i,10)).padStart(3,"0");return P.join(M(t,i),`${n}.md`)}function X(){let t=st.homedir();return P.join(t,".opencode-haimati","log")}function Ct(){let t=st.homedir();return P.join(t,".opencode-haimati",rt)}function z(){let t=Ct(),i={level:"info",logRetentionDays:180};if(!S.existsSync(t)){try{let n=P.dirname(t);S.existsSync(n)||S.mkdirSync(n,{recursive:!0}),S.writeFileSync(t,`# \u65E5\u5FD7\u7EA7\u522B\uFF1Adebug\u3001info\u3001warn\u3001error \uFF0C\u9ED8\u8BA4info
3
- level: info
4
- # \u65E5\u5FD7\u4FDD\u5B58\u5929\u6570\uFF0C\u9ED8\u8BA4 180 \u5929
5
- log_retention_days: 180
6
- `,"utf-8")}catch(n){console.error("[haimati] \u521B\u5EFA\u65E5\u5FD7\u914D\u7F6E\u6587\u4EF6\u5931\u8D25:",n)}return i}try{let a=S.readFileSync(t,"utf-8").split(`
7
- `),e=i.level,r=i.logRetentionDays;for(let c of a){let o=c.trim();if(!o||o.startsWith("#"))continue;let f=o.match(/^([^:]+):\s*(.+)$/);if(f){let u=f[1].trim(),l=f[2].trim();if(u==="level")["debug","info","warn","error"].includes(l)&&(e=l);else if(u==="log_retention_days"){let m=parseInt(l,10);!isNaN(m)&&m>0&&(r=m)}}}return{level:e,logRetentionDays:r}}catch(n){return console.error("[haimati] \u8BFB\u53D6\u65E5\u5FD7\u914D\u7F6E\u5931\u8D25:",n),i}}function D(t){return S.promises.mkdir(t,{recursive:!0}).then(()=>{})}function $(t){return S.promises.access(t).then(()=>!0).catch(()=>!1)}import ct from"fs";import Tt from"path";import{promisify as ft}from"util";var lt=ft(ct.readFile),Ft=ft(ct.writeFile);function R(t){let i=0,n=0,a=t.length;for(;n<a;)if(t[n]==="\u2502"&&n+3<a&&t.slice(n+1,n+4)===" ")i++,n+=4;else if(t.slice(n,n+4)===" ")i++,n+=4;else{if((t[n]==="\u251C"||t[n]==="\u2514")&&n+3<a&&t.slice(n+1,n+4)==="\u2500\u2500 ")break;break}return i}function j(t){let n=t.trim().replace(/^[│├└─\s]+/,"").trim();return n==="/"?"/":!n.endsWith("/")||(n=n.slice(0,-1),!n)?null:n}function At(t){let i=[],n=t.split(`
8
- `),a=[];for(let e of n){if(!e.trim())continue;let r=R(e),c=e.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(c){let o=c[1].trim(),f=String(parseInt(c[2],10)),l=a.slice(0,r).filter(m=>m!=="").join("/");i.push({id:f,category:l,title:o})}else{let o=j(e);if(o)if(o==="/"){a[r]="";for(let f=r+1;f<a.length;f++)delete a[f]}else{a[r]=o;for(let f=r+1;f<a.length;f++)delete a[f]}}}return i}function C(t,i){return t.find(n=>n.id===i)||null}function Q(t,i,n){return t.find(a=>a.category===i&&a.title===n)||null}function ut(t,i){return t.filter(n=>n.id!==i)}function Z(t){if(t.length===0)return"";let i={name:"/",children:[],entry:null};for(let e of t){let r=e.category.split("/"),c=i;for(let f=0;f<r.length;f++){let u=r[f];if(!u)continue;let l=c.children.find(m=>m.name===u);l||(l={name:u,children:[],entry:null},c.children.push(l)),c=l}let o={name:e.id,children:[],entry:e};c.children.push(o)}function n(e){e.children.sort((r,c)=>r.name.localeCompare(c.name,void 0,{sensitivity:"base"}));for(let r of e.children)n(r)}n(i);function a(e,r,c){let o=[],f=r+(c?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "),u=e.name==="/"?"/":e.name+"/";o.push(`${f}${u}`),r=r+(c?" ":"\u2502 ");let l=e.children.filter(g=>g.entry===null),m=e.children.filter(g=>g.entry!==null),p=[...l,...m];for(let g=0;g<p.length;g++){let d=p[g],y=g===p.length-1;if(d.entry){let h=d.entry.id.padStart(3,"0"),E=r+(y?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ");o.push(`${E}${d.entry.title} - ${h}`)}else o.push(...a(d,r,y))}return o}return a(i,"",!0).join(`
9
- `)}async function b(t){let i=I(t);if(!await $(i))return[];let n=await lt(i,"utf-8");return At(n)}async function T(t,i){let n=Tt.join(t,A);await $(n)||await D(n);let a=Z(i),e=I(t);await Ft(e,a,"utf-8")}async function mt(t){let i=I(t);return await $(i)?lt(i,"utf-8"):""}import W from"fs";import{promisify as B}from"util";var qt=B(W.readFile),Nt=B(W.writeFile),Rt=B(W.unlink),dt=B(W.mkdir);async function k(t,i){let n=N(t,i);if(!await $(n))return null;let e=(await qt(n,"utf-8")).split(`
10
- `);if(e.length<4)return null;let r="------system------",c=Math.max(0,e.length-5),o=-1;for(let g=e.length-1;g>=c;g--)if(e[g].trim()===r){o=g;break}if(o===-1){if(e.length>=3&&e[2].startsWith("version:")&&/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/.test(e[1])){let h=e[0],E=e[1],w=parseInt(e[2].substring(8).trim(),10)||1,v=e.slice(3).join(`
11
- `);return{title:h,createdAt:E,content:v,version:w}}let d=e[0],y=e.join(`
12
- `);return{title:d,createdAt:"",content:y,version:1}}if(o+3>=e.length)return null;let f=e.slice(0,o).join(`
13
- `),u=e[o+1],l=e[o+2],m=e[o+3],p=parseInt(m.substring(8).trim(),10)||1;return{title:u,createdAt:l,content:f,version:p}}async function F(t,i,n,a,e,r=1){let c=Y(t);await $(c)||await dt(c,{recursive:!0});let o=M(t,i);await $(o)||await dt(o,{recursive:!0});let f=N(t,i),l=`------system------
14
- ${n}
15
- ${a}
16
- version:${r}`,m=e?`${e}
17
- ${l}`:l;await Nt(f,m,"utf-8")}async function ht(t,i){let n=N(t,i);return await $(n)?(await Rt(n),!0):!1}function gt(t,i){if(i===0)return 0;let n=1,a=0;for(;a<t.length;){if(t[a]===`
18
- `){if(n===i)return a+1;n++}a++}return a}function yt(t,i,n,a){let e=i===1?0:gt(t,i-1),r=gt(t,n),o=(r<t.length?t.substring(r):"").startsWith(`
19
- `),f=r<t.length&&!a.endsWith(`
20
- `)&&!o;return t.substring(0,e)+a+(f?`
21
- `:"")+t.substring(r)}async function tt(t,i,n,a,e=!1){let r=i.toLowerCase().split(/\s+/).filter(o=>o.length>0);if(r.length===0)return[];let c=[];for(let o of t){let f=o.title.toLowerCase(),u=o.category.toLowerCase(),l=o.id.toLowerCase(),m=0,p=0;for(let d of r)(f.includes(d)||u.includes(d)||l.includes(d))&&m++;if(e&&a){let d=await k(a,o.id);if(d&&d.content){let y=d.content.toLowerCase();for(let h of r)y.includes(h)&&p++}}let g=m+p;n==="and"?g>=r.length&&c.push({entry:o,score:g}):(m>0||e&&p>0)&&c.push({entry:o,score:g})}return c.sort((o,f)=>f.score-o.score),c.map(o=>o.entry)}import It from"fs";import{promisify as bt}from"util";import pt from"fs";import{promisify as wt}from"util";var Wt=wt(pt.writeFile),Bt=wt(pt.unlink);async function $t(t){let i=L(t);await $(i)||await D(i);let n=V(t),a=Date.now(),e=50+Math.random()*20;for(;await $(n);){if(Date.now()-a>5e3)return!1;await new Promise(r=>setTimeout(r,e))}return await Wt(n,String(process.pid),"utf-8"),!0}async function xt(t){let i=V(t);await $(i)&&await Bt(i)}import G from"fs";import et from"path";import{promisify as H}from"util";var Ot=H(G.appendFile),Gt=H(G.readdir),Ht=H(G.unlink),Ut=H(G.stat),_t={debug:0,info:1,warn:2,error:3};function _(t,i=5e3){if(t.length<=i)return t;let n=Math.floor((i-20)/2);return t.substring(0,n)+"...(\u7701\u7565"+(t.length-i)+"\u5B57\u7B26)..."+t.substring(t.length-n)}function Kt(t){let i=t.getFullYear(),n=String(t.getMonth()+1).padStart(2,"0"),a=String(t.getDate()).padStart(2,"0");return`${i}-${n}-${a}`}function Vt(t){let i=t.getFullYear(),n=String(t.getMonth()+1).padStart(2,"0"),a=String(t.getDate()).padStart(2,"0"),e=String(t.getHours()).padStart(2,"0"),r=String(t.getMinutes()).padStart(2,"0"),c=String(t.getSeconds()).padStart(2,"0");return`${i}-${n}-${a} ${e}:${r}:${c}`}function Yt(){let t=Kt(new Date);return et.join(X(),`${t}.log`)}async function Xt(t,i){try{let n=et.dirname(t);await $(n)||await D(n),await Ot(t,i+`
22
- `,"utf-8")}catch(n){console.error("[haimati] \u5199\u5165\u65E5\u5FD7\u6587\u4EF6\u5931\u8D25:",n)}}async function Et(){try{let t=z(),i=X();if(!await $(i))return;let n=await Gt(i),e=new Date().getTime()-t.logRetentionDays*24*60*60*1e3;for(let r of n){if(!r.match(/^\d{4}-\d{2}-\d{2}\.log$/))continue;let c=et.join(i,r);(await Ut(c)).mtime.getTime()<e&&await Ht(c)}}catch(t){console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",t)}}async function O(t,i,n){try{let a=z();if(_t[t]<_t[a.level])return;let r=Vt(new Date),c=n?`[${n}] `:"",o=`[${r}] [${t.toUpperCase()}] ${c}${i}`,f=o.length>5e3?_(o):o;await Xt(Yt(),f),Et().catch(u=>{console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",u)})}catch(a){console.error("[haimati] \u65E5\u5FD7\u8BB0\u5F55\u5931\u8D25:",a)}}var s={debug(t,i){return O("debug",t,i)},info(t,i){return O("info",t,i)},warn(t,i){return O("warn",t,i)},error(t,i){return O("error",t,i)}};async function Pt(){await Et()}var zt=bt(It.readFile),Qt=bt(It.writeFile);async function Zt(t){let i=q(t);if(!await $(i))return 1;let a=(await zt(i,"utf-8")).trim(),e=parseInt(a,10);return!isNaN(e)&&e>0?e:1}async function Jt(t){let i=q(t);if(await $(i))return;let n=await b(t),a=0;for(let e of n){let r=parseInt(e.id,10);r>a&&(a=r)}await vt(t,a+1)}async function vt(t,i){let n=L(t);await $(n)||await D(n);let a=q(t);await Qt(a,String(i),"utf-8")}async function St(t,i,n,a,e,r=!1){if(/ - \d{3}$/.test(n))throw await s.warn(`[allocateIdWithLock] title \u683C\u5F0F\u4E0D\u5408\u89C4: "${n}", \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 s.info(`[allocateIdWithLock] \u5F00\u59CB\u5206\u914D\u5E8F\u53F7: category="${i}", title="${n}"`),!await $t(t))return await s.warn(`[allocateIdWithLock] \u83B7\u53D6\u9501\u5931\u8D25: category="${i}", title="${n}"`),null;await s.debug(`[allocateIdWithLock] \u83B7\u53D6\u9501\u6210\u529F: category="${i}", title="${n}"`);try{await Jt(t);let c=await b(t),o=c.find(m=>m.category===i&&m.title===n);if(o){if(!r)throw new Error(`\u8BB0\u5FC6\u5DF2\u5B58\u5728: ${i}/${n}\uFF0C\u5982\u9700\u66F4\u65B0\u8BF7\u4F7F\u7528 haimati_edit \u5DE5\u5177`);let m=await k(t,o.id),p=m?m.createdAt:a,g=m?m.version+1:1;return await F(t,o.id,n,p,e,g),await s.info(`[allocateIdWithLock] \u66F4\u65B0\u5DF2\u6709\u6761\u76EE: #${o.id} ${i}/${n}, \u65B0\u7248\u672C: ${g}`),null}let f=await Zt(t),u=String(f).padStart(3,"0");await F(t,u,n,a,e,1);let l={id:u,category:i,title:n};return c.push(l),await T(t,c),await vt(t,f+1),await s.info(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u6210\u529F: #${u} ${i}/${n}`),u}catch(c){let o=c instanceof Error?c.message:String(c);if(await s.error(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u5931\u8D25: ${o}`),o.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw c;return null}finally{await xt(t)}}function Lt(){return{haimati_read:x({description:`\u4ECE\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u8BFB\u53D6\u8BB0\u5FC6\u5185\u5BB9\u3002\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\u8BB0\u5FC6\uFF0C\u652F\u6301\u5206\u9875\u8BFB\u53D6\u3002
1
+ import{tool as x}from"@opencode-ai/plugin";import C from"path";import wt from"os";import O from"fs";var st=".haimati",ct="\u7D22\u5F15.md";var lt="next-id.txt",dt="info";import A from"path";import zt from"os";import q from"fs";import W from"fs";import K from"path";import{promisify as G}from"util";var At=G(W.appendFile),Ot=G(W.readdir),Rt=G(W.unlink),Bt=G(W.stat),ut={debug:0,info:1,warn:2,error:3};function Wt(t){let r=t.getFullYear(),e=String(t.getMonth()+1).padStart(2,"0"),o=String(t.getDate()).padStart(2,"0");return`${r}-${e}-${o}`}function Gt(t){let r=t.getFullYear(),e=String(t.getMonth()+1).padStart(2,"0"),o=String(t.getDate()).padStart(2,"0"),n=String(t.getHours()).padStart(2,"0"),a=String(t.getMinutes()).padStart(2,"0"),l=String(t.getSeconds()).padStart(2,"0");return`${r}-${e}-${o} ${n}:${a}:${l}`}function Ht(){let t=Wt(new Date);return K.join(Q(),`${t}.log`)}async function Ut(t,r){try{let e=K.dirname(t);await b(e)||await T(e),await At(t,r+`
2
+ `,"utf-8")}catch(e){console.error("[haimati] \u5199\u5165\u65E5\u5FD7\u6587\u4EF6\u5931\u8D25:",e)}}async function ft(){try{let t=Z(),r=Q();if(!await b(r))return;let e=await Ot(r),n=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 l=K.join(r,a);(await Bt(l)).mtime.getTime()<n&&await Rt(l)}}catch(t){console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",t)}}async function B(t,r,e){try{let o=Z();if(ut[t]<ut[o.level])return;let a=Gt(new Date),l=e?`[${e}] `:"",s=`[${a}] [${t.toUpperCase()}] ${l}${r}`,c=Ht();await Ut(c,s),ft().catch(f=>{console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",f)})}catch(o){console.error("[haimati] \u65E5\u5FD7\u8BB0\u5F55\u5931\u8D25:",o)}}var i={debug(t,r){return B("debug",t,r)},info(t,r){return B("info",t,r)},warn(t,r){return B("warn",t,r)},error(t,r){return B("error",t,r)}};async function gt(){await ft()}var Jt=["haimati.jsonc","haimati.json"];function Vt(t){let r="",e=0,o=!1;for(;e<t.length;){let n=t[e],a=t[e+1];if(o){if(n==="\\"){r+=n+a,e+=2;continue}n==='"'&&(o=!1),r+=n,e++;continue}if(n==='"'){o=!0,r+=n,e++;continue}if(n==="/"&&a==="/"){for(;e<t.length&&t[e]!==`
3
+ `;)e++;continue}if(n==="/"&&a==="*"){for(e+=2;e<t.length-1&&!(t[e]==="*"&&t[e+1]==="/");)e++;e+=2;continue}r+=n,e++}return r}function Yt(t){let e=Vt(t).replace(/,\s*([}\]])/g,"$1");return JSON.parse(e)}function tt(t){for(let r of Jt){let e=A.join(t,r);if(q.existsSync(e))return e}return null}function et(t){try{let r=q.readFileSync(t,"utf-8"),e=Yt(r);return typeof e=="object"&&e!==null?e:{}}catch{return{}}}function H(t,r){let e={...t};for(let o of Object.keys(r)){let n=e[o],a=r[o];n&&a&&typeof n=="object"&&typeof a=="object"&&!Array.isArray(n)&&!Array.isArray(a)?e[o]=H(n,a):a!==void 0&&(e[o]=a)}return e}function mt(){return A.join(zt.homedir(),".config","opencode")}function Xt(){return process.env.OPENCODE_CONFIG_DIR||null}function Kt(t){return A.join(t,".opencode")}function Qt(){let t=mt(),r=A.join(t,"haimati.jsonc");if(!q.existsSync(r))try{q.existsSync(t)||q.mkdirSync(t,{recursive:!0}),q.writeFileSync(r,`{
4
+ // \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
5
+ // "haimatiPath": ".haimati",
6
+
7
+ // \u65E5\u5FD7\u914D\u7F6E
8
+ // "log": {
9
+ // "level": "info", // debug\u3001info\u3001warn\u3001error
10
+ // "logRetentionDays": 180 // \u65E5\u5FD7\u4FDD\u7559\u5929\u6570
11
+ // }
12
+ }
13
+ `,"utf-8")}catch{}}function ht(t){i.debug(`[loadConfig] \u5165\u53C2: projectDir="${t}"`),Qt();let r={},e=tt(mt());if(e){let a=et(e);r=H(r,a),i.debug(`[loadConfig] \u52A0\u8F7D\u5168\u5C40\u914D\u7F6E: ${e}`)}let o=Xt();if(o){let a=tt(o);if(a){let l=et(a);r=H(r,l),i.debug(`[loadConfig] \u52A0\u8F7D\u81EA\u5B9A\u4E49\u914D\u7F6E: ${a}`)}}let n=tt(Kt(t));if(n){let a=et(n);r=H(r,a),i.debug(`[loadConfig] \u52A0\u8F7D\u9879\u76EE\u914D\u7F6E: ${n}`)}return i.debug(`[loadConfig] \u51FA\u53C2: config=${JSON.stringify(r)}`),i.info("[loadConfig] \u914D\u7F6E\u52A0\u8F7D\u5B8C\u6210"),r}function $t(t,r,e){return t.haimatiPath?A.resolve(r,t.haimatiPath):e}function k(t){let r=ht(t),e=C.join(t,st),o=$t(r,t,e);return i.debug(`[getHaimatiDir] directory="${t}", result="${o}"`),o}function L(t){return C.join(k(t),ct)}function U(t){return C.join(k(t),lt)}function nt(t){return C.join(k(t),".lock")}function rt(t){return C.join(k(t),"\u4E66\u9875")}function M(t,r){let e=parseInt(r,10),o=Math.floor((e-1)/50)*50+1,n=o+50-1,a=`${String(o).padStart(3,"0")}-${String(n).padStart(3,"0")}`;return C.join(rt(t),a)}function z(t,r){let e=String(parseInt(r,10)).padStart(3,"0");return C.join(M(t,r),`${e}.md`)}function Q(){let t=wt.homedir();return C.join(t,".opencode-haimati","log")}function ee(t){try{if(!O.existsSync(t))return null;let e=O.readFileSync(t,"utf-8").replace(/\/\/.*$/gm,"").replace(/\/\*[\s\S]*?\*\//g,"").replace(/,\s*([}\]])/g,"$1"),o=JSON.parse(e);return o&&typeof o.log=="object"&&o.log!==null?o.log:null}catch{return null}}function Z(){let t={level:dt,logRetentionDays:180},r=C.join(wt.homedir(),".config","opencode"),e=[C.join(r,"haimati.jsonc"),C.join(r,"haimati.json")].find(o=>O.existsSync(o));if(e){let o=ee(e);if(o)return{level:o.level||t.level,logRetentionDays:o.logRetentionDays??t.logRetentionDays}}return t}function T(t){return O.promises.mkdir(t,{recursive:!0}).then(()=>{})}function b(t){return O.promises.access(t).then(()=>!0).catch(()=>!1)}import pt from"fs";import{promisify as yt}from"util";var xt=yt(pt.readFile),ie=yt(pt.writeFile);function J(t){let r=0,e=0,o=t.length;for(;e<o;)if(t[e]==="\u2502"&&e+3<o&&t.slice(e+1,e+4)===" ")r++,e+=4;else if(t.slice(e,e+4)===" ")r++,e+=4;else{if((t[e]==="\u251C"||t[e]==="\u2514")&&e+3<o&&t.slice(e+1,e+4)==="\u2500\u2500 ")break;break}return r}function V(t){let e=t.trim().replace(/^[│├└─\s]+/,"").trim();return e==="/"?"/":!e.endsWith("/")||(e=e.slice(0,-1),!e)?null:e}function ne(t){i.debug(`[parseIndex] \u5165\u53C2: content=
14
+ ${t}`);let r=[],e=t.split(`
15
+ `),o=[];for(let n of e){if(!n.trim())continue;let a=J(n),l=n.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(l){let s=l[1].trim(),c=String(parseInt(l[2],10)),h=o.slice(0,a).filter($=>$!=="").join("/");r.push({id:c,category:h,title:s})}else{let s=V(n);if(s)if(s==="/"){o[a]="";for(let c=a+1;c<o.length;c++)delete o[c]}else{o[a]=s;for(let c=a+1;c<o.length;c++)delete o[c]}}}return i.debug(`[parseIndex] \u51FA\u53C2: entries=
16
+ ${JSON.stringify(r,null,2)}`),r}function F(t,r){return t.find(e=>e.id===r)||null}function bt(t,r,e){return t.find(o=>o.category===r&&o.title===e)||null}function _t(t,r){return t.filter(e=>e.id!==r)}function ot(t){if(i.debug(`[buildIndexTree] \u5165\u53C2: entries=
17
+ ${JSON.stringify(t,null,2)}`),t.length===0)return i.debug("[buildIndexTree] \u51FA\u53C2: \u7A7A\u7D22\u5F15"),"";let r={name:"/",children:[],entry:null};for(let a of t){let l=a.category.split("/"),s=r;for(let f=0;f<l.length;f++){let h=l[f];if(!h)continue;let $=s.children.find(w=>w.name===h);$||($={name:h,children:[],entry:null},s.children.push($)),s=$}let c={name:a.id,children:[],entry:a};s.children.push(c)}function e(a){a.children.sort((l,s)=>l.name.localeCompare(s.name,void 0,{sensitivity:"base"}));for(let l of a.children)e(l)}e(r);function o(a,l,s){let c=[],f=l+(s?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "),h=a.name==="/"?"/":a.name+"/";c.push(`${f}${h}`),l=l+(s?" ":"\u2502 ");let $=a.children.filter(d=>d.entry===null),w=a.children.filter(d=>d.entry!==null),g=[...$,...w];for(let d=0;d<g.length;d++){let u=g[d],m=d===g.length-1;if(u.entry){let y=u.entry.id.padStart(3,"0"),p=l+(m?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ");c.push(`${p}${u.entry.title} - ${y}`)}else c.push(...o(u,l,m))}return c}let n=o(r,"",!0).join(`
18
+ `);return i.debug(`[buildIndexTree] \u51FA\u53C2: tree=
19
+ ${n}`),n}async function D(t){await i.debug(`[readIndex] \u5165\u53C2: directory="${t}"`);let r=L(t);if(!await b(r))return await i.debug("[readIndex] \u51FA\u53C2: \u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728\uFF0C\u8FD4\u56DE\u7A7A\u6570\u7EC4"),[];let e=await xt(r,"utf-8"),o=ne(e);return await i.debug(`[readIndex] \u51FA\u53C2: \u8BFB\u53D6\u5230${o.length}\u6761\u8BB0\u5F55`),await i.info(`[readIndex] \u8BFB\u53D6\u7D22\u5F15: ${r}, \u5171${o.length}\u6761`),o}async function R(t,r){await i.debug(`[writeIndex] \u5165\u53C2: directory="${t}", entries=
20
+ ${JSON.stringify(r,null,2)}`);let e=k(t);await b(e)||(await T(e),await i.debug(`[writeIndex] \u521B\u5EFA\u6D77\u9A6C\u4F53\u76EE\u5F55: ${e}`));let o=ot(r),n=L(t);await ie(n,o,"utf-8"),await i.debug(`[writeIndex] \u51FA\u53C2: \u5199\u5165\u6210\u529F, indexPath="${n}", tree=
21
+ ${o}`),await i.info(`[writeIndex] \u5199\u5165\u7D22\u5F15: ${n}, \u5171${r.length}\u6761`)}async function Et(t){await i.debug(`[readIndexContent] \u5165\u53C2: directory="${t}"`);let r=L(t);if(!await b(r))return await i.debug("[readIndexContent] \u51FA\u53C2: \u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728"),"";let e=await xt(r,"utf-8");return await i.debug(`[readIndexContent] \u51FA\u53C2: content=
22
+ ${e}`),e}import Y from"fs";import{promisify as X}from"util";var re=X(Y.readFile),oe=X(Y.writeFile),ae=X(Y.unlink),Pt=X(Y.mkdir);async function v(t,r){await i.debug(`[readPage] \u5165\u53C2: directory="${t}", id="${r}"`);let e=z(t,r);if(!await b(e))return await i.debug(`[readPage] \u51FA\u53C2: \u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728: ${e}`),null;let n=(await re(e,"utf-8")).split(`
23
+ `);if(n.length<4)return await i.warn("[readPage] \u51FA\u53C2: \u4E66\u9875\u683C\u5F0F\u4E0D\u5B8C\u6574\uFF0C\u5C11\u4E8E4\u884C"),null;let a="------system------",l=Math.max(0,n.length-5),s=-1;for(let d=n.length-1;d>=l;d--)if(n[d].trim()===a){s=d;break}if(s===-1){if(n.length>=3&&n[2].startsWith("version:")&&/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/.test(n[1])){let p=n[0],_=n[1],P=parseInt(n[2].substring(8).trim(),10)||1,I=n.slice(3).join(`
24
+ `);await i.debug(`[readPage] \u65E7\u683C\u5F0F\u89E3\u6790: title="${p}", version=${P}`);let S={title:p,createdAt:_,content:I,version:P};return await i.debug("[readPage] \u51FA\u53C2: \u8BFB\u53D6\u6210\u529F (\u65E7\u683C\u5F0F)"),S}let u=n[0],m=n.join(`
25
+ `);await i.debug(`[readPage] \u6700\u65E7\u683C\u5F0F\u89E3\u6790: title="${u}"`);let y={title:u,createdAt:"",content:m,version:1};return await i.debug("[readPage] \u51FA\u53C2: \u8BFB\u53D6\u6210\u529F (\u6700\u65E7\u683C\u5F0F)"),y}if(s+3>=n.length)return await i.warn("[readPage] \u51FA\u53C2: \u65B0\u683C\u5F0F\u4E0D\u5B8C\u6574"),null;let c=n.slice(0,s).join(`
26
+ `),f=n[s+1],h=n[s+2],$=n[s+3],w=parseInt($.substring(8).trim(),10)||1;await i.debug(`[readPage] \u65B0\u683C\u5F0F\u89E3\u6790: title="${f}", version=${w}, content=
27
+ ${c}`);let g={title:f,createdAt:h,content:c,version:w};return await i.debug("[readPage] \u51FA\u53C2: \u8BFB\u53D6\u6210\u529F"),await i.info(`[readPage] \u8BFB\u53D6\u4E66\u9875: #${r}, version=${w}`),g}async function j(t,r,e,o,n,a=1){await i.debug(`[writePage] \u5165\u53C2: id="${r}", title="${e}", version=${a}, content=
28
+ ${n}`);let l=rt(t);await b(l)||(await Pt(l,{recursive:!0}),await i.debug(`[writePage] \u521B\u5EFA\u4E66\u9875\u76EE\u5F55: ${l}`));let s=M(t,r);await b(s)||(await Pt(s,{recursive:!0}),await i.debug(`[writePage] \u521B\u5EFA\u5206\u7EC4\u76EE\u5F55: ${s}`));let c=z(t,r),h=`------system------
29
+ ${e}
30
+ ${o}
31
+ version:${a}`,$=n?`${n}
32
+ ${h}`:h;await oe(c,$,"utf-8"),await i.debug(`[writePage] \u51FA\u53C2: \u5199\u5165\u6210\u529F, pagePath="${c}", fileContent=
33
+ ${$}`),await i.info(`[writePage] \u5199\u5165\u4E66\u9875: ${c}, version=${a}`)}async function vt(t,r){await i.debug(`[deletePage] \u5165\u53C2: directory="${t}", id="${r}"`);let e=z(t,r);return await b(e)?(await ae(e),await i.debug(`[deletePage] \u51FA\u53C2: \u5220\u9664\u6210\u529F, pagePath="${e}"`),await i.info(`[deletePage] \u5220\u9664\u4E66\u9875: ${e}`),!0):(await i.debug(`[deletePage] \u51FA\u53C2: \u6587\u4EF6\u4E0D\u5B58\u5728, pagePath="${e}"`),!1)}function It(t,r){if(r===0)return 0;let e=1,o=0;for(;o<t.length;){if(t[o]===`
34
+ `){if(e===r)return o+1;e++}o++}return o}function St(t,r,e,o){i.debug(`[applyContentEdit] \u5165\u53C2: offsetBegin=${r}, offsetEnd=${e}, newContent=
35
+ ${o}, content=
36
+ ${t}`);let n=r===1?0:It(t,r-1),a=It(t,e),l=a<t.length?a-1:a;i.debug(`[applyContentEdit] \u8BA1\u7B97\u4F4D\u7F6E: beforeEndIndex=${n}, afterStartIndex=${l}`);let c=(l<t.length?t.substring(l):"").startsWith(`
37
+ `),f=l<t.length&&!o.endsWith(`
38
+ `)&&!c,h=t.substring(0,n)+o+(f?`
39
+ `:"")+t.substring(l);return i.debug(`[applyContentEdit] \u51FA\u53C2: result=
40
+ ${h}`),h}async function Ct(t,r,e,o,n=!1){await i.debug(`[searchEntries] \u5165\u53C2: keyword="${r}", matchMode="${e}", entries=
41
+ ${JSON.stringify(t,null,2)}, searchContent=${n}`);let a=r.toLowerCase().split(/\s+/).filter(c=>c.length>0);if(a.length===0)return await i.debug("[searchEntries] \u51FA\u53C2: \u5173\u952E\u5B57\u4E3A\u7A7A\uFF0C\u8FD4\u56DE\u7A7A\u6570\u7EC4"),[];await i.debug(`[searchEntries] \u89E3\u6790\u5173\u952E\u5B57: [${a.join(", ")}]`);let l=[];for(let c of t){let f=c.title.toLowerCase(),h=c.category.toLowerCase(),$=c.id.toLowerCase(),w=new Set,g=0;for(let d of a)(f.includes(d)||h.includes(d)||$.includes(d))&&(g++,w.add(d));if(n&&o){let d=await v(o,c.id);if(d&&d.content){let u=d.content.toLowerCase();for(let m of a)u.includes(m)&&(g++,w.add(m))}}e==="and"?w.size===a.length&&l.push({entry:c,score:g}):w.size>0&&l.push({entry:c,score:g})}l.sort((c,f)=>f.score-c.score);let s=l.map(c=>c.entry);return await i.debug(`[searchEntries] \u51FA\u53C2: \u5339\u914D\u5230 ${s.length} \u6761\u8BB0\u5F55`),await i.info(`[searchEntries] \u641C\u7D22\u5B8C\u6210: \u5173\u952E\u5B57="${r}", \u6A21\u5F0F=${e}, \u7ED3\u679C\u6570=${s.length}`),s}import Nt from"fs";import{promisify as qt}from"util";import Lt from"fs";import{promisify as Dt}from"util";var ce=Dt(Lt.writeFile),le=Dt(Lt.unlink);async function kt(t){await i.debug(`[acquireLock] \u5165\u53C2: directory="${t}"`);let r=k(t);await b(r)||(await T(r),await i.debug(`[acquireLock] \u521B\u5EFA\u6D77\u9A6C\u4F53\u76EE\u5F55: ${r}`));let e=nt(t),o=Date.now(),n=50+Math.random()*20,a=0;for(;await b(e);){if(a++,Date.now()-o>5e3)return await i.warn(`[acquireLock] \u51FA\u53C2: \u9501\u83B7\u53D6\u8D85\u65F6 (\u91CD\u8BD5${a}\u6B21)`),!1;await new Promise(l=>setTimeout(l,n))}return await i.debug(`[acquireLock] \u7B49\u5F85\u9501\u91CA\u653E: \u91CD\u8BD5${a}\u6B21, \u8017\u65F6${Date.now()-o}ms`),await ce(e,String(process.pid),"utf-8"),await i.debug(`[acquireLock] \u51FA\u53C2: \u9501\u83B7\u53D6\u6210\u529F, PID=${process.pid}`),await i.info(`[acquireLock] \u9501\u83B7\u53D6\u6210\u529F: ${e}`),!0}async function Tt(t){await i.debug(`[releaseLock] \u5165\u53C2: directory="${t}"`);let r=nt(t);await b(r)?(await le(r),await i.debug("[releaseLock] \u51FA\u53C2: \u9501\u91CA\u653E\u6210\u529F"),await i.info(`[releaseLock] \u9501\u91CA\u653E\u6210\u529F: ${r}`)):await i.debug("[releaseLock] \u51FA\u53C2: \u9501\u6587\u4EF6\u4E0D\u5B58\u5728\uFF0C\u65E0\u9700\u91CA\u653E")}var de=qt(Nt.readFile),ue=qt(Nt.writeFile);async function fe(t){await i.debug(`[readNextIdFromFile] \u5165\u53C2: directory="${t}"`);let r=U(t);if(!await b(r))return await i.debug("[readNextIdFromFile] \u51FA\u53C2: next-id\u6587\u4EF6\u4E0D\u5B58\u5728\uFF0C\u8FD4\u56DE\u9ED8\u8BA4\u503C1"),1;let o=(await de(r,"utf-8")).trim(),n=parseInt(o,10);return!isNaN(n)&&n>0?(await i.debug(`[readNextIdFromFile] \u51FA\u53C2: nextId=${n}`),n):(await i.debug("[readNextIdFromFile] \u51FA\u53C2: \u89E3\u6790\u5931\u8D25\uFF0C\u8FD4\u56DE\u9ED8\u8BA4\u503C1"),1)}async function ge(t){await i.debug(`[initializeNextIdIfNeeded] \u5165\u53C2: directory="${t}"`);let r=U(t);if(await b(r)){await i.debug("[initializeNextIdIfNeeded] \u51FA\u53C2: next-id\u6587\u4EF6\u5DF2\u5B58\u5728\uFF0C\u65E0\u9700\u521D\u59CB\u5316");return}let e=await D(t),o=0;for(let n of e){let a=parseInt(n.id,10);a>o&&(o=a)}await Mt(t,o+1),await i.debug(`[initializeNextIdIfNeeded] \u51FA\u53C2: \u521D\u59CB\u5316\u5B8C\u6210, nextId=${o+1}`)}async function Mt(t,r){await i.debug(`[writeNextIdToFile] \u5165\u53C2: directory="${t}", nextId=${r}`);let e=k(t);await b(e)||await T(e);let o=U(t);await ue(o,String(r),"utf-8"),await i.debug(`[writeNextIdToFile] \u51FA\u53C2: \u5199\u5165\u6210\u529F, nextIdPath="${o}", nextId=${r}`)}async function Ft(t,r,e,o,n,a=!1){if(/ - \d{3}$/.test(e))throw await i.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 i.info(`[allocateIdWithLock] \u5F00\u59CB\u5206\u914D\u5E8F\u53F7: category="${r}", title="${e}"`),!await kt(t))return await i.warn(`[allocateIdWithLock] \u83B7\u53D6\u9501\u5931\u8D25: category="${r}", title="${e}"`),null;await i.debug(`[allocateIdWithLock] \u83B7\u53D6\u9501\u6210\u529F: category="${r}", title="${e}"`);try{await ge(t);let l=await D(t),s=l.find($=>$.category===r&&$.title===e);if(s){if(!a)throw new Error(`\u8BB0\u5FC6\u5DF2\u5B58\u5728: ${r}/${e}\uFF0C\u5982\u9700\u66F4\u65B0\u8BF7\u4F7F\u7528 haimati_edit \u5DE5\u5177`);let $=await v(t,s.id),w=$?$.createdAt:o,g=$?$.version+1:1;return await j(t,s.id,e,w,n,g),await i.info(`[allocateIdWithLock] \u66F4\u65B0\u5DF2\u6709\u6761\u76EE: #${s.id} ${r}/${e}, \u65B0\u7248\u672C: ${g}`),null}let c=await fe(t),f=String(c).padStart(3,"0");await j(t,f,e,o,n,1);let h={id:f,category:r,title:e};return l.push(h),await R(t,l),await Mt(t,c+1),await i.info(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u6210\u529F: #${f} ${r}/${e}`),f}catch(l){let s=l instanceof Error?l.message:String(l);if(await i.error(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u5931\u8D25: ${s}`),s.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw l;return null}finally{await Tt(t)}}function N(t){let r=t;return typeof r?.directory=="string"&&r.directory?r.directory:null}function me(t){let r=t.trim();if(!r)return null;if(/^\d+$/.test(r))return[String(parseInt(r,10))];let e=[],o=r.split(",");for(let n of o){let a=n.trim();if(!a)return null;let l=a.match(/^(\d+)\s*-\s*(\d+)$/);if(l){let s=parseInt(l[1],10),c=parseInt(l[2],10);if(s>c||s<=0)return null;for(let f=s;f<=c;f++)e.push(String(f))}else if(/^\d+$/.test(a))e.push(String(parseInt(a,10)));else return null}return e}function jt(){return{haimati_read:x({description:`\u4ECE\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u8BFB\u53D6\u8BB0\u5FC6\u5185\u5BB9\u3002\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\u8BB0\u5FC6\uFF0C\u652F\u6301\u5355\u6761\u548C\u6279\u91CF\u8BFB\u53D6\u3002
23
42
 
24
43
  \u529F\u80FD\u8BF4\u660E\uFF1A
25
44
  - \u901A\u8FC7\u5E8F\u53F7\uFF08\u5982 '086'\uFF09\u5B9A\u4F4D\u5E76\u8BFB\u53D6\u6307\u5B9A\u8BB0\u5FC6\u7684\u5B8C\u6574\u5185\u5BB9
26
45
  - \u5E8F\u53F7\u652F\u6301\u81EA\u52A8\u8865\u5168\uFF1A\u8F93\u5165 '86' \u6216 '086' \u5747\u53EF\u5B9A\u4F4D\u5230\u5E8F\u53F7 086 \u7684\u8BB0\u5FC6
27
- - \u652F\u6301\u5206\u9875\u8BFB\u53D6\uFF1A\u901A\u8FC7 offset \u548C limit \u53C2\u6570\u8BFB\u53D6\u6307\u5B9A\u884C\u8303\u56F4
28
- - \u8FD4\u56DE\u5185\u5BB9\u5305\u542B\u884C\u53F7\u524D\u7F00\u548C\u7CFB\u7EDF\u4FE1\u606F\uFF08\u6807\u9898\u3001\u521B\u5EFA\u65F6\u95F4\u3001version\uFF09
46
+ - \u652F\u6301\u5355\u6761\u5206\u9875\u8BFB\u53D6\uFF1A\u901A\u8FC7 offset \u548C limit \u53C2\u6570\u8BFB\u53D6\u6307\u5B9A\u884C\u8303\u56F4
47
+ - \u652F\u6301\u6279\u91CF\u8BFB\u53D6\uFF1A\u9017\u53F7\u5206\u9694\u591A\u4E2A\u5E8F\u53F7\uFF0C\u6216\u4F7F\u7528\u8303\u56F4\u8BED\u6CD5\uFF08\u5982 "086-090"\uFF09
48
+ - \u8FD4\u56DE\u5185\u5BB9\u4EE5 "===== #N =====" \u5F00\u5934\uFF0C\u540E\u8DDF\u884C\u53F7\u5185\u5BB9\u548C\u7CFB\u7EDF\u4FE1\u606F
49
+ - \u884C\u524D\u7684 "N|" \u8868\u793A\u884C\u53F7\uFF08\u5982 "1|xxx" \u8868\u793A\u7B2C 1 \u884C\uFF09\uFF0C\u4E0D\u662F\u8BB0\u5FC6\u5185\u5BB9\u7684\u4E00\u90E8\u5206
50
+
51
+ \u4F7F\u7528\u65F6\u673A\u5EFA\u8BAE\uFF1A
52
+ - \u5DF2\u77E5\u5177\u4F53\u5E8F\u53F7\uFF0C\u53EA\u9700\u770B\u5185\u5BB9 \u2192 query="086"
53
+ - \u5DF2\u77E5\u5177\u4F53\u5E8F\u53F7\uFF0C\u4F46\u5185\u5BB9\u5F88\u957F \u2192 query="086", offset=1, limit=20\uFF0C\u53EA\u8BFB\u524D20\u884C
54
+ - \u9700\u8981\u770B\u591A\u6761\u8BB0\u5FC6 \u2192 query="086,087,088" \u6216 query="086-090"
29
55
 
30
56
  \u8FD4\u56DE\u683C\u5F0F\uFF1A
31
- 1| # \u7B2C\u4E00\u884C\u5185\u5BB9
32
- 2|
33
- 3|\u8FD9\u91CC\u662F\u7B2C\u4E09\u884C\u5185\u5BB9
57
+ ===== #086 =====
58
+ 1|\u7B2C\u4E00\u884C\u5185\u5BB9
59
+ ...
34
60
  ------system------
35
61
  \u6807\u9898:{\u6807\u9898}
36
62
  \u521B\u5EFA\u65F6\u95F4:{\u521B\u5EFA\u65F6\u95F4}
@@ -40,23 +66,33 @@ version:{version}
40
66
  - query="086" - \u8BFB\u53D6\u5E8F\u53F7 086 \u7684\u5B8C\u6574\u8BB0\u5FC6\u5185\u5BB9
41
67
  - query="1", offset=1, limit=10 - \u8BFB\u53D6\u5E8F\u53F7 001 \u7684\u524D 10 \u884C
42
68
  - query="046", offset=50, limit=15 - \u8BFB\u53D6\u5E8F\u53F7 046 \u7684\u7B2C 50-64 \u884C\uFF08\u5171 15 \u884C\uFF09
43
- - query="5" - \u8BFB\u53D6\u5E8F\u53F7 005 \u7684\u5185\u5BB9\uFF08\u81EA\u52A8\u8865\u5168\u4E3A\u4E09\u4F4D\u6570\uFF09`,args:{query:x.schema.string().describe("\u5E8F\u53F7\u3002\u4F8B\u5982\uFF1A'086'"),offset:x.schema.number().optional().default(1).describe("\u8D77\u59CB\u884C\u53F7\uFF08\u9ED8\u8BA4 1\uFF09"),limit:x.schema.number().optional().default(2e3).describe("\u6700\u5927\u8BFB\u53D6\u884C\u6570\uFF08\u9ED8\u8BA4 2000\uFF09")},async execute(t,i){let{directory:n}=i,a=I(n);if(await s.info(`[haimati_read] \u5F00\u59CB\u8BFB\u53D6 #${t.query}`),await s.debug(`[haimati_read] \u5165\u53C2: query="${t.query}", offset=${t.offset||1}, limit=${t.limit||2e3}`),!await $(a)){let e=`\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728\u4E8E ${a}`;return await s.warn(`[haimati_read] \u51FA\u53C2:
44
- ${_(e)}`),e}try{let e=await b(n);await s.debug(`[haimati_read] \u8BFB\u53D6\u7D22\u5F15: \u5171 ${e.length} \u6761\u8BB0\u5F55`);let r=t.query.trim();if(!/^\d+$/.test(r)){let w="\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";return await s.warn(`[haimati_read] \u51FA\u53C2:
45
- ${_(w)}`),w}let c=String(parseInt(r,10)),o=C(e,c);if(await s.debug(`[haimati_read] \u5E8F\u53F7\u67E5\u8BE2 #${r}: ${o?"\u627E\u5230":"\u672A\u627E\u5230"}`),!o){let w=`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;return await s.debug(`[haimati_read] \u51FA\u53C2:
46
- ${_(w)}`),await s.info(`[haimati_read] \u8BFB\u53D6\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),w}let f=await k(n,o.id);if(!f){let w=`\u672A\u627E\u5230\u4E66\u9875: #${o.id.padStart(3,"0")}`;return await s.error(`[haimati_read] \u51FA\u53C2:
47
- ${_(w)}`),w}let u=M(n,o.id);await s.debug(`[haimati_read] \u8BFB\u53D6\u4E66\u9875: \u4E66\u9875/${u.split(/[\\/]/).pop()}/${o.id}.md, version=${f.version}`);let l=f.content.split(`
48
- `),m=t.offset||1,p=t.limit||2e3,g=l.length,d=Math.max(0,m-1),y=Math.min(g,d+p),h=[];for(let w=d;w<y;w++)h.push(`${w+1}|${l[w]}`);h.push("------system------"),h.push(`\u6807\u9898:${o.title}`),h.push(`\u521B\u5EFA\u65F6\u95F4:${f.createdAt}`),h.push(`version:${f.version}`);let E=h.join(`
49
- `);return await s.debug(`[haimati_read] \u51FA\u53C2:
50
- ${_(E)}`),await s.info(`[haimati_read] \u8BFB\u53D6\u6210\u529F: #${o.id} (${o.category}/${o.title}), version=${f.version}`),E}catch(e){let r=e instanceof Error?e.message:String(e),c=e instanceof Error?e.stack:"";return await s.error(`[haimati_read] \u51FA\u53C2: \u9519\u8BEF: ${r}
51
- \u5806\u6808: ${c}`),`\u9519\u8BEF: ${r}`}}}),haimati_write:x({description:"\u5C06\u65B0\u4FE1\u606F\u5199\u5165\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u3002\u9700\u8981\u63D0\u4F9B\u5206\u7C7B\u8DEF\u5F84\uFF08\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0'\uFF09\u3001\u6807\u9898\u548C\u5185\u5BB9\u3002\u5982\u679C\u76F8\u540C\u5206\u7C7B\u548C\u6807\u9898\u7684\u8BB0\u5FC6\u5DF2\u5B58\u5728\uFF0C\u5219\u4F1A\u62A5\u9519\u3002",args:{category:x.schema.string().describe("\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0' \u6216 '\u901A\u7528'"),title:x.schema.string().describe("\u8BB0\u5FC6\u6807\u9898\uFF0C\u5982 '\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236'"),content:x.schema.string().describe("\u8981\u5199\u5165\u7684\u8BE6\u7EC6\u5185\u5BB9")},async execute(t,i){let{directory:n}=i;await s.info(`[haimati_write] \u5F00\u59CB\u5199\u5165 ${t.category}/${t.title}`),await s.debug(`[haimati_write] \u5165\u53C2: category="${t.category}", title="${t.title}", content\u957F\u5EA6=${t.content.length}\u5B57\u7B26, content=
52
- ${_(t.content)}
53
- `);try{let a=new Date().toLocaleString("zh-CN",{hour12:!1}),e=null;for(let f=0;f<3;f++)try{if(e=await St(n,t.category,t.title,a,t.content,!1),e)break;await s.warn(`[haimati_write] \u9501\u83B7\u53D6\u5931\u8D25\uFF0C\u91CD\u8BD5\u7B2C ${f+1} \u6B21`)}catch(u){let l=u instanceof Error?u.message:String(u);if(l.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw u;await s.warn(`[haimati_write] \u83B7\u53D6\u9501\u5F02\u5E38: ${l}, \u91CD\u8BD5\u7B2C ${f+1} \u6B21`)}if(e){let f=M(n,e);await s.debug(`[haimati_write] \u5206\u914D\u65B0\u5E8F\u53F7: #${e}`),await s.debug(`[haimati_write] \u4E66\u9875\u548C\u7D22\u5F15\u5DF2\u66F4\u65B0: \u4E66\u9875/${f.split(/[\\/]/).pop()}/${e}.md`);let u=`\u5DF2\u5199\u5165\u6D77\u9A6C\u4F53 #${e}
69
+ - query="5" - \u8BFB\u53D6\u5E8F\u53F7 005 \u7684\u5185\u5BB9\uFF08\u81EA\u52A8\u8865\u5168\u4E3A\u4E09\u4F4D\u6570\uFF09
70
+ - query="086,087,088" - \u6279\u91CF\u8BFB\u53D6\u5E8F\u53F7 086\u3001087\u3001088
71
+ - query="086-090" - \u6279\u91CF\u8BFB\u53D6\u5E8F\u53F7 086 \u5230 090\uFF08\u8303\u56F4\u8BED\u6CD5\uFF09
72
+ - query="086-088,091" - \u6DF7\u5408\u4F7F\u7528\u8303\u56F4\u548C\u9017\u53F7`,args:{query:x.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:x.schema.number().optional().default(1).describe("\u8D77\u59CB\u884C\u53F7\uFF08\u9ED8\u8BA4 1\uFF0C\u4EC5\u5355\u6761\u8BFB\u53D6\u751F\u6548\uFF09"),limit:x.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,r){let e=N(r);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let o=L(e);if(await i.info(`[haimati_read] \u5F00\u59CB\u8BFB\u53D6 #${t.query}`),await i.debug(`[haimati_read] \u5165\u53C2: query="${t.query}", offset=${t.offset||1}, limit=${t.limit||2e3}`),!await b(o)){let n=`\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728\u4E8E ${o}`;return await i.warn(`[haimati_read] \u51FA\u53C2:
73
+ ${n}`),n}try{let n=await D(e);await i.debug(`[haimati_read] \u8BFB\u53D6\u7D22\u5F15: \u5171 ${n.length} \u6761\u8BB0\u5F55`);let a=t.query.trim(),l=me(a);if(!l||l.length===0){let w=`\u9519\u8BEF\uFF1A\u65E0\u6548\u7684\u67E5\u8BE2\u683C\u5F0F "${a}"`;return await i.warn(`[haimati_read] \u51FA\u53C2:
74
+ ${w}`),w}if(l.length===1){let w=l[0],g=F(n,w);if(await i.debug(`[haimati_read] \u5E8F\u53F7\u67E5\u8BE2 #${a}: ${g?"\u627E\u5230":"\u672A\u627E\u5230"}`),!g){let E=`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;return await i.debug(`[haimati_read] \u51FA\u53C2:
75
+ ${E}`),await i.info(`[haimati_read] \u8BFB\u53D6\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),E}let d=await v(e,g.id);if(!d){let E=`\u672A\u627E\u5230\u4E66\u9875: #${g.id.padStart(3,"0")}`;return await i.error(`[haimati_read] \u51FA\u53C2:
76
+ ${E}`),E}let u=M(e,g.id);await i.debug(`[haimati_read] \u8BFB\u53D6\u4E66\u9875: \u4E66\u9875/${u.split(/[\\/]/).pop()}/${g.id}.md, version=${d.version}`);let m=d.content.split(`
77
+ `),y=t.offset||1,p=t.limit||2e3,_=Math.max(0,y-1),P=Math.min(m.length,_+p),I=[];for(let E=_;E<P;E++)I.push(`${E+1}|${m[E]}`);I.push("------system------"),I.push(`\u6807\u9898:${g.title}`),I.push(`\u521B\u5EFA\u65F6\u95F4:${d.createdAt}`),I.push(`version:${d.version}`);let S=`===== #${g.id.padStart(3,"0")} =====
78
+ ${I.join(`
79
+ `)}`;return await i.debug(`[haimati_read] \u51FA\u53C2:
80
+ ${S}`),await i.info(`[haimati_read] \u8BFB\u53D6\u6210\u529F: #${g.id} (${g.category}/${g.title}), version=${d.version}`),S}let s=[],c=0,f=0,h=0;for(let w of l){let g=F(n,w);if(!g){await i.warn(`[haimati_read] \u6279\u91CF: \u672A\u627E\u5230\u8BB0\u5FC6 #${w}`),s.push(`===== #${w.padStart(3,"0")} =====
81
+ \u672A\u627E\u5230\u8BB0\u5FC6: ${w}`),f++;continue}let d=await v(e,g.id);if(!d){await i.error(`[haimati_read] \u6279\u91CF: \u672A\u627E\u5230\u4E66\u9875 #${g.id}`),s.push(`===== #${g.id.padStart(3,"0")} =====
82
+ \u672A\u627E\u5230\u4E66\u9875`),h++;continue}await i.debug(`[haimati_read] \u6279\u91CF: #${g.id} \u8BFB\u53D6\u6210\u529F, version=${d.version}`);let u=d.content.split(`
83
+ `),m=[];for(let y=0;y<u.length;y++)m.push(`${y+1}|${u[y]}`);m.push("------system------"),m.push(`\u6807\u9898:${g.title}`),m.push(`\u521B\u5EFA\u65F6\u95F4:${d.createdAt}`),m.push(`version:${d.version}`),s.push(`===== #${g.id.padStart(3,"0")} =====
84
+ ${m.join(`
85
+ `)}`),c++}let $=s.join(`
86
+
87
+ `);return await i.debug(`[haimati_read] \u6279\u91CF\u8BFB\u53D6: \u5171 ${l.length} \u6761, \u6210\u529F ${c} \u6761, \u672A\u627E\u5230\u8BB0\u5FC6 ${f} \u6761, \u672A\u627E\u5230\u4E66\u9875 ${h} \u6761`),await i.info(`[haimati_read] \u6279\u91CF\u8BFB\u53D6\u7ED3\u675F: \u5171 ${l.length} \u6761, \u6210\u529F ${c} \u6761`),$}catch(n){let a=n instanceof Error?n.message:String(n),l=n instanceof Error?n.stack:"";return await i.error(`[haimati_read] \u51FA\u53C2: \u9519\u8BEF: ${a}
88
+ \u5806\u6808: ${l}`),`\u9519\u8BEF: ${a}`}}}),haimati_write:x({description:"\u5C06\u65B0\u4FE1\u606F\u5199\u5165\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u3002\u9700\u8981\u63D0\u4F9B\u5206\u7C7B\u8DEF\u5F84\uFF08\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0'\uFF09\u3001\u6807\u9898\u548C\u5185\u5BB9\u3002\u5982\u679C\u76F8\u540C\u5206\u7C7B\u548C\u6807\u9898\u7684\u8BB0\u5FC6\u5DF2\u5B58\u5728\uFF0C\u5219\u4F1A\u62A5\u9519\u3002",args:{category:x.schema.string().describe("\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0' \u6216 '\u901A\u7528'"),title:x.schema.string().describe("\u8BB0\u5FC6\u6807\u9898\uFF0C\u5982 '\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236'"),content:x.schema.string().describe("\u8981\u5199\u5165\u7684\u8BE6\u7EC6\u5185\u5BB9")},async execute(t,r){let e=N(r);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";await i.info(`[haimati_write] \u5F00\u59CB\u5199\u5165 ${t.category}/${t.title}`),await i.debug(`[haimati_write] \u5165\u53C2: category="${t.category}", title="${t.title}", content=
89
+ ${t.content}`);try{let o=new Date().toLocaleString("zh-CN",{hour12:!1}),n=null;for(let c=0;c<3;c++)try{if(n=await Ft(e,t.category,t.title,o,t.content,!1),n)break;await i.warn(`[haimati_write] \u9501\u83B7\u53D6\u5931\u8D25\uFF0C\u91CD\u8BD5\u7B2C ${c+1} \u6B21`)}catch(f){let h=f instanceof Error?f.message:String(f);if(h.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw f;await i.warn(`[haimati_write] \u83B7\u53D6\u9501\u5F02\u5E38: ${h}, \u91CD\u8BD5\u7B2C ${c+1} \u6B21`)}if(n){let c=M(e,n);await i.debug(`[haimati_write] \u5206\u914D\u65B0\u5E8F\u53F7: #${n}`),await i.debug(`[haimati_write] \u4E66\u9875\u548C\u7D22\u5F15\u5DF2\u66F4\u65B0: \u4E66\u9875/${c.split(/[\\/]/).pop()}/${n}.md`);let f=`\u5DF2\u5199\u5165\u6D77\u9A6C\u4F53 #${n}
54
90
  \u8DEF\u5F84: ${t.category}/${t.title}
55
- \u7248\u672C: 1`;return await s.debug(`[haimati_write] \u51FA\u53C2:
56
- ${_(u)}`),await s.info(`[haimati_write] \u5199\u5165\u6210\u529F: #${e} (${t.category}/${t.title})`),u}let r=await b(n),c=Q(r,t.category,t.title);if(c){let f=`\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 s.error(`[haimati_write] \u51FA\u53C2:
57
- ${_(f)}`),f}let o="\u9519\u8BEF\uFF1A\u65E0\u6CD5\u5206\u914D\u5E8F\u53F7\uFF08\u9501\u7B49\u5F85\u8D85\u65F6\uFF09";return await s.error(`[haimati_write] \u51FA\u53C2:
58
- ${_(o)}`),o}catch(a){let e=a instanceof Error?a.message:String(a),r=a instanceof Error?a.stack:"";return await s.error(`[haimati_write] \u51FA\u53C2: \u9519\u8BEF: ${e}
59
- \u5806\u6808: ${r}`),`\u9519\u8BEF: ${e}`}}}),haimati_search:x({description:`\u641C\u7D22\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\uFF08\u652F\u6301\u591A\u5173\u952E\u5B57\uFF0C\u7528\u7A7A\u683C\u5206\u9694\uFF09\u3002\u641C\u7D22\u8303\u56F4\u5305\u62EC\uFF1A\u6807\u9898\u3001\u5206\u7C7B\u3001\u5E8F\u53F7\u3001\u4E66\u9875\u5185\u5BB9\u3002\u8F93\u5165\u5173\u952E\u8BCD\uFF0C\u8FD4\u56DE\u5339\u914D\u7684\u6761\u76EE\u5217\u8868\u548C\u5185\u5BB9\u7247\u6BB5\uFF0C\u652F\u6301\u5206\u9875\uFF08limit/offset\uFF09\u3002
91
+ \u7248\u672C: 1`;return await i.debug(`[haimati_write] \u51FA\u53C2:
92
+ ${f}`),await i.info(`[haimati_write] \u5199\u5165\u6210\u529F: #${n} (${t.category}/${t.title})`),f}let a=await D(e),l=bt(a,t.category,t.title);if(l){let c=`\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 i.error(`[haimati_write] \u51FA\u53C2:
93
+ ${c}`),c}let s="\u9519\u8BEF\uFF1A\u65E0\u6CD5\u5206\u914D\u5E8F\u53F7\uFF08\u9501\u7B49\u5F85\u8D85\u65F6\uFF09";return await i.error(`[haimati_write] \u51FA\u53C2:
94
+ ${s}`),s}catch(o){let n=o instanceof Error?o.message:String(o),a=o instanceof Error?o.stack:"";return await i.error(`[haimati_write] \u51FA\u53C2: \u9519\u8BEF: ${n}
95
+ \u5806\u6808: ${a}`),`\u9519\u8BEF: ${n}`}}}),haimati_search:x({description:`\u641C\u7D22\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\uFF08\u652F\u6301\u591A\u5173\u952E\u5B57\uFF0C\u7528\u7A7A\u683C\u5206\u9694\uFF09\u3002\u641C\u7D22\u8303\u56F4\u5305\u62EC\uFF1A\u6807\u9898\u3001\u5206\u7C7B\u3001\u5E8F\u53F7\u3001\u4E66\u9875\u5185\u5BB9\u3002\u8F93\u5165\u5173\u952E\u8BCD\uFF0C\u8FD4\u56DE\u5339\u914D\u7684\u6761\u76EE\u5217\u8868\u548C\u5185\u5BB9\u7247\u6BB5\uFF0C\u652F\u6301\u5206\u9875\uFF08limit/offset\uFF09\u3002
60
96
 
61
97
  \u641C\u7D22\u8303\u56F4\uFF1A
62
98
  - \u6807\u9898\uFF08\u6743\u91CD\u9AD8\uFF09\u3001\u5206\u7C7B\u8DEF\u5F84\uFF08\u6743\u91CD\u4E2D\uFF09\u3001\u5E8F\u53F7\uFF08\u6743\u91CD\u4E2D\uFF09\u2014\u2014\u5143\u6570\u636E\u641C\u7D22
@@ -75,19 +111,27 @@ ${_(o)}`),o}catch(a){let e=a instanceof Error?a.message:String(a),r=a instanceof
75
111
  - keyword="WS \u7B7E\u540D", match="and" \u2192 \u641C\u7D22\u540C\u65F6\u5305\u542B"WS"\u548C"\u7B7E\u540D"\u7684\u8BB0\u5FC6
76
112
  - keyword="\u5BC6\u7801 \u6CE8\u518C", match="or" \u2192 \u641C\u7D22\u5305\u542B"\u5BC6\u7801"\u6216"\u6CE8\u518C"\u7684\u4EFB\u610F\u8BB0\u5FC6
77
113
  - keyword="\u767B\u5F55", match="and", limit=5, offset=0 \u2192 \u641C\u7D22\u524D 5 \u6761
78
- - keyword="\u767B\u5F55", match="and", limit=5, offset=5 \u2192 \u7FFB\u9875\uFF0C\u83B7\u53D6\u7B2C 6-10 \u6761`,args:{keyword:x.schema.string().describe("\u641C\u7D22\u5173\u952E\u8BCD\uFF08\u652F\u6301\u591A\u5173\u952E\u5B57\uFF0C\u7528\u7A7A\u683C\u5206\u9694\uFF09"),match:x.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:x.schema.number().default(10).describe("\u8FD4\u56DE\u7ED3\u679C\u6570\u91CF\u9650\u5236"),offset:x.schema.number().default(0).describe("\u5206\u9875\u504F\u79FB\u91CF\uFF0C\u7528\u4E8E\u83B7\u53D6\u540E\u7EED\u9875\u9762")},async execute(t,i){let{directory:n}=i,a=I(n);if(await s.info(`[haimati_search] \u5F00\u59CB\u641C\u7D22 "${t.keyword}"`),await s.debug(`[haimati_search] \u5165\u53C2: keyword="${t.keyword}", match="${t.match}", limit=${t.limit||10}, offset=${t.offset||0}`),!await $(a)){let e="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await s.warn(`[haimati_search] \u51FA\u53C2:
79
- ${_(e)}`),await s.info("[haimati_search] \u641C\u7D22\u5931\u8D25: \u7D22\u5F15\u4E0D\u5B58\u5728"),e}try{let e=await b(n),r=t.keyword.trim(),c=t.match,o=t.limit||10,f=t.offset||0,u=await tt(e,r,c,n,!0),l=u.length,m=u.slice(f,f+o);if(m.length===0){let h=`\u672A\u627E\u5230\u5305\u542B '${r}' \u7684\u8BB0\u5FC6`;return await s.debug(`[haimati_search] \u51FA\u53C2:
80
- ${_(h)}`),await s.info("[haimati_search] \u641C\u7D22\u5B8C\u6210: \u672A\u627E\u5230\u5339\u914D"),h}let p=[],g=f+m.length<l,d=g?`${f+1}-${f+m.length}/${l}`:`${f+1}-${f+m.length}/${l}`;p.push(`\u627E\u5230 ${d} \u6761\u5339\u914D\uFF1A
81
- `),g&&p.push(`\uFF08\u5982\u9700\u83B7\u53D6\u66F4\u591A\uFF0C\u8BF7\u4F7F\u7528 offset=${f+o} \u7EE7\u7EED\u7FFB\u9875\uFF09
82
- `);for(let h of m){let E=await k(n,h.id),w=`${h.category}/${h.title}`,v="";E&&(v=E.content.split(`
83
- `).filter(Dt=>Dt.trim()).slice(0,3).join(" | ").substring(0,150),v.length===150&&(v+="...")),p.push(`## ${w} [${h.id}]`),v&&p.push(`> ${v}`),p.push("")}let y=p.join(`
84
- `);return await s.debug(`[haimati_search] \u51FA\u53C2:
85
- ${_(y)}`),await s.info(`[haimati_search] \u641C\u7D22\u5B8C\u6210: \u627E\u5230 ${l} \u6761\u5339\u914D`),y}catch(e){let r=e instanceof Error?e.message:String(e),c=e instanceof Error?e.stack:"";return await s.error(`[haimati_search] \u51FA\u53C2: \u9519\u8BEF: ${r}
86
- \u5806\u6808: ${c}`),await s.info(`[haimati_search] \u641C\u7D22\u5931\u8D25: ${r}`),`\u9519\u8BEF: ${r}`}}}),haimati_edit:x({description:`\u4FEE\u6539\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7684\u90E8\u5206\u5185\u5BB9\u3002\u5C06\u6307\u5B9A\u884C\u53F7\u8303\u56F4 [offsetBegin, offsetEnd] \u7684\u5185\u5BB9\u66FF\u6362\u4E3A\u65B0 content\uFF08\u95ED\u533A\u95F4\uFF0C\u4E24\u7AEF\u90FD\u5305\u62EC\uFF09\u3002
114
+ - keyword="\u767B\u5F55", match="and", limit=5, offset=5 \u2192 \u7FFB\u9875\uFF0C\u83B7\u53D6\u7B2C 6-10 \u6761`,args:{keyword:x.schema.string().describe("\u641C\u7D22\u5173\u952E\u8BCD\uFF08\u652F\u6301\u591A\u5173\u952E\u5B57\uFF0C\u7528\u7A7A\u683C\u5206\u9694\uFF09"),match:x.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:x.schema.number().default(10).describe("\u8FD4\u56DE\u7ED3\u679C\u6570\u91CF\u9650\u5236"),offset:x.schema.number().default(0).describe("\u5206\u9875\u504F\u79FB\u91CF\uFF0C\u7528\u4E8E\u83B7\u53D6\u540E\u7EED\u9875\u9762")},async execute(t,r){let e=N(r);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let o=L(e);if(await i.info(`[haimati_search] \u5F00\u59CB\u641C\u7D22 "${t.keyword}"`),await i.debug(`[haimati_search] \u5165\u53C2: keyword="${t.keyword}", match="${t.match}", limit=${t.limit||10}, offset=${t.offset||0}`),!await b(o)){let n="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await i.warn(`[haimati_search] \u51FA\u53C2:
115
+ ${n}`),await i.info("[haimati_search] \u641C\u7D22\u5931\u8D25: \u7D22\u5F15\u4E0D\u5B58\u5728"),n}try{let n=await D(e),a=t.keyword.trim(),l=t.match,s=t.limit||10,c=t.offset||0,f=await Ct(n,a,l,e,!0),h=f.length,$=f.slice(c,c+s);if($.length===0){let m=`\u672A\u627E\u5230\u5305\u542B '${a}' \u7684\u8BB0\u5FC6`;return await i.debug(`[haimati_search] \u51FA\u53C2:
116
+ ${m}`),await i.info("[haimati_search] \u641C\u7D22\u5B8C\u6210: \u672A\u627E\u5230\u5339\u914D"),m}let w=[],g=c+$.length<h,d=g?`${c+1}-${c+$.length}/${h}`:`${c+1}-${c+$.length}/${h}`;w.push(`\u627E\u5230 ${d} \u6761\u5339\u914D\uFF1A
117
+ `),g&&w.push(`\uFF08\u5982\u9700\u83B7\u53D6\u66F4\u591A\uFF0C\u8BF7\u4F7F\u7528 offset=${c+s} \u7EE7\u7EED\u7FFB\u9875\uFF09
118
+ `);for(let m of $){let y=await v(e,m.id),p=`${m.category}/${m.title}`,_="";y&&(_=y.content.split(`
119
+ `).filter(I=>I.trim()).slice(0,3).join(" | ").substring(0,150),_.length===150&&(_+="...")),w.push(`## ${p} [${m.id}]`),_&&w.push(`> ${_}`),w.push("")}let u=w.join(`
120
+ `);return await i.debug(`[haimati_search] \u51FA\u53C2:
121
+ ${u}`),await i.info(`[haimati_search] \u641C\u7D22\u5B8C\u6210: \u627E\u5230 ${h} \u6761\u5339\u914D`),u}catch(n){let a=n instanceof Error?n.message:String(n),l=n instanceof Error?n.stack:"";return await i.error(`[haimati_search] \u51FA\u53C2: \u9519\u8BEF: ${a}
122
+ \u5806\u6808: ${l}`),await i.info(`[haimati_search] \u641C\u7D22\u5931\u8D25: ${a}`),`\u9519\u8BEF: ${a}`}}}),haimati_edit:x({description:`\u4FEE\u6539\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7684\u90E8\u5206\u5185\u5BB9\u3002\u652F\u6301\u5355\u5904\u4FEE\u6539\u548C\u591A\u5904\u6279\u91CF\u4FEE\u6539\u3002
123
+
124
+ \u4F7F\u7528 edits \u6570\u7EC4\u53C2\u6570\uFF0C\u4E00\u6B21\u6027\u4FEE\u6539\u4E00\u4E2A\u6216\u591A\u4E2A\u4F4D\u7F6E\u3002
87
125
 
88
126
  \u5178\u578B\u6D41\u7A0B\uFF1A
89
127
  1. \u8C03\u7528 haimati_read \u8BFB\u53D6\u8BB0\u5FC6\u5185\u5BB9\uFF0C\u83B7\u53D6\u884C\u53F7\u548C version
90
- 2. \u8C03\u7528 haimati_edit\uFF0C\u4F20\u5165 offsetBegin/offsetEnd \u6307\u5B9A\u66FF\u6362\u8303\u56F4\uFF0C\u4F20\u5165 version \u8FDB\u884C\u5E76\u53D1\u63A7\u5236
128
+ 2. \u8C03\u7528 haimati_edit\uFF0C\u4F20\u5165 edits \u6570\u7EC4\u548C version \u8FDB\u884C\u5E76\u53D1\u63A7\u5236
129
+
130
+ \u6267\u884C\u987A\u5E8F\uFF08\u91CD\u8981\uFF09\uFF1A
131
+ - edits \u6570\u7EC4\u4E2D\u7684\u64CD\u4F5C\u4F1A\u81EA\u52A8\u6309\u884C\u53F7\u4ECE\u540E\u5F80\u524D\u6267\u884C
132
+ - \u4F8B\u5982\uFF1Aedits=[{offsetBegin:3,offsetEnd:5},{offsetBegin:10,offsetEnd:15}]
133
+ - \u5B9E\u9645\u6267\u884C\u987A\u5E8F\uFF1A\u5148\u4FEE\u6539\u7B2C 10-15 \u884C\uFF0C\u518D\u4FEE\u6539\u7B2C 3-5 \u884C
134
+ - \u8FD9\u6837\u524D\u9762\u7684\u4FEE\u6539\u4E0D\u4F1A\u5F71\u54CD\u540E\u9762\u4FEE\u6539\u7684\u884C\u53F7\u4F4D\u7F6E
91
135
 
92
136
  \u5E76\u53D1\u63A7\u5236\uFF1A
93
137
  - \u8BFB\u53D6\u65F6\u8FD4\u56DE version\uFF0C\u7F16\u8F91\u65F6\u9700\u4F20\u5165\u76F8\u540C\u7684 version
@@ -95,17 +139,18 @@ ${_(y)}`),await s.info(`[haimati_search] \u641C\u7D22\u5B8C\u6210: \u627E\u5230
95
139
  - \u7F16\u8F91\u6210\u529F\u540E version \u81EA\u52A8 +1
96
140
 
97
141
  \u4F7F\u7528\u793A\u4F8B\uFF1A
98
- - \u66FF\u6362\u5355\u884C\uFF1AoffsetBegin=3, offsetEnd=3, content="\u65B0\u7684\u7B2C3\u884C" \u2192 \u66FF\u6362\u7B2C3\u884C
99
- - \u66FF\u6362\u591A\u884C\uFF1AoffsetBegin=5, offsetEnd=8, content="\u65B0\u5185\u5BB9" \u2192 \u66FF\u6362\u7B2C5-8\u884C\u4E3A\u65B0\u5185\u5BB9
100
- - \u5220\u9664\u884C\uFF1AoffsetBegin=3, offsetEnd=5, content="" \u2192 \u5220\u9664\u7B2C3-5\u884C
101
- - \u5728\u7B2C3\u884C\u524D\u63D2\u5165\uFF1A\u5148 read \u83B7\u53D6\u7B2C3\u884C\u5185\u5BB9\uFF0C\u518D\u7528 offsetBegin=3, offsetEnd=3, content="\u65B0\u884C
102
- \u539F\u7B2C3\u884C"`,args:{query:x.schema.string().describe("\u5E8F\u53F7\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u66F4\u65B0\u7684\u8BB0\u5FC6"),offsetBegin:x.schema.number().describe("\u8D77\u59CB\u884C\u53F7\uFF08\u5305\u62EC\uFF09"),offsetEnd:x.schema.number().describe("\u7ED3\u675F\u884C\u53F7\uFF08\u5305\u62EC\u6B64\u884C\uFF09"),content:x.schema.string().describe("\u66FF\u6362\u5185\u5BB9"),version:x.schema.number().describe("read \u65F6\u8FD4\u56DE\u7684 version\uFF0C\u7528\u4E8E\u5E76\u53D1\u63A7\u5236")},async execute(t,i){let{directory:n}=i,a=I(n);if(await s.info(`[haimati_edit] \u5F00\u59CB\u7F16\u8F91 #${t.query}`),await s.debug(`[haimati_edit] \u5165\u53C2: query="${t.query}", offsetBegin=${t.offsetBegin}, offsetEnd=${t.offsetEnd}, content\u957F\u5EA6=${t.content.length}\u5B57\u7B26, version=${t.version}`),!await $(a))return await s.warn("[haimati_edit] \u51FA\u53C2: \u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728"),"\u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728";try{let e=await b(n),r=t.query.trim();if(!/^\d+$/.test(r))return await s.warn("[haimati_edit] \u51FA\u53C2: query\u65E0\u6548"),"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let c=String(parseInt(r,10)),o=C(e,c);if(!o)return await s.debug(`[haimati_edit] \u51FA\u53C2:
103
- \u672A\u627E\u5230`),await s.info("[haimati_edit] \u7F16\u8F91\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6"),`\u672A\u627E\u5230\u4E0E '${r}' \u76F8\u5173\u7684\u8BB0\u5FC6`;let f=await k(n,o.id);if(!f)return await s.error("[haimati_edit] \u51FA\u53C2: \u4E66\u9875\u4E0D\u5B58\u5728"),`\u672A\uFFFD\uFFFD\u5230\u4E66\u9875: #${o.id.padStart(3,"0")}`;if(f.version!==t.version)return await s.warn("[haimati_edit] \u51FA\u53C2: \u7248\u672C\u51B2\u7A81"),`\u9519\u8BEF\uFF1A\u7248\u672C\u51B2\u7A81\uFF0C\u5F53\u524D version=${f.version}\uFF0C\u4F20\u5165 version=${t.version}\uFF0C\u8BF7\u91CD\u65B0\u8BFB\u53D6\u540E\u518D\u64CD\u4F5C`;let u=f.content.split(`
104
- `).length,{offsetBegin:l,offsetEnd:m}=t;if(l<1||l>u||l>m||m>u)return await s.warn("[haimati_edit] \u51FA\u53C2: offset\u975E\u6CD5"),`\u9519\u8BEF\uFF1Aoffset \u975E\u6CD5\uFF0CoffsetBegin=${l}, offsetEnd=${m}, \u6587\u4EF6\u603B\u884C\u6570=${u}\uFF0C\u6709\u6548\u8303\u56F4 offsetBegin=[1, ${u}], offsetEnd=[offsetBegin, ${u}]`;let p=yt(f.content,l,m,t.content);await F(n,o.id,o.title,f.createdAt,p,f.version+1);let g=`${o.category}/${o.title}`,d=`\u5DF2\u66F4\u65B0\u6D77\u9A6C\u4F53 #${o.id.padStart(3,"0")}
105
- \u8DEF\u5F84: ${g}
106
- \u65B0\u7248\u672C: ${f.version+1}`;return await s.debug(`[haimati_edit] \u51FA\u53C2:
107
- ${_(d)}`),await s.info(`[haimati_edit] \u7F16\u8F91\u6210\u529F: #${o.id.padStart(3,"0")} -> v${f.version+1}`),d}catch(e){let r=e instanceof Error?e.message:String(e),c=e instanceof Error?e.stack:"";return await s.error(`[haimati_edit] \u51FA\u53C2: ${r}
108
- \u5806\u6808: ${c}`),`\u9519\u8BEF: ${r}`}}}),haimati_delete:x({description:`\u5220\u9664\u6D77\u9A6C\u4F53\u4E2D\u7684\u8BB0\u5FC6\u3002\u4EC5\u652F\u6301\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\u8981\u5220\u9664\u7684\u8BB0\u5FC6\u3002
142
+ - \u5355\u5904\u4FEE\u6539\uFF1Aquery="086", version=1, edits=[{offsetBegin:3,offsetEnd:5,content:"\u65B0\u5185\u5BB9"}]
143
+ - \u591A\u5904\u4FEE\u6539\uFF1Aquery="086", version=1, edits=[{offsetBegin:3,offsetEnd:5,content:"\u65B0\u5185\u5BB91"},{offsetBegin:10,offsetEnd:15,content:"\u65B0\u5185\u5BB92"}]
144
+ - \u66FF\u6362\u5355\u884C\uFF1Aedits=[{offsetBegin:3,offsetEnd:3,content:"\u65B0\u7684\u7B2C3\u884C"}]
145
+ - \u5220\u9664\u884C\uFF1Aedits=[{offsetBegin:3,offsetEnd:5,content:""}]`,args:{query:x.schema.string().describe("\u5E8F\u53F7\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u66F4\u65B0\u7684\u8BB0\u5FC6"),version:x.schema.number().describe("read \u65F6\u8FD4\u56DE\u7684 version\uFF0C\u7528\u4E8E\u5E76\u53D1\u63A7\u5236"),edits:x.schema.array(x.schema.object({offsetBegin:x.schema.number().describe("\u8D77\u59CB\u884C\u53F7\uFF08\u5305\u62EC\uFF09"),offsetEnd:x.schema.number().describe("\u7ED3\u675F\u884C\u53F7\uFF08\u5305\u62EC\u6B64\u884C\uFF09"),content:x.schema.string().describe("\u66FF\u6362\u5185\u5BB9")})).describe("\u7F16\u8F91\u64CD\u4F5C\u6570\u7EC4")},async execute(t,r){let e=N(r);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let o=L(e);if(await i.info(`[haimati_edit] \u5F00\u59CB\u7F16\u8F91 #${t.query}`),await i.debug(`[haimati_edit] \u5165\u53C2: query="${t.query}", version=${t.version}, edits=${JSON.stringify(t.edits)}`),!t.edits||t.edits.length===0)return await i.warn("[haimati_edit] \u51FA\u53C2: edits\u6570\u7EC4\u4E3A\u7A7A"),"\u9519\u8BEF\uFF1Aedits \u6570\u7EC4\u4E0D\u80FD\u4E3A\u7A7A";if(!await b(o))return await i.warn("[haimati_edit] \u51FA\u53C2: \u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728"),"\u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728";try{let n=await D(e),a=t.query.trim();if(!/^\d+$/.test(a))return await i.warn("[haimati_edit] \u51FA\u53C2: query\u65E0\u6548"),"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let l=String(parseInt(a,10)),s=F(n,l);if(!s)return await i.debug(`[haimati_edit] \u51FA\u53C2:
146
+ \u672A\u627E\u5230`),await i.info("[haimati_edit] \u7F16\u8F91\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6"),`\u672A\u627E\u5230\u4E0E '${a}' \u76F8\u5173\u7684\u8BB0\u5FC6`;let c=await v(e,s.id);if(!c)return await i.error("[haimati_edit] \u51FA\u53C2: \u4E66\u9875\u4E0D\u5B58\u5728"),`\u672A\u627E\u5230\u4E66\u9875: #${s.id.padStart(3,"0")}`;if(c.version!==t.version)return await i.warn("[haimati_edit] \u51FA\u53C2: \u7248\u672C\u51B2\u7A81"),`\u9519\u8BEF\uFF1A\u7248\u672C\u51B2\u7A81\uFF0C\u5F53\u524D version=${c.version}\uFF0C\u4F20\u5165 version=${t.version}\uFF0C\u8BF7\u91CD\u65B0\u8BFB\u53D6\u540E\u518D\u64CD\u4F5C`;let f=c.content.split(`
147
+ `).length;for(let d=0;d<t.edits.length;d++){let u=t.edits[d];if(u.offsetBegin<1||u.offsetBegin>f||u.offsetBegin>u.offsetEnd||u.offsetEnd>f)return await i.warn("[haimati_edit] \u51FA\u53C2: offset\u975E\u6CD5"),`\u9519\u8BEF\uFF1A\u7B2C ${d+1} \u4E2A\u7F16\u8F91\u64CD\u4F5C\u7684 offset \u975E\u6CD5\uFF0CoffsetBegin=${u.offsetBegin}, offsetEnd=${u.offsetEnd}, \u6587\u4EF6\u603B\u884C\u6570=${f}\uFF0C\u6709\u6548\u8303\u56F4 offsetBegin=[1, ${f}], offsetEnd=[offsetBegin, ${f}]`}for(let d=0;d<t.edits.length;d++)for(let u=d+1;u<t.edits.length;u++){let m=t.edits[d],y=t.edits[u];if(!(m.offsetEnd<y.offsetBegin||y.offsetEnd<m.offsetBegin))return await i.warn("[haimati_edit] \u51FA\u53C2: \u884C\u53F7\u8303\u56F4\u91CD\u53E0"),`\u9519\u8BEF\uFF1A\u7B2C ${d+1} \u4E2A\u548C\u7B2C ${u+1} \u4E2A\u7F16\u8F91\u64CD\u4F5C\u7684\u884C\u53F7\u8303\u56F4\u91CD\u53E0\uFF08[${m.offsetBegin},${m.offsetEnd}] \u548C [${y.offsetBegin},${y.offsetEnd}]\uFF09\uFF0C\u8BF7\u4FEE\u6539\u540E\u91CD\u8BD5`}let h=[...t.edits].sort((d,u)=>u.offsetBegin-d.offsetBegin),$=c.content;for(let d of h)$=St($,d.offsetBegin,d.offsetEnd,d.content);await j(e,s.id,s.title,c.createdAt,$,c.version+1);let w=`${s.category}/${s.title}`,g=t.edits.length===1?`\u5DF2\u66F4\u65B0\u6D77\u9A6C\u4F53 #${s.id.padStart(3,"0")}
148
+ \u8DEF\u5F84: ${w}
149
+ \u65B0\u7248\u672C: ${c.version+1}`:`\u5DF2\u66F4\u65B0\u6D77\u9A6C\u4F53 #${s.id.padStart(3,"0")}\uFF08\u5171 ${t.edits.length} \u5904\u4FEE\u6539\uFF09
150
+ \u8DEF\u5F84: ${w}
151
+ \u65B0\u7248\u672C: ${c.version+1}`;return await i.debug(`[haimati_edit] \u51FA\u53C2:
152
+ ${g}`),await i.info(`[haimati_edit] \u7F16\u8F91\u6210\u529F: #${s.id.padStart(3,"0")} -> v${c.version+1}`),g}catch(n){let a=n instanceof Error?n.message:String(n),l=n instanceof Error?n.stack:"";return await i.error(`[haimati_edit] \u51FA\u53C2: ${a}
153
+ \u5806\u6808: ${l}`),`\u9519\u8BEF: ${a}`}}}),haimati_delete:x({description:`\u5220\u9664\u6D77\u9A6C\u4F53\u4E2D\u7684\u8BB0\u5FC6\u3002\u4EC5\u652F\u6301\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\u8981\u5220\u9664\u7684\u8BB0\u5FC6\u3002
109
154
 
110
155
  \u529F\u80FD\u8BF4\u660E\uFF1A
111
156
  - \u901A\u8FC7\u5E8F\u53F7\uFF08\u5982 '086'\uFF09\u5B9A\u4F4D\u5E76\u5220\u9664\u6307\u5B9A\u8BB0\u5FC6
@@ -122,37 +167,136 @@ ${_(d)}`),await s.info(`[haimati_edit] \u7F16\u8F91\u6210\u529F: #${o.id.padStar
122
167
  \u6CE8\u610F\u4E8B\u9879\uFF1A
123
168
  - \u4EC5\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2\uFF0C\u4E0D\u652F\u6301\u5B8C\u6574\u8DEF\u5F84
124
169
  - \u5982\u679C\u4E0D\u786E\u5B9A\u8981\u5220\u9664\u7684\u8BB0\u5FC6\u5E8F\u53F7\uFF0C\u8BF7\u5148\u4F7F\u7528 haimati_search \u6216 haimati_list \u67E5\u627E
125
- - \u5220\u9664\u64CD\u4F5C\u4E0D\u53EF\u9006\uFF0C\u5EFA\u8BAE\u5148\u4F7F\u7528 haimati_read \u786E\u8BA4\u5185\u5BB9`,args:{query:x.schema.string().describe("\u5E8F\u53F7\u3002\u4F8B\u5982\uFF1A'086'")},async execute(t,i){let{directory:n}=i,a=I(n);if(await s.info(`[haimati_delete] \u5F00\u59CB\u5220\u9664 #${t.query}`),await s.debug(`[haimati_delete] \u5165\u53C2: query="${t.query}"`),!await $(a)){let e="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await s.warn(`[haimati_delete] \u51FA\u53C2:
126
- ${_(e)}`),e}try{let e=await b(n),r=t.query.trim();if(!/^\d+$/.test(r)){let m="\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";return await s.warn(`[haimati_delete] \u51FA\u53C2:
127
- ${_(m)}`),m}let c=String(parseInt(r,10)),o=C(e,c);if(await s.debug(`[haimati_delete] \u5E8F\u53F7\u67E5\u8BE2 #${r}: ${o?"\u627E\u5230":"\u672A\u627E\u5230"}`),!o){let m=`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;return await s.debug(`[haimati_delete] \u51FA\u53C2:
128
- ${_(m)}`),await s.info(`[haimati_delete] \u5220\u9664\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),m}await ht(n,o.id);let f=ut(e,o.id);await T(n,f);let u=`${o.category}/${o.title}`,l=`\u5DF2\u5220\u9664\u6D77\u9A6C\u4F53 #${o.id.padStart(3,"0")}
129
- \u8DEF\u5F84: ${u}`;return await s.debug(`[haimati_delete] \u51FA\u53C2:
130
- ${_(l)}`),await s.info(`[haimati_delete] \u5220\u9664\u6210\u529F: #${o.id.padStart(3,"0")} (${u})`),l}catch(e){let r=e instanceof Error?e.message:String(e),c=e instanceof Error?e.stack:"";return await s.error(`[haimati_delete] \u51FA\u53C2: \u9519\u8BEF: ${r}
131
- \u5806\u6808: ${c}`),await s.info(`[haimati_delete] \u5220\u9664\u5931\u8D25: ${r}`),`\u9519\u8BEF: ${r}`}}}),haimati_move:x({description:"\u4FEE\u6539\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7684\u5206\u7C7B\u8DEF\u5F84\u3002\u901A\u8FC7\u5E8F\u53F7\u6216\u5B8C\u6574\u8DEF\u5F84\u5B9A\u4F4D\u8BB0\u5FC6\uFF0C\u7136\u540E\u5C06\u5176\u79FB\u52A8\u5230\u65B0\u7684\u5206\u7C7B\u3002",args:{query:x.schema.string().describe("\u5E8F\u53F7\u6216\u5B8C\u6574\u8DEF\u5F84\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u79FB\u52A8\u7684\u8BB0\u5FC6"),newCategory:x.schema.string().describe("\u65B0\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u5BA2\u6237\u7AEF' \u6216 '\u901A\u7528'")},async execute(t,i){let{directory:n}=i,a=I(n);if(await s.info(`[haimati_move] \u5F00\u59CB\u79FB\u52A8 ${t.query} -> ${t.newCategory}`),await s.debug(`[haimati_move] \u5165\u53C2: query="${t.query}", newCategory="${t.newCategory}"`),!await $(a)){let e="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await s.warn(`[haimati_move] \u51FA\u53C2:
132
- ${_(e)}`),e}try{let e=await b(n),r=t.query.trim(),c=null;if(/^\d+$/.test(r))c=C(e,String(parseInt(r,10)));else{let g=r.split("/").filter(Boolean);if(g.length>=2){let d=g.pop(),y=g.join("/");c=Q(e,y,d)}else{let d=await tt(e,r,"or",n);if(d.length===1)c=d[0];else if(d.length>1){let y=d.slice(0,10).map(h=>` - ${h.category}/${h.title} [${h.id.padStart(3,"0")}]`).join(`
133
- `);return await s.info(`[haimati_move] \u79FB\u52A8\u5931\u8D25: \u591A\u6761\u5339\u914D (${d.length}\u6761)`),`\u627E\u5230\u591A\u6761\u5339\u914D\uFF0C\u8BF7\u4F7F\u7528\u5E8F\u53F7\u7CBE\u786E\u6307\u5B9A\uFF1A
134
- ${y}`}}}if(!c){let g=`\u672A\u627E\u5230\u4E0E '${r}' \u76F8\u5173\u7684\u8BB0\u5FC6`;return await s.debug(`[haimati_move] \u51FA\u53C2:
135
- ${_(g)}`),await s.info("[haimati_move] \u79FB\u52A8\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6"),g}let f=`${c.category}/${c.title}`,u=t.newCategory,l=`${u}/${c.title}`,m=e.map(g=>g.id===c.id?{...g,category:u}:g);await T(n,m);let p=`\u5DF2\u79FB\u52A8\u6D77\u9A6C\u4F53 #${c.id}
136
- \u65E7\u8DEF\u5F84: ${f}
137
- \u65B0\u8DEF\u5F84: ${l}`;return await s.debug(`[haimati_move] \u51FA\u53C2:
138
- ${_(p)}`),await s.info(`[haimati_move] \u79FB\u52A8\u6210\u529F: #${c.id} ${f} -> ${l}`),p}catch(e){let r=e instanceof Error?e.message:String(e),c=e instanceof Error?e.stack:"";return await s.error(`[haimati_move] \u51FA\u53C2: \u9519\u8BEF: ${r}
139
- \u5806\u6808: ${c}`),`\u9519\u8BEF: ${r}`}}}),haimati_list:x({description:"\u5217\u51FA\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u7684\u5B8C\u6574\u7D22\u5F15\u7ED3\u6784\u3002",args:{category:x.schema.string().optional().describe("\u53EF\u9009\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5217\u51FA\u8BE5\u5206\u7C7B\u4E0B\u7684\u6761\u76EE"),recursive:x.schema.boolean().optional().default(!1).describe("\u662F\u5426\u9012\u5F52\u904D\u5386\u5B50\u5206\u7C7B\uFF0C\u9ED8\u8BA4false")},async execute(t,i){let{directory:n}=i,a=I(n);if(await s.info(`[haimati_list] \u5F00\u59CB\u5217\u51FA${t.category?` ${t.category}`:" \u5168\u90E8"}`),await s.debug(`[haimati_list] \u5165\u53C2: category="${t.category||"(\u65E0)"}, recursive=${t.recursive}"`),!await $(a)){let e="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await s.warn(`[haimati_list] \u51FA\u53C2:
140
- ${_(e)}`),e}try{let e=await b(n);if(t.category){let f=(await mt(n)).split(`
141
- `),u=0,l=[];for(let d of f){if(!d.trim())continue;let y=R(d);if(d.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/))continue;let E=j(d);if(E&&(E==="/"?l[y]="":l[y]=E,l=l.slice(0,y+1),l.filter(Boolean).join("/")===t.category)){u=y;break}}let m=[],p=[];l=[];for(let d of f){if(!d.trim())continue;let y=R(d),h=d.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(h){let w=h[1].trim(),v=h[2];if(y===u+1){let U=l.slice(1,y).filter(Boolean).join("/");U===t.category&&p.push({category:U,title:w,id:v})}continue}let E=j(d);E&&(E==="/"?l[y]="":l[y]=E,l=l.slice(0,y+1),y===u+1&&l.filter(Boolean).join("/")===t.category&&m.push(E))}let g=`## ${t.category}
142
-
143
- `;if(t.recursive){let d=e.filter(h=>h.category===t.category||h.category.startsWith(t.category+"/")),y=new Map;for(let h of d){let w=h.category.slice(t.category.length+1).split("/")[0]||"(\u76F4\u63A5)";y.has(w)||y.set(w,[]),y.get(w).push(h)}for(let[h,E]of y)g+=`### ${h}/
144
- `,g+=E.map(w=>`- ${w.title} - ${w.id.padStart(3,"0")}`).join(`
170
+ - \u5220\u9664\u64CD\u4F5C\u4E0D\u53EF\u9006\uFF0C\u5EFA\u8BAE\u5148\u4F7F\u7528 haimati_read \u786E\u8BA4\u5185\u5BB9`,args:{query:x.schema.string().describe("\u5E8F\u53F7\u3002\u4F8B\u5982\uFF1A'086'")},async execute(t,r){let e=N(r);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let o=L(e);if(await i.info(`[haimati_delete] \u5F00\u59CB\u5220\u9664 #${t.query}`),await i.debug(`[haimati_delete] \u5165\u53C2: query="${t.query}"`),!await b(o)){let n="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await i.warn(`[haimati_delete] \u51FA\u53C2:
171
+ ${n}`),n}try{let n=await D(e),a=t.query.trim();if(!/^\d+$/.test(a)){let $="\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";return await i.warn(`[haimati_delete] \u51FA\u53C2:
172
+ ${$}`),$}let l=String(parseInt(a,10)),s=F(n,l);if(await i.debug(`[haimati_delete] \u5E8F\u53F7\u67E5\u8BE2 #${a}: ${s?"\u627E\u5230":"\u672A\u627E\u5230"}`),!s){let $=`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;return await i.debug(`[haimati_delete] \u51FA\u53C2:
173
+ ${$}`),await i.info(`[haimati_delete] \u5220\u9664\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),$}await vt(e,s.id);let c=_t(n,s.id);await R(e,c);let f=`${s.category}/${s.title}`,h=`\u5DF2\u5220\u9664\u6D77\u9A6C\u4F53 #${s.id.padStart(3,"0")}
174
+ \u8DEF\u5F84: ${f}`;return await i.debug(`[haimati_delete] \u51FA\u53C2:
175
+ ${h}`),await i.info(`[haimati_delete] \u5220\u9664\u6210\u529F: #${s.id.padStart(3,"0")} (${f})`),h}catch(n){let a=n instanceof Error?n.message:String(n),l=n instanceof Error?n.stack:"";return await i.error(`[haimati_delete] \u51FA\u53C2: \u9519\u8BEF: ${a}
176
+ \u5806\u6808: ${l}`),await i.info(`[haimati_delete] \u5220\u9664\u5931\u8D25: ${a}`),`\u9519\u8BEF: ${a}`}}}),haimati_move:x({description:`\u4FEE\u6539\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7684\u5206\u7C7B\u8DEF\u5F84\u548C/\u6216\u6807\u9898\u3002\u901A\u8FC7\u5E8F\u53F7\u5B9A\u4F4D\u8BB0\u5FC6\uFF0C\u7136\u540E\u4FEE\u6539\u5176\u5206\u7C7B\u548C\u6807\u9898\uFF0C\u5E8F\u53F7\u548C\u5185\u5BB9\u4FDD\u6301\u4E0D\u53D8\u3002
177
+
178
+ \u529F\u80FD\u8BF4\u660E\uFF1A
179
+ - \u901A\u8FC7\u5E8F\u53F7\uFF08\u5982 '086'\uFF09\u5B9A\u4F4D\u8BB0\u5FC6\uFF0C\u4FEE\u6539\u5176\u5206\u7C7B\u548C/\u6216\u6807\u9898
180
+ - \u652F\u6301\u5355\u72EC\u4FEE\u6539\u5206\u7C7B\uFF08newCategory\uFF09\u3001\u5355\u72EC\u4FEE\u6539\u6807\u9898\uFF08newTitle\uFF09\uFF0C\u6216\u540C\u65F6\u4FEE\u6539
181
+ - \u4FEE\u6539\u540E\u8BB0\u5FC6\u7684\u5E8F\u53F7\u548C\u5185\u5BB9\u4E0D\u53D8
182
+ - \u5E8F\u53F7\u652F\u6301\u81EA\u52A8\u8865\u5168\uFF1A\u8F93\u5165 '86' \u6216 '086' \u5747\u53EF\u5B9A\u4F4D\u5230\u5E8F\u53F7 086 \u7684\u8BB0\u5FC6
183
+
184
+ \u4F7F\u7528\u793A\u4F8B\uFF1A
185
+ - query="086", newCategory="xxx\u9879\u76EE/\u5BA2\u6237\u7AEF" \u2192 \u4EC5\u5C06\u5206\u7C7B\u79FB\u52A8\u5230"xxx\u9879\u76EE/\u5BA2\u6237\u7AEF"
186
+ - query="1", newTitle="\u65B0\u7684\u6807\u9898" \u2192 \u4EC5\u5C06\u6807\u9898\u6539\u4E3A"\u65B0\u7684\u6807\u9898"
187
+ - query="086", newCategory="xxx\u9879\u76EE/\u6587\u6863", newTitle="\u65B0\u6807\u9898" \u2192 \u540C\u65F6\u4FEE\u6539\u5206\u7C7B\u548C\u6807\u9898
188
+ - query="046", newCategory="\u901A\u7528" \u2192 \u5C06\u5E8F\u53F7 046 \u7684\u5206\u7C7B\u6539\u4E3A"\u901A\u7528"
189
+
190
+ \u6CE8\u610F\u4E8B\u9879\uFF1A
191
+ - query \u4EC5\u652F\u6301\u5E8F\u53F7\uFF08\u7EAF\u6570\u5B57\uFF09
192
+ - newCategory \u548C newTitle \u90FD\u662F\u53EF\u9009\u53C2\u6570\uFF0C\u81F3\u5C11\u9700\u8981\u63D0\u4F9B\u5176\u4E2D\u4E00\u4E2A
193
+ - \u5982\u679C\u4E0D\u786E\u5B9A\u8981\u4FEE\u6539\u7684\u8BB0\u5FC6\u5E8F\u53F7\uFF0C\u8BF7\u5148\u4F7F\u7528 haimati_search \u6216 haimati_list \u67E5\u627E
194
+ - \u4FEE\u6539\u4E0D\u4F1A\u5F71\u54CD\u8BB0\u5FC6\u7684\u5E8F\u53F7\u548C\u5185\u5BB9`,args:{query:x.schema.string().describe("\u5E8F\u53F7\u3002\u4F8B\u5982\uFF1A'086'"),newCategory:x.schema.string().optional().describe("\u65B0\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u5BA2\u6237\u7AEF' \u6216 '\u901A\u7528'"),newTitle:x.schema.string().optional().describe("\u65B0\u7684\u6807\u9898\uFF0C\u5982 '\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236v2'")},async execute(t,r){let e=N(r);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let o=L(e);if(await i.info(`[haimati_move] \u5F00\u59CB\u79FB\u52A8 ${t.query}`),await i.debug(`[haimati_move] \u5165\u53C2: query="${t.query}", newCategory="${t.newCategory}", newTitle="${t.newTitle}"`),!await b(o)){let n="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await i.warn(`[haimati_move] \u51FA\u53C2:
195
+ ${n}`),n}try{let n=await D(e),a=t.query.trim();if(!/^\d+$/.test(a)){let p="\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";return await i.warn(`[haimati_move] \u51FA\u53C2:
196
+ ${p}`),p}let l=String(parseInt(a,10)),s=F(n,l);if(!s){let p=`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;return await i.debug(`[haimati_move] \u51FA\u53C2:
197
+ ${p}`),await i.info(`[haimati_move] \u79FB\u52A8\u5931\u8D25: \u672A\u627E\u5230\u8BB0\u5FC6 #${t.query}`),p}let c=t.newCategory?.trim(),f=t.newTitle?.trim();if(!c&&!f){let p="\u9519\u8BEF\uFF1A\u81F3\u5C11\u9700\u8981\u63D0\u4F9B newCategory \u6216 newTitle \u4E2D\u7684\u4E00\u4E2A";return await i.warn(`[haimati_move] \u51FA\u53C2:
198
+ ${p}`),p}let h=s.category,$=s.title,w=c||h,g=f||$,d=`${h}/${$}`,u=`${w}/${g}`,m=n.map(p=>p.id===s.id?{...p,category:w,title:g}:p);if(await R(e,m),f){let p=await v(e,s.id);p&&await j(e,s.id,g,p.createdAt,p.content,p.version+1)}let y=`\u5DF2\u79FB\u52A8\u6D77\u9A6C\u4F53 #${s.id}
199
+ \u65E7\u8DEF\u5F84: ${d}
200
+ \u65B0\u8DEF\u5F84: ${u}`;return await i.debug(`[haimati_move] \u51FA\u53C2:
201
+ ${y}`),await i.info(`[haimati_move] \u79FB\u52A8\u6210\u529F: #${s.id} ${d} -> ${u}`),y}catch(n){let a=n instanceof Error?n.message:String(n),l=n instanceof Error?n.stack:"";return await i.error(`[haimati_move] \u51FA\u53C2: \u9519\u8BEF: ${a}
202
+ \u5806\u6808: ${l}`),`\u9519\u8BEF: ${a}`}}}),haimati_list:x({description:`\u5217\u51FA\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u7684\u7D22\u5F15\u7ED3\u6784\uFF0C\u652F\u6301\u6309\u5206\u7C7B\u6D4F\u89C8\u548C\u67E5\u770B\u8BE6\u7EC6\u5185\u5BB9\u3002
203
+
204
+ \u529F\u80FD\u8BF4\u660E\uFF1A
205
+ - \u65E0\u53C2\u6570\uFF1A\u5217\u51FA\u5B8C\u6574\u7684\u6811\u5F62\u7D22\u5F15\uFF0C\u5C55\u793A\u6240\u6709\u5206\u7C7B\u548C\u6761\u76EE
206
+ - \u6307\u5B9A category\uFF1A\u5217\u51FA\u6307\u5B9A\u5206\u7C7B\u4E0B\u7684\u76F4\u63A5\u5B50\u5206\u7C7B\u548C\u6761\u76EE
207
+ - \u6307\u5B9A category + recursive=true\uFF1A\u9012\u5F52\u5217\u51FA\u8BE5\u5206\u7C7B\u4E0B\u6240\u6709\u5C42\u7EA7\u7684\u6761\u76EE
208
+ - \u6307\u5B9A detail=true\uFF1A\u540C\u65F6\u663E\u793A\u6761\u76EE\u7684\u5B8C\u6574\u6B63\u6587\u5185\u5BB9
209
+
210
+ \u4F7F\u7528\u65F6\u673A\u5EFA\u8BAE\uFF1A
211
+ - \u4E0D\u786E\u5B9A\u8BB0\u5FC6\u5728\u54EA \u2192 \u65E0\u53C2\u6570\u5217\u51FA\u5168\u8C8C\uFF0C\u6216 detail=true \u5168\u6587\u641C\u7D22\u6D4F\u89C8
212
+ - \u5DF2\u786E\u5B9A\u5206\u7C7B\u8DEF\u5F84 \u2192 category="xxx"\uFF0C\u7F29\u5C0F\u8303\u56F4\u805A\u7126
213
+ - \u9700\u4E86\u89E3\u5B8C\u6574\u6761\u76EE \u2192 category="xxx" + recursive=true\uFF0C\u663E\u793A\u6240\u6709\u5C42\u7EA7
214
+ - \u9700\u9605\u8BFB\u5185\u5BB9 \u2192 \u52A0\u4E0A detail=true\uFF0C\u4E00\u6B65\u5230\u4F4D\u514D\u53BB\u4E8C\u6B21 haimati_read
215
+
216
+ \u8FD4\u56DE\u793A\u4F8B\uFF08\u65E0\u53C2\u6570\uFF09\uFF1A
217
+ /
218
+ \u251C\u2500\u2500 \u901A\u7528/
219
+ \u2502 \u2514\u2500\u2500 \u901A\u7528\u5F00\u53D1\u6280\u5DE7 - 002
220
+ \u2514\u2500\u2500 xxx\u9879\u76EE/
221
+ \u2514\u2500\u2500 \u914D\u7F6E/
222
+ \u2514\u2500\u2500 \u4E09\u7EA7\u914D\u7F6E\u7CFB\u7EDF\u8BBE\u8BA1 - 001
223
+
224
+ \u8FD4\u56DE\u793A\u4F8B\uFF08\u6307\u5B9A category + recursive=true\uFF09\uFF1A
225
+ ## xxx\u9879\u76EE
226
+
227
+ ### \u914D\u7F6E/
228
+ - \u4E09\u7EA7\u914D\u7F6E\u7CFB\u7EDF\u8BBE\u8BA1 - 001
229
+
230
+ ### \u7B7E\u7AE0/
231
+ - \u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236 - 086
232
+
233
+ \u8FD4\u56DE\u793A\u4F8B\uFF08\u6307\u5B9A category + recursive=true + detail=true\uFF09\uFF1A
234
+ ## xxx\u9879\u76EE
235
+
236
+ ### \u914D\u7F6E/
237
+ #### \u4E09\u7EA7\u914D\u7F6E\u7CFB\u7EDF\u8BBE\u8BA1 - 001
238
+ 1|\u5168\u5C40\u914D\u7F6E\u4F4D\u4E8E ~/.config/opencode/haimati.jsonc
239
+ 2|\u4E5F\u53EF\u901A\u8FC7 OPENCODE_CONFIG_DIR \u73AF\u5883\u53D8\u91CF\u81EA\u5B9A\u4E49
240
+ ...
241
+ ------system------
242
+ \u6807\u9898:\u4E09\u7EA7\u914D\u7F6E\u7CFB\u7EDF\u8BBE\u8BA1
243
+ \u521B\u5EFA\u65F6\u95F4:2026/5/7 10:30:00
244
+ version:2
245
+
246
+ \u6CE8\u610F\uFF1Adetail=true \u7684\u8F93\u51FA\u4E2D\uFF0C\u884C\u524D\u7684 "N|" \u8868\u793A\u884C\u53F7\uFF08\u5982 "1|xxx" \u8868\u793A\u7B2C 1 \u884C\uFF09\uFF0C\u4E0D\u662F\u8BB0\u5FC6\u5185\u5BB9\u7684\u4E00\u90E8\u5206
247
+
248
+ \u53C2\u6570\u7EC4\u5408\u793A\u4F8B\uFF1A
249
+ - \uFF08\u65E0\u53C2\u6570\uFF09\u2192 \u663E\u793A\u5B8C\u6574\u6811\u5F62\u7D22\u5F15
250
+ - category="\u901A\u7528" \u2192 \u663E\u793A"\u901A\u7528"\u5206\u7C7B\u4E0B\u7684\u5B50\u5206\u7C7B\u548C\u6761\u76EE
251
+ - category="\u901A\u7528", recursive=true \u2192 \u9012\u5F52\u663E\u793A"\u901A\u7528"\u4E0B\u6240\u6709\u6761\u76EE
252
+ - category="\u901A\u7528", recursive=true, detail=true \u2192 \u663E\u793A"\u901A\u7528"\u4E0B\u6240\u6709\u6761\u76EE\u7684\u5B8C\u6574\u5185\u5BB9
253
+ - detail=true \u2192 \u663E\u793A\u6240\u6709\u6761\u76EE\u7684\u8BE6\u7EC6\u5185\u5BB9\uFF08\u6309\u9876\u7EA7\u5206\u7C7B\u5206\u7EC4\uFF09`,args:{category:x.schema.string().optional().describe("\u53EF\u9009\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5217\u51FA\u8BE5\u5206\u7C7B\u4E0B\u7684\u6761\u76EE"),recursive:x.schema.boolean().optional().default(!1).describe("\u662F\u5426\u9012\u5F52\u904D\u5386\u5B50\u5206\u7C7B\uFF0C\u9ED8\u8BA4false"),detail:x.schema.boolean().optional().default(!1).describe("\u662F\u5426\u663E\u793A\u8BB0\u5FC6\u7684\u8BE6\u7EC6\u5185\u5BB9\uFF0C\u9ED8\u8BA4false")},async execute(t,r){let e=N(r);if(!e)return"\u9519\u8BEF\uFF1A\u7F3A\u5C11 directory \u914D\u7F6E";let o=L(e);if(await i.info(`[haimati_list] \u5F00\u59CB\u5217\u51FA${t.category?` ${t.category}`:" \u5168\u90E8"}${t.detail?" (\u8BE6\u7EC6\u6A21\u5F0F)":""}`),await i.debug(`[haimati_list] \u5165\u53C2: category="${t.category||"(\u65E0)"}, recursive=${t.recursive}, detail=${t.detail}`),!await b(o)){let n="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await i.warn(`[haimati_list] \u51FA\u53C2:
254
+ ${n}`),n}try{let n=await D(e);if(t.category){let c=(await Et(e)).split(`
255
+ `),f=0,h=[];for(let d of c){if(!d.trim())continue;let u=J(d);if(d.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/))continue;let y=V(d);if(y&&(y==="/"?h[u]="":h[u]=y,h=h.slice(0,u+1),h.filter(Boolean).join("/")===t.category)){f=u;break}}let $=[],w=[];h=[];for(let d of c){if(!d.trim())continue;let u=J(d),m=d.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(m){let p=m[1].trim(),_=m[2];if(u===f+1){let P=h.slice(1,u).filter(Boolean).join("/");P===t.category&&w.push({category:P,title:p,id:_})}continue}let y=V(d);y&&(y==="/"?h[u]="":h[u]=y,h=h.slice(0,u+1),u===f+1&&h.filter(Boolean).join("/")===t.category&&$.push(y))}await i.debug(`[haimati_list] \u5206\u7C7B "${t.category}": targetDepth=${f}, subCategories=${$.length}, directEntries=${w.length}`);let g=`## ${t.category}
256
+
257
+ `;if(t.recursive){let d=n.filter(m=>m.category===t.category||m.category.startsWith(t.category+"/"));await i.debug(`[haimati_list] \u9012\u5F52\u6A21\u5F0F: \u540E\u4EE3\u6761\u76EE\u6570=${d.length}`);let u=new Map;for(let m of d){let p=m.category.slice(t.category.length+1).split("/")[0]||"(\u76F4\u63A5)";u.has(p)||u.set(p,[]),u.get(p).push(m)}for(let[m,y]of u)g+=`### ${m}/
258
+ `,g+=y.map(p=>`- ${p.title} - ${p.id.padStart(3,"0")}`).join(`
259
+ `)+`
260
+
261
+ `}else $.length>0&&(g+=`**\u5B50\u5206\u7C7B\uFF1A**
262
+ `+$.map(d=>`- ${d}/`).join(`
263
+ `)+`
264
+
265
+ `),w.length>0&&(g+=`**\u76F4\u63A5\u6761\u76EE\uFF1A**
266
+ `+w.map(d=>`- ${d.title} - ${d.id.padStart(3,"0")}`).join(`
267
+ `));if(t.detail){let d=t.recursive?n.filter(u=>u.category===t.category||u.category.startsWith(t.category+"/")):n.filter(u=>u.category===t.category);if(await i.debug(`[haimati_list] detail\u6A21\u5F0F: \u5339\u914D ${d.length} \u6761\u6761\u76EE`),d.length>0)if(t.recursive){let u=`## ${t.category}
268
+
269
+ `,m=new Map;for(let y of d){let p=y.category.slice(t.category.length+1).split("/")[0]||"(\u76F4\u63A5)";m.has(p)||m.set(p,[]),m.get(p).push(y)}for(let[y,p]of m){u+=`### ${y}/
270
+ `;for(let _ of p){let P=await v(e,_.id);if(!P){u+=`- ${_.title} - ${_.id.padStart(3,"0")} (\u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728)
271
+
272
+ `;continue}await i.debug(`[haimati_list] detail: #${_.id} (${_.title}), version=${P.version}`);let I=P.content.split(`
273
+ `),S=[];for(let E=0;E<I.length;E++)S.push(`${E+1}|${I[E]}`);S.push("------system------"),S.push(`\u6807\u9898:${_.title}`),S.push(`\u521B\u5EFA\u65F6\u95F4:${P.createdAt}`),S.push(`version:${P.version}`),u+=`#### ${_.title} - ${_.id.padStart(3,"0")}
274
+ `,u+=S.join(`
145
275
  `)+`
146
276
 
147
- `}else m.length>0&&(g+=`**\u5B50\u5206\u7C7B\uFF1A**
148
- `+m.map(d=>`- ${d}/`).join(`
277
+ `}}g=u}else{g+=`
278
+ **\u8BE6\u7EC6\u5185\u5BB9\uFF1A**
279
+
280
+ `;for(let u of d){let m=await v(e,u.id);if(!m){g+=`- ${u.title} - ${u.id.padStart(3,"0")} (\u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728)
281
+
282
+ `;continue}await i.debug(`[haimati_list] detail: #${u.id} (${u.title}), version=${m.version}`);let y=m.content.split(`
283
+ `),p=[];for(let _=0;_<y.length;_++)p.push(`${_+1}|${y[_]}`);p.push("------system------"),p.push(`\u6807\u9898:${u.title}`),p.push(`\u521B\u5EFA\u65F6\u95F4:${m.createdAt}`),p.push(`version:${m.version}`),g+=`#### ${u.title} - ${u.id.padStart(3,"0")}
284
+ `,g+=p.join(`
285
+ `)+`
286
+
287
+ `}}}return await i.debug(`[haimati_list] \u51FA\u53C2:
288
+ ${g}`),await i.info(`[haimati_list] \u5217\u51FA\u6210\u529F: ${t.category}${t.detail?" (\u8BE6\u7EC6\u6A21\u5F0F)":""}`),g}if(t.detail){await i.debug(`[haimati_list] detail\u6A21\u5F0F: \u5171 ${n.length} \u6761\u6761\u76EE`);let s=`## \u6D77\u9A6C\u4F53\u7D22\u5F15\u8BE6\u60C5
289
+
290
+ `,c=new Map;for(let h of n){let $=h.category.split("/")[0]||"(\u65E0\u5206\u7C7B)";c.has($)||c.set($,[]),c.get($).push(h)}for(let[h,$]of c){s+=`### ${h}/
291
+
292
+ `;for(let w of $){let g=await v(e,w.id);if(!g){await i.warn(`[haimati_list] detail: #${w.id} (${w.title}) \u4E66\u9875\u6587\u4EF6\u4E0D\u5B58\u5728`);continue}await i.debug(`[haimati_list] detail: #${w.id} (${w.category}/${w.title}), version=${g.version}`);let d=g.content.split(`
293
+ `),u=[];for(let m=0;m<d.length;m++)u.push(`${m+1}|${d[m]}`);u.push("------system------"),u.push(`\u6807\u9898:${w.title}`),u.push(`\u521B\u5EFA\u65F6\u95F4:${g.createdAt}`),u.push(`version:${g.version}`),s+=`#### ${w.category}/${w.title} - ${w.id.padStart(3,"0")}
294
+ `,s+=u.join(`
149
295
  `)+`
150
296
 
151
- `),p.length>0&&(g+=`**\u76F4\u63A5\u6761\u76EE\uFF1A**
152
- `+p.map(d=>`- ${d.title} - ${d.id.padStart(3,"0")}`).join(`
153
- `));return await s.debug(`[haimati_list] \u51FA\u53C2:
154
- ${_(g)}`),await s.info(`[haimati_list] \u5217\u51FA\u6210\u529F: ${t.category||"(\u5168\u90E8)"}`),g}let c=`## \u6D77\u9A6C\u4F53\u7D22\u5F15
297
+ `}}let f=s;return await i.debug(`[haimati_list] \u51FA\u53C2:
298
+ ${f}`),await i.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8 (\u8BE6\u7EC6\u6A21\u5F0F)"),f}let l=`## \u6D77\u9A6C\u4F53\u7D22\u5F15
155
299
 
156
- ${Z(e)||"(\u7A7A)"}`;return await s.debug(`[haimati_list] \u51FA\u53C2:
157
- ${_(c)}`),await s.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8"),c}catch(e){let r=e instanceof Error?e.message:String(e),c=e instanceof Error?e.stack:"";return await s.error(`[haimati_list] \u51FA\u53C2: \u9519\u8BEF: ${r}
158
- \u5806\u6808: ${c}`),`\u9519\u8BEF: ${r}`}}})}}var Ze=async t=>{await Pt(),await s.debug("\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u63D2\u4EF6\u5DF2\u52A0\u8F7D");let{client:i}=t;return{tool:Lt()}};export{Ze as HaimatiPlugin};
300
+ ${ot(n)||"(\u7A7A)"}`;return await i.debug(`[haimati_list] \u51FA\u53C2:
301
+ ${l}`),await i.info("[haimati_list] \u5217\u51FA\u6210\u529F: \u5168\u90E8"),l}catch(n){let a=n instanceof Error?n.message:String(n),l=n instanceof Error?n.stack:"";return await i.error(`[haimati_list] \u51FA\u53C2: \u9519\u8BEF: ${a}
302
+ \u5806\u6808: ${l}`),`\u9519\u8BEF: ${a}`}}})}}var bi=async t=>{await gt(),await i.debug("\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u63D2\u4EF6\u5DF2\u52A0\u8F7D");let{client:r}=t;return{tool:jt()}};export{bi as HaimatiPlugin};
package/dist/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "opencode-haimati",
3
- "version": "1.2.2",
3
+ "version": "1.2.4",
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",
@@ -9,11 +9,12 @@
9
9
  "dist"
10
10
  ],
11
11
  "scripts": {
12
- "build": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin --minify && cp package.json dist/",
13
- "build:uncompressed": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin && cp package.json dist/",
12
+ "build": "if (Test-Path dist) { Remove-Item -Recurse -Force dist }; npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin --minify; Copy-Item package.json dist/",
13
+ "build:uncompressed": "if (Test-Path dist) { Remove-Item -Recurse -Force dist }; npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin; Copy-Item package.json dist/",
14
14
  "typecheck": "tsc --noEmit",
15
15
  "prepublishOnly": "npm run build",
16
- "test": "npx tsx test/index.ts"
16
+ "publish": "node scripts/publish-npmjs.js",
17
+ "debug-build-copy": "node scripts/debug-build-copy.js"
17
18
  },
18
19
  "peerDependencies": {
19
20
  "@opencode-ai/plugin": ">=0.15.0",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "opencode-haimati",
3
- "version": "1.2.2",
3
+ "version": "1.2.4",
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",
@@ -9,11 +9,12 @@
9
9
  "dist"
10
10
  ],
11
11
  "scripts": {
12
- "build": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin --minify && cp package.json dist/",
13
- "build:uncompressed": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin && cp package.json dist/",
12
+ "build": "if (Test-Path dist) { Remove-Item -Recurse -Force dist }; npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin --minify; Copy-Item package.json dist/",
13
+ "build:uncompressed": "if (Test-Path dist) { Remove-Item -Recurse -Force dist }; npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin; Copy-Item package.json dist/",
14
14
  "typecheck": "tsc --noEmit",
15
15
  "prepublishOnly": "npm run build",
16
- "test": "npx tsx test/index.ts"
16
+ "publish": "node scripts/publish-npmjs.js",
17
+ "debug-build-copy": "node scripts/debug-build-copy.js"
17
18
  },
18
19
  "peerDependencies": {
19
20
  "@opencode-ai/plugin": ">=0.15.0",