gitlab-ai-review 3.2.5 → 3.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/index.js CHANGED
@@ -275,9 +275,28 @@ export class GitLabAIReview {
275
275
  // 构建整个文件的批量审查消息
276
276
  const messages = PromptTools.buildFileReviewMessages(fileName, meaningfulChanges, projectPrompt);
277
277
 
278
+ // 🔍 输出完整的 Prompt(用于调试)
279
+ console.log('\n' + '='.repeat(80));
280
+ console.log('🔍 发送给 AI 的完整 Prompt:');
281
+ console.log('='.repeat(80));
282
+ messages.forEach((msg, index) => {
283
+ console.log(`\n📝 消息 ${index + 1} [${msg.role}]:`);
284
+ console.log('-'.repeat(80));
285
+ console.log(msg.content);
286
+ });
287
+ console.log('\n' + '='.repeat(80));
288
+ console.log('⏳ 等待 AI 响应...\n');
289
+
278
290
  // 调用 AI(一次调用审查整个文件)
279
291
  const response = await aiClient.sendMessage(messages);
280
292
 
293
+ // 🔍 输出 AI 的原始返回(用于调试)
294
+ console.log('\n' + '='.repeat(80));
295
+ console.log('📥 AI 原始返回:');
296
+ console.log('='.repeat(80));
297
+ console.log(response.content);
298
+ console.log('='.repeat(80) + '\n');
299
+
281
300
  // 解析 AI 返回的 JSON
282
301
  try {
283
302
  // 提取 JSON(可能被包裹在 ```json ``` 中)
@@ -451,9 +470,28 @@ export class GitLabAIReview {
451
470
  ? PromptTools.buildFileReviewWithImpactMessages(fileName, meaningfulChanges, impactAnalysis, projectPrompt)
452
471
  : PromptTools.buildFileReviewMessages(fileName, meaningfulChanges, projectPrompt);
453
472
 
473
+ // 🔍 输出完整的 Prompt(用于调试)
474
+ console.log('\n' + '='.repeat(80));
475
+ console.log('🔍 发送给 AI 的完整 Prompt (包含影响分析):');
476
+ console.log('='.repeat(80));
477
+ messages.forEach((msg, index) => {
478
+ console.log(`\n📝 消息 ${index + 1} [${msg.role}]:`);
479
+ console.log('-'.repeat(80));
480
+ console.log(msg.content);
481
+ });
482
+ console.log('\n' + '='.repeat(80));
483
+ console.log('⏳ 等待 AI 响应...\n');
484
+
454
485
  // 调用 AI(一次调用审查整个文件)
455
486
  const response = await aiClient.sendMessage(messages);
456
487
 
488
+ // 🔍 输出 AI 的原始返回(用于调试)
489
+ console.log('\n' + '='.repeat(80));
490
+ console.log('📥 AI 原始返回 (包含影响分析):');
491
+ console.log('='.repeat(80));
492
+ console.log(response.content);
493
+ console.log('='.repeat(80) + '\n');
494
+
457
495
  // 解析 AI 返回的 JSON
458
496
  try {
459
497
  // 提取 JSON(可能被包裹在 ```json ``` 中)
@@ -115,6 +115,7 @@ export function extractMeaningfulChanges(hunks) {
115
115
 
116
116
  hunks.forEach(hunk => {
117
117
  let currentNewLine = hunk.newStart;
118
+ let currentOldLine = hunk.oldStart;
118
119
 
119
120
  hunk.changes.forEach((change, index) => {
120
121
  if (change.type === 'addition') {
@@ -141,7 +142,7 @@ export function extractMeaningfulChanges(hunks) {
141
142
  meaningfulChanges.push({
142
143
  type: 'deletion',
143
144
  content: change.content,
144
- oldLineNumber: currentNewLine,
145
+ lineNumber: currentOldLine, // 使用旧文件的行号
145
146
  hunk: hunk.header,
146
147
  context: {
147
148
  before: hunk.changes.slice(Math.max(0, index - 2), index).map(c => c.content),
@@ -149,8 +150,10 @@ export function extractMeaningfulChanges(hunks) {
149
150
  },
150
151
  });
151
152
  }
153
+ currentOldLine++;
152
154
  } else if (change.type === 'context') {
153
155
  currentNewLine++;
156
+ currentOldLine++;
154
157
  }
155
158
  });
156
159
  });
@@ -110,12 +110,7 @@ export function buildFileReviewPrompt(fileName, meaningfulChanges) {
110
110
  - 如果没有定义特殊格式,使用中文简洁描述即可
111
111
 
112
112
  6. 如果所有代码都没有问题,返回空的 reviews 数组:\`{"reviews": []}\`
113
- 7. **只返回 JSON**,不要在 JSON 外面添加任何文字说明
114
-
115
- **再次强调:**
116
- - 看到 "类型: 删除" 和 "-" → 代码被移除了
117
- - 看到 "类型: 新增" 和 "+" → 代码是新加的
118
- - 不要混淆删除和新增!`;
113
+ 7. 只返回 JSON,不要包含其他文字说明`;
119
114
 
120
115
  return prompt;
121
116
  }
@@ -278,83 +273,14 @@ export function buildFileReviewWithImpactPrompt(fileName, meaningfulChanges, imp
278
273
  prompt += `\`\`\`\n`;
279
274
  });
280
275
 
281
- prompt += `\n## ⚠️ 🚨 最重要的规则:理解代码修改 vs 重复定义
282
-
283
- **🔥 核心概念(必读):**
284
-
285
- 在 diff 中,如果你看到:
286
- - 第一行:**"-"** 开头(删除旧值)
287
- - 第二行:**"+"** 开头(添加新值)
288
- - 并且是同一个变量名或属性名
289
-
290
- 这是 **"修改/替换"**,NOT "重复定义"!
291
-
292
- **❌ 常见错误(请务必避免):**
293
-
294
- **错误 1:对象属性修改**
295
- 看到 diff:
296
- - deleted: deletedSymbols,
297
- + deleted: allDeleted,
298
-
299
- 错误理解:❌ "返回对象中存在重复的 'deleted' 键,违反对象键唯一性"
300
- 正确理解:✅ "将 deleted 属性的值从 deletedSymbols 修改为 allDeleted"
301
-
302
- 解释:
303
- - 旧版本(-)的 "deleted: deletedSymbols" 已经被删除了,不存在了
304
- - 新版本(+)的 "deleted: allDeleted" 是现在的版本
305
- - 最终代码中只有一个 deleted 键,没有重复!
306
-
307
- **错误 2:变量赋值修改**
308
- 看到 diff:
309
- - const name = 'old';
310
- + const name = 'new';
311
-
312
- 错误理解:❌ "定义了两次 name 变量"
313
- 正确理解:✅ "修改了 name 的初始值"
276
+ prompt += `\n## 审查要求
314
277
 
315
- **错误 3:属性值修改**
316
- 看到 diff:
317
- - all: [...addedSymbols, ...deletedSymbols],
318
- + all: [...addedSymbols, ...allDeleted],
319
-
320
- 错误理解:❌ "all 属性重复定义"
321
- 正确理解:✅ "修改了 all 数组的第二个展开项"
322
-
323
- **🎯 判断标准:**
324
-
325
- 1. **如何判断是修改而非重复?**
326
- - 看是否在**相邻的行**
327
- - 一行是 **"-"**(删除)
328
- - 下一行是 **"+"**(新增)
329
- - **同一个变量名/属性名**
330
- → 这就是**修改**!
331
-
332
- 2. **如何判断是真正的重复定义?**
333
- - 两行都是 **"+"**(新增)
334
- - 没有对应的 **"-"**(删除)
335
- - 同一个变量名/属性名
336
- → 这才是**重复定义**!
337
-
338
- **🚨 重要提醒:**
339
- - **"-"** 开头的代码已经**不存在**了,不要把它当作"存在"
340
- - **"+"** 开头的代码才是**最终保留**的版本
341
- - 不要说"存在两个XXX",应该说"将XXX从A修改为B"
342
-
343
- ## 审查要求
344
-
345
- 1. **首先确认变更类型**:看清楚是"删除"还是"新增"
346
- 2. **🚨 最高优先级**:检查"类型: 删除"的符号是否仍被使用(文件内部或其他文件)
347
- 3. **特别关注**:
348
- - **删除的函数/类/组件**是否在其他地方被调用(这会导致错误)
349
- - 修改的函数签名是否会导致现有调用失效
350
- - 新增的代码质量是否符合规范
351
- 4. 检查函数签名是否改变,所有调用方式是否需要更新
352
- 5. 检查是否有潜在的 API 不兼容问题
353
- 6. 如果发现文件内部使用了**被删除**的符号,这是**严重错误**
354
- 7. 如果发现其他文件使用了**被删除/修改**的符号,需要提醒可能的影响
355
- 8. **只对有问题的行提出审查意见**,没有问题的行不需要评论
356
- 9. **必须使用中文**返回审查意见
357
- 10. **必须返回标准 JSON 格式**,不要用其他格式,结构如下:
278
+ 1. 仔细审查每一行变更,判断是否存在问题
279
+ 2. 注意区分**修改**和**重复定义**:如果同一位置有删除(-)和新增(+),这是修改,不是重复
280
+ 3. 优先检查"类型: 删除"的代码,确认是否有其他地方仍在使用
281
+ 4. **只对有问题的行提出审查意见**,没有问题的行不需要评论
282
+ 5. **必须使用中文**返回审查意见
283
+ 6. **必须返回标准 JSON 格式**,不要用其他格式,结构如下:
358
284
 
359
285
  \`\`\`json
360
286
  {
@@ -385,14 +311,8 @@ export function buildFileReviewWithImpactPrompt(fileName, meaningfulChanges, imp
385
311
  如果删除了第 15 行的函数,且发现其他文件在使用,comment 内容可以是:
386
312
  "【严重程度评分:8/10】\\n\\n📋 问题描述:\\n删除了函数 fetchData 但该函数仍被多处使用\\n\\n🔍 影响分析:\\n• 当前文件:函数定义被完全移除\\n• 受影响的其他文件:components/UserList.vue (第 45 行)\\n\\n💡 改进建议:\\n1. 恢复此函数或提供替代方案\\n2. 先标记为 @deprecated"
387
313
 
388
- 11. 如果所有代码都没有问题,返回空的 reviews 数组:\`{"reviews": []}\`
389
- 12. **只返回 JSON**,不要在 JSON 外面添加任何文字说明
390
-
391
- **最后再次确认:**
392
- - 看到 **"类型: 删除"** 和 **"-"** → 代码**被移除了**,需要检查影响
393
- - 看到 **"类型: 新增"** 和 **"+"** → 代码**是新的**,检查代码质量
394
- - **千万不要把删除理解成新增!**
395
- - **返回的必须是标准 JSON,不要在最外层使用特殊字符!**`;
314
+ 7. 如果所有代码都没有问题,返回空的 reviews 数组:\`{"reviews": []}\`
315
+ 8. **只返回 JSON**,不要在 JSON 外面添加任何文字说明`;
396
316
 
397
317
  return prompt;
398
318
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "gitlab-ai-review",
3
- "version": "3.2.5",
3
+ "version": "3.4.0",
4
4
  "description": "GitLab AI Review SDK with Impact Analysis - 支持影响分析、删除符号检测、注释代码识别、文件内部冲突检查、智能文件过滤的智能代码审查工具",
5
5
  "main": "index.js",
6
6
  "type": "module",