@ppdocs/mcp 3.2.30 → 3.2.32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.js +28 -12
- package/package.json +1 -1
- package/templates/cursorrules.md +47 -0
- package/templates/kiro-rules/ppdocs.md +47 -0
package/dist/cli.js
CHANGED
|
@@ -155,6 +155,20 @@ function writePpdocsConfig(cwd, opts) {
|
|
|
155
155
|
}
|
|
156
156
|
async function initProject(opts) {
|
|
157
157
|
const cwd = process.cwd();
|
|
158
|
+
// ★ 版本检查: 防止 npx 缓存导致安装旧版
|
|
159
|
+
const pkg = JSON.parse(fs.readFileSync(path.join(__dirname, '..', 'package.json'), 'utf-8'));
|
|
160
|
+
const currentVersion = pkg.version;
|
|
161
|
+
try {
|
|
162
|
+
const latest = execSync('npm view @ppdocs/mcp version', { encoding: 'utf-8', timeout: 5000 }).trim();
|
|
163
|
+
if (latest && latest !== currentVersion) {
|
|
164
|
+
console.log(`\n⚠️ 当前版本 ${currentVersion}, 最新版本 ${latest}`);
|
|
165
|
+
console.log(` npx 缓存了旧版本, 请运行:\n`);
|
|
166
|
+
console.log(` npx -y @ppdocs/mcp@${latest} init ${process.argv.slice(3).join(' ')}\n`);
|
|
167
|
+
console.log(` 或清除缓存: rm -rf ~/.npm/_npx && npx -y @ppdocs/mcp@latest init ...\n`);
|
|
168
|
+
process.exit(1);
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
catch { /* 离线或超时, 跳过检查 */ }
|
|
158
172
|
const apiUrl = writePpdocsConfig(cwd, opts);
|
|
159
173
|
// Install workflow templates based on IDE detection
|
|
160
174
|
const detectedIdes = detectIDEs(cwd);
|
|
@@ -539,21 +553,23 @@ function installCursorTemplates(cwd, apiUrl, user) {
|
|
|
539
553
|
// ★ 通用工作流安装 — 全平台共享 (删旧 + 写新)
|
|
540
554
|
// 所有 IDE 最终都通过此函数安装 .agents/workflows/ 下的工作流文件
|
|
541
555
|
// ========================================================================
|
|
542
|
-
/** 工作流版本映射表: 模板文件名 → { 工作流命令名, 描述 } */
|
|
556
|
+
/** 工作流版本映射表: 模板文件名 → { 工作流命令名, 描述 } — 仅保留 5 个核心 */
|
|
543
557
|
const WORKFLOW_MAP = {
|
|
544
|
-
'
|
|
545
|
-
'
|
|
546
|
-
'sync.md': { name: 'pp-sync', desc: 'Knowledge Graph Deep-Sync Protocol' },
|
|
547
|
-
'review.md': { name: 'pp-shencha', desc: '审查任务成果' },
|
|
558
|
+
'init.md': { name: 'pp-init', desc: '知识图谱初始化' },
|
|
559
|
+
'sync.md': { name: 'pp-sync', desc: '知识图谱同步' },
|
|
548
560
|
'diagnose.md': { name: 'pp-diagnose', desc: '深度问题诊断' },
|
|
549
|
-
'
|
|
550
|
-
'
|
|
551
|
-
'discuss.md': { name: 'pp-discuss', desc: '讨论响应与协作' },
|
|
552
|
-
'Zero_Defec_Genesis.md': { name: 'plan', desc: '零缺陷创生协议' },
|
|
553
|
-
'SynchronizationProtocol.md': { name: 'pp-syncpro', desc: 'Knowledge Graph Quick-Sync Protocol' },
|
|
561
|
+
'Zero_Defec_Genesis.md': { name: 'plan', desc: '方案制定' },
|
|
562
|
+
'review.md': { name: 'pp-shencha', desc: '任务成果审查' },
|
|
554
563
|
};
|
|
555
|
-
/** 已废弃的旧版工作流文件名 (
|
|
556
|
-
const LEGACY_WORKFLOW_NAMES = [
|
|
564
|
+
/** 已废弃的旧版工作流文件名 (安装时自动清理) */
|
|
565
|
+
const LEGACY_WORKFLOW_NAMES = [
|
|
566
|
+
// 旧版中文名
|
|
567
|
+
'pp-fenxi.md', 'pp-review.md',
|
|
568
|
+
// 旧版英文名
|
|
569
|
+
'diagnosticprotocol.md', 'zhixing.md', 'paln.md', 'fenxi.md', 'shencha.md',
|
|
570
|
+
// v3.2.31 移除的工作流
|
|
571
|
+
'pp-task.md', 'pp-execute.md', 'pp-audit.md', 'pp-discuss.md', 'pp-syncpro.md',
|
|
572
|
+
];
|
|
557
573
|
/**
|
|
558
574
|
* 通用工作流安装: 删除旧版 → 写入最新版到 .agents/workflows/
|
|
559
575
|
* 全平台共享: Antigravity / Claude Code / Cursor / Codex / Kiro
|
package/package.json
CHANGED
package/templates/cursorrules.md
CHANGED
|
@@ -26,6 +26,53 @@ kg_discuss(action:"list") → 检查待回复讨论
|
|
|
26
26
|
|
|
27
27
|
---
|
|
28
28
|
|
|
29
|
+
## 方案制定 (第一性原理)
|
|
30
|
+
|
|
31
|
+
**任何需求,先设计逻辑流程,再写代码。禁止跳过设计直接编码。**
|
|
32
|
+
|
|
33
|
+
### Phase A: 第一性原理分析
|
|
34
|
+
```
|
|
35
|
+
1. 拆解需求本质: 这个功能的核心目的是什么?
|
|
36
|
+
2. 识别输入/输出: 进什么 → 出什么?
|
|
37
|
+
3. 查图谱现状: kg_flowchart(get) → 哪些模块已存在可复用?
|
|
38
|
+
4. 最小化依赖: 能否用最少的模块、最短的路径实现?
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
### Phase B: 逻辑流程设计
|
|
42
|
+
```
|
|
43
|
+
用 ASCII 流程图画出完整逻辑:
|
|
44
|
+
|
|
45
|
+
+----------+ +----------+ +----------+
|
|
46
|
+
| 输入 | --> | 处理逻辑 | --> | 输出 |
|
|
47
|
+
+----------+ +----+-----+ +----------+
|
|
48
|
+
|
|
|
49
|
+
+----v-----+
|
|
50
|
+
| 异常分支 |
|
|
51
|
+
+----------+
|
|
52
|
+
|
|
53
|
+
向用户展示流程图,确认逻辑正确后再继续。
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
### Phase C: 细化逻辑节点
|
|
57
|
+
```
|
|
58
|
+
对流程图中每个节点,依次向下细化:
|
|
59
|
+
1. 定义接口: 输入参数 + 返回值
|
|
60
|
+
2. 选择实现: 复用现有 / 新建模块
|
|
61
|
+
3. 标注依赖: 上游数据来源 + 下游消费者
|
|
62
|
+
4. 异常处理: 每个节点的失败路径
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
### Phase D: 按流程执行 + 审查
|
|
66
|
+
```
|
|
67
|
+
按 Phase B 确认的逻辑流程,逐节点实现:
|
|
68
|
+
使用 Step 3 的逐步执行循环 (执行→验证→记录→回写)
|
|
69
|
+
|
|
70
|
+
全部完成后:
|
|
71
|
+
对照逻辑流程图进行审查,确保实现与设计一致
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
---
|
|
75
|
+
|
|
29
76
|
## 标准执行流程
|
|
30
77
|
|
|
31
78
|
### Step 1: 知识锚定 (理解需求时)
|
|
@@ -26,6 +26,53 @@ kg_discuss(action:"list") → 检查待回复讨论
|
|
|
26
26
|
|
|
27
27
|
---
|
|
28
28
|
|
|
29
|
+
## 方案制定 (第一性原理)
|
|
30
|
+
|
|
31
|
+
**任何需求,先设计逻辑流程,再写代码。禁止跳过设计直接编码。**
|
|
32
|
+
|
|
33
|
+
### Phase A: 第一性原理分析
|
|
34
|
+
```
|
|
35
|
+
1. 拆解需求本质: 这个功能的核心目的是什么?
|
|
36
|
+
2. 识别输入/输出: 进什么 → 出什么?
|
|
37
|
+
3. 查图谱现状: kg_flowchart(get) → 哪些模块已存在可复用?
|
|
38
|
+
4. 最小化依赖: 能否用最少的模块、最短的路径实现?
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
### Phase B: 逻辑流程设计
|
|
42
|
+
```
|
|
43
|
+
用 ASCII 流程图画出完整逻辑:
|
|
44
|
+
|
|
45
|
+
+----------+ +----------+ +----------+
|
|
46
|
+
| 输入 | --> | 处理逻辑 | --> | 输出 |
|
|
47
|
+
+----------+ +----+-----+ +----------+
|
|
48
|
+
|
|
|
49
|
+
+----v-----+
|
|
50
|
+
| 异常分支 |
|
|
51
|
+
+----------+
|
|
52
|
+
|
|
53
|
+
向用户展示流程图,确认逻辑正确后再继续。
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
### Phase C: 细化逻辑节点
|
|
57
|
+
```
|
|
58
|
+
对流程图中每个节点,依次向下细化:
|
|
59
|
+
1. 定义接口: 输入参数 + 返回值
|
|
60
|
+
2. 选择实现: 复用现有 / 新建模块
|
|
61
|
+
3. 标注依赖: 上游数据来源 + 下游消费者
|
|
62
|
+
4. 异常处理: 每个节点的失败路径
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
### Phase D: 按流程执行 + 审查
|
|
66
|
+
```
|
|
67
|
+
按 Phase B 确认的逻辑流程,逐节点实现:
|
|
68
|
+
使用 Step 3 的逐步执行循环 (执行→验证→记录→回写)
|
|
69
|
+
|
|
70
|
+
全部完成后:
|
|
71
|
+
对照逻辑流程图进行审查,确保实现与设计一致
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
---
|
|
75
|
+
|
|
29
76
|
## 标准执行流程
|
|
30
77
|
|
|
31
78
|
### Step 1: 知识锚定 (理解需求时)
|