@opensumi/ide-ai-native 3.8.1-next-1740726474.0 → 3.8.1-next-1740735952.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.
Files changed (127) hide show
  1. package/lib/browser/ai-core.contribution.d.ts +1 -4
  2. package/lib/browser/ai-core.contribution.d.ts.map +1 -1
  3. package/lib/browser/ai-core.contribution.js +1 -20
  4. package/lib/browser/ai-core.contribution.js.map +1 -1
  5. package/lib/browser/chat/chat-manager.service.d.ts +0 -6
  6. package/lib/browser/chat/chat-manager.service.d.ts.map +1 -1
  7. package/lib/browser/chat/chat-manager.service.js +1 -31
  8. package/lib/browser/chat/chat-manager.service.js.map +1 -1
  9. package/lib/browser/chat/chat-model.d.ts +0 -2
  10. package/lib/browser/chat/chat-model.d.ts.map +1 -1
  11. package/lib/browser/chat/chat-model.js +2 -8
  12. package/lib/browser/chat/chat-model.js.map +1 -1
  13. package/lib/browser/chat/chat.internal.service.d.ts +0 -1
  14. package/lib/browser/chat/chat.internal.service.d.ts.map +1 -1
  15. package/lib/browser/chat/chat.internal.service.js +0 -3
  16. package/lib/browser/chat/chat.internal.service.js.map +1 -1
  17. package/lib/browser/chat/chat.module.less +2 -1
  18. package/lib/browser/chat/chat.view.d.ts.map +1 -1
  19. package/lib/browser/chat/chat.view.js +38 -6
  20. package/lib/browser/chat/chat.view.js.map +1 -1
  21. package/lib/browser/components/ChatContext/index.js +2 -2
  22. package/lib/browser/components/ChatContext/index.js.map +1 -1
  23. package/lib/browser/components/ChatHistory.d.ts +1 -0
  24. package/lib/browser/components/ChatHistory.d.ts.map +1 -1
  25. package/lib/browser/components/ChatHistory.js +14 -14
  26. package/lib/browser/components/ChatHistory.js.map +1 -1
  27. package/lib/browser/components/ChatInput.d.ts.map +1 -1
  28. package/lib/browser/components/ChatInput.js +1 -25
  29. package/lib/browser/components/ChatInput.js.map +1 -1
  30. package/lib/browser/components/ChatToolRender.d.ts.map +1 -1
  31. package/lib/browser/components/ChatToolRender.js +3 -2
  32. package/lib/browser/components/ChatToolRender.js.map +1 -1
  33. package/lib/browser/components/{chat-history.module.less → chat-history.css} +1 -1
  34. package/lib/browser/components/components.module.less +0 -20
  35. package/lib/browser/context/llm-context.service.d.ts +5 -16
  36. package/lib/browser/context/llm-context.service.d.ts.map +1 -1
  37. package/lib/browser/context/llm-context.service.js +47 -78
  38. package/lib/browser/context/llm-context.service.js.map +1 -1
  39. package/lib/browser/layout/layout.module.less +4 -4
  40. package/lib/browser/mcp/base-apply.service.d.ts +40 -31
  41. package/lib/browser/mcp/base-apply.service.d.ts.map +1 -1
  42. package/lib/browser/mcp/base-apply.service.js +167 -233
  43. package/lib/browser/mcp/base-apply.service.js.map +1 -1
  44. package/lib/browser/mcp/tools/components/EditFile.d.ts.map +1 -1
  45. package/lib/browser/mcp/tools/components/EditFile.js +41 -55
  46. package/lib/browser/mcp/tools/components/EditFile.js.map +1 -1
  47. package/lib/browser/mcp/tools/components/index.module.less +3 -23
  48. package/lib/browser/mcp/tools/createNewFileWithText.d.ts.map +1 -1
  49. package/lib/browser/mcp/tools/createNewFileWithText.js +0 -1
  50. package/lib/browser/mcp/tools/createNewFileWithText.js.map +1 -1
  51. package/lib/browser/mcp/tools/editFile.js +1 -1
  52. package/lib/browser/mcp/tools/editFile.js.map +1 -1
  53. package/lib/browser/mcp/tools/getDiagnosticsByPath.d.ts.map +1 -1
  54. package/lib/browser/mcp/tools/getDiagnosticsByPath.js +0 -1
  55. package/lib/browser/mcp/tools/getDiagnosticsByPath.js.map +1 -1
  56. package/lib/browser/mcp/tools/handlers/EditFile.d.ts +1 -5
  57. package/lib/browser/mcp/tools/handlers/EditFile.d.ts.map +1 -1
  58. package/lib/browser/mcp/tools/handlers/EditFile.js +4 -4
  59. package/lib/browser/mcp/tools/handlers/EditFile.js.map +1 -1
  60. package/lib/browser/mcp/tools/handlers/RunCommand.d.ts.map +1 -1
  61. package/lib/browser/mcp/tools/handlers/RunCommand.js +0 -2
  62. package/lib/browser/mcp/tools/handlers/RunCommand.js.map +1 -1
  63. package/lib/browser/mcp/tools/runTerminalCmd.d.ts.map +1 -1
  64. package/lib/browser/mcp/tools/runTerminalCmd.js +0 -1
  65. package/lib/browser/mcp/tools/runTerminalCmd.js.map +1 -1
  66. package/lib/browser/model/msg-history-manager.d.ts +0 -1
  67. package/lib/browser/model/msg-history-manager.d.ts.map +1 -1
  68. package/lib/browser/model/msg-history-manager.js +2 -12
  69. package/lib/browser/model/msg-history-manager.js.map +1 -1
  70. package/lib/browser/types.d.ts +1 -1
  71. package/lib/browser/types.d.ts.map +1 -1
  72. package/lib/browser/widget/inline-diff/inline-diff-widget.module.less +0 -12
  73. package/lib/browser/widget/inline-stream-diff/inline-stream-diff.handler.d.ts +0 -2
  74. package/lib/browser/widget/inline-stream-diff/inline-stream-diff.handler.d.ts.map +1 -1
  75. package/lib/browser/widget/inline-stream-diff/inline-stream-diff.handler.js +4 -11
  76. package/lib/browser/widget/inline-stream-diff/inline-stream-diff.handler.js.map +1 -1
  77. package/lib/common/llm-context.d.ts +9 -12
  78. package/lib/common/llm-context.d.ts.map +1 -1
  79. package/lib/common/llm-context.js.map +1 -1
  80. package/lib/common/prompts/context-prompt-provider.d.ts +3 -4
  81. package/lib/common/prompts/context-prompt-provider.d.ts.map +1 -1
  82. package/lib/common/prompts/context-prompt-provider.js +22 -33
  83. package/lib/common/prompts/context-prompt-provider.js.map +1 -1
  84. package/lib/common/types.d.ts +0 -17
  85. package/lib/common/types.d.ts.map +1 -1
  86. package/lib/common/types.js.map +1 -1
  87. package/lib/node/base-language-model.d.ts +1 -1
  88. package/lib/node/base-language-model.d.ts.map +1 -1
  89. package/lib/node/base-language-model.js +3 -54
  90. package/lib/node/base-language-model.js.map +1 -1
  91. package/package.json +23 -23
  92. package/src/browser/ai-core.contribution.ts +1 -25
  93. package/src/browser/chat/chat-manager.service.ts +1 -29
  94. package/src/browser/chat/chat-model.ts +3 -18
  95. package/src/browser/chat/chat.internal.service.ts +0 -4
  96. package/src/browser/chat/chat.module.less +2 -1
  97. package/src/browser/chat/chat.view.tsx +70 -7
  98. package/src/browser/components/ChatContext/index.tsx +2 -2
  99. package/src/browser/components/ChatHistory.tsx +15 -21
  100. package/src/browser/components/ChatInput.tsx +4 -67
  101. package/src/browser/components/ChatToolRender.tsx +2 -1
  102. package/src/browser/components/{chat-history.module.less → chat-history.css} +1 -1
  103. package/src/browser/components/components.module.less +0 -20
  104. package/src/browser/context/llm-context.service.ts +54 -90
  105. package/src/browser/layout/layout.module.less +4 -4
  106. package/src/browser/mcp/base-apply.service.ts +213 -266
  107. package/src/browser/mcp/tools/components/EditFile.tsx +60 -82
  108. package/src/browser/mcp/tools/components/index.module.less +3 -23
  109. package/src/browser/mcp/tools/createNewFileWithText.ts +0 -1
  110. package/src/browser/mcp/tools/editFile.ts +2 -2
  111. package/src/browser/mcp/tools/getDiagnosticsByPath.ts +0 -1
  112. package/src/browser/mcp/tools/handlers/EditFile.ts +4 -4
  113. package/src/browser/mcp/tools/handlers/RunCommand.ts +0 -2
  114. package/src/browser/mcp/tools/runTerminalCmd.ts +0 -1
  115. package/src/browser/model/msg-history-manager.ts +2 -12
  116. package/src/browser/types.ts +1 -1
  117. package/src/browser/widget/inline-diff/inline-diff-widget.module.less +0 -12
  118. package/src/browser/widget/inline-stream-diff/inline-stream-diff.handler.tsx +4 -13
  119. package/src/common/llm-context.ts +4 -10
  120. package/src/common/prompts/context-prompt-provider.ts +29 -38
  121. package/src/common/types.ts +0 -20
  122. package/src/node/base-language-model.ts +1 -63
  123. package/lib/browser/widget/inline-diff/inline-diff-manager.d.ts +0 -6
  124. package/lib/browser/widget/inline-diff/inline-diff-manager.d.ts.map +0 -1
  125. package/lib/browser/widget/inline-diff/inline-diff-manager.js +0 -27
  126. package/lib/browser/widget/inline-diff/inline-diff-manager.js.map +0 -1
  127. package/src/browser/widget/inline-diff/inline-diff-manager.tsx +0 -38
@@ -12,7 +12,7 @@ import {
12
12
  import { EditorSelectionChangeEvent } from '@opensumi/ide-editor/lib/browser/types';
13
13
  import { IMarkerService } from '@opensumi/ide-markers/lib/common/types';
14
14
 
15
- import { AttachFileContext, FileContext, LLMContextService, SerializedContext } from '../../common/llm-context';
15
+ import { FileContext, LLMContextService, SerializedContext } from '../../common/llm-context';
16
16
 
17
17
  @Injectable()
18
18
  export class LLMContextServiceImpl extends WithEventBus implements LLMContextService {
@@ -27,65 +27,40 @@ export class LLMContextServiceImpl extends WithEventBus implements LLMContextSer
27
27
 
28
28
  private isAutoCollecting = false;
29
29
 
30
- private readonly maxAttachFilesLimit = 10;
31
- private readonly maxViewFilesLimit = 20;
32
- private readonly attachedFiles: FileContext[] = [];
33
- private readonly recentlyViewFiles: FileContext[] = [];
34
- private readonly onDidContextFilesChangeEmitter = new Emitter<{ viewed: FileContext[]; attached: FileContext[] }>();
35
- onDidContextFilesChangeEvent = this.onDidContextFilesChangeEmitter.event;
30
+ private contextFiles: FileContext[] = [];
36
31
 
37
- private addFileToList(file: FileContext, list: FileContext[], maxLimit: number) {
38
- const existingIndex = list.findIndex((f) => f.uri.toString() === file.uri.toString());
39
- if (existingIndex > -1) {
40
- list.splice(existingIndex, 1);
41
- }
32
+ private maxFiles: number = 10; // 上下文的最大长度限制
42
33
 
43
- list.push(file);
44
- if (list.length > maxLimit) {
45
- list.shift();
46
- }
47
- }
34
+ private onDidContextFilesChangeEmitter = new Emitter<FileContext[]>();
35
+ onDidContextFilesChangeEvent = this.onDidContextFilesChangeEmitter.event;
48
36
 
49
- addFileToContext(uri: URI, selection?: [number, number], isManual = false): void {
50
- if (!uri) {
51
- return;
52
- }
37
+ addFileToContext(uri: URI, selection?: [number, number], isManual = true): void {
38
+ this.removeFileFromContext(uri);
53
39
 
54
- const file = { uri, selection };
55
- const targetList = isManual ? this.attachedFiles : this.recentlyViewFiles;
56
- const maxLimit = isManual ? this.maxAttachFilesLimit : this.maxViewFilesLimit;
40
+ this.contextFiles.push({ uri, selection, isManual });
57
41
 
58
- if (isManual) {
59
- this.docModelManager.createModelReference(uri);
42
+ if (this.contextFiles.length > this.maxFiles) {
43
+ this.contextFiles.shift();
60
44
  }
61
45
 
62
- this.addFileToList(file, targetList, maxLimit);
63
- this.notifyContextChange();
64
- }
65
-
66
- private notifyContextChange(): void {
67
46
  this.onDidContextFilesChangeEmitter.fire(this.getAllContextFiles());
68
47
  }
69
48
 
70
49
  cleanFileContext() {
71
- this.attachedFiles.length = 0;
72
- this.notifyContextChange();
50
+ this.contextFiles = [];
51
+ this.onDidContextFilesChangeEmitter.fire(this.getAllContextFiles());
73
52
  }
74
53
 
75
54
  private getAllContextFiles() {
76
- return {
77
- viewed: this.recentlyViewFiles,
78
- attached: this.attachedFiles,
79
- };
55
+ return [...this.contextFiles];
80
56
  }
81
57
 
82
- removeFileFromContext(uri: URI, isManual = false): void {
83
- const targetList = isManual ? this.attachedFiles : this.recentlyViewFiles;
84
- const index = targetList.findIndex((file) => file.uri.toString() === uri.toString());
58
+ removeFileFromContext(uri: URI): void {
59
+ const index = this.contextFiles.findIndex((file) => file.uri.toString() === uri.toString());
85
60
  if (index > -1) {
86
- targetList.splice(index, 1);
61
+ this.contextFiles.splice(index, 1);
62
+ this.onDidContextFilesChangeEmitter.fire(this.getAllContextFiles());
87
63
  }
88
- this.notifyContextChange();
89
64
  }
90
65
 
91
66
  startAutoCollection(): void {
@@ -103,7 +78,8 @@ export class LLMContextServiceImpl extends WithEventBus implements LLMContextSer
103
78
  if (event.payload.uri.scheme !== 'file') {
104
79
  return;
105
80
  }
106
- this.addFileToContext(event.payload.uri, undefined, false);
81
+ // FIXME: 暂时不自动添加
82
+ // this.addFileToContext(event.payload.uri);
107
83
  }),
108
84
  );
109
85
 
@@ -112,8 +88,6 @@ export class LLMContextServiceImpl extends WithEventBus implements LLMContextSer
112
88
  if (event.payload.scheme !== 'file') {
113
89
  return;
114
90
  }
115
-
116
- this.removeFileFromContext(event.payload, false);
117
91
  }),
118
92
  );
119
93
 
@@ -135,12 +109,11 @@ export class LLMContextServiceImpl extends WithEventBus implements LLMContextSer
135
109
  ].sort() as [number, number];
136
110
 
137
111
  if (selection[0] === selection[1]) {
138
- this.addFileToContext(event.payload.editorUri, undefined, false);
112
+ this.addFileToContext(event.payload.editorUri, undefined);
139
113
  } else {
140
114
  this.addFileToContext(
141
115
  event.payload.editorUri,
142
116
  selection.sort((a, b) => a - b),
143
- false,
144
117
  );
145
118
  }
146
119
  }
@@ -154,51 +127,42 @@ export class LLMContextServiceImpl extends WithEventBus implements LLMContextSer
154
127
 
155
128
  serialize(): SerializedContext {
156
129
  const files = this.getAllContextFiles();
157
- const workspaceRoot = URI.file(this.appConfig.workspaceDir);
158
-
159
- return {
160
- recentlyViewFiles: this.serializeRecentlyViewFiles(files.viewed, workspaceRoot),
161
- attachedFiles: this.serializeAttachedFiles(files.attached, workspaceRoot),
162
- };
163
- }
164
-
165
- private serializeRecentlyViewFiles(files: FileContext[], workspaceRoot: URI): string[] {
166
- return files
167
- .map((file) => workspaceRoot.relative(file.uri)?.toString() || file.uri.parent.toString())
130
+ const recentlyViewFiles = files
131
+ .filter((v) => !v.selection)
132
+ .map((file) => {
133
+ const relativePath = URI.file(this.appConfig.workspaceDir).relative(file.uri);
134
+ if (relativePath) {
135
+ return relativePath.toString();
136
+ }
137
+ return file.uri.parent.toString();
138
+ })
168
139
  .filter(Boolean);
169
- }
170
-
171
- private serializeAttachedFiles(files: FileContext[], workspaceRoot: URI): AttachFileContext[] {
172
- return files
173
- .map((file) => this.serializeAttachedFile(file, workspaceRoot))
174
- .filter(Boolean) as unknown as AttachFileContext[];
175
- }
176
140
 
177
- private serializeAttachedFile(file: FileContext, workspaceRoot: URI) {
178
- try {
179
- const ref = this.docModelManager.getModelReference(file.uri);
180
- if (!ref) {
181
- return null;
182
- }
183
-
184
- return {
185
- content: ref.instance.getText(),
186
- lineErrors: this.getFileErrors(file.uri),
187
- path: workspaceRoot.relative(file.uri)!.toString(),
188
- language: ref.instance.languageId!,
189
- };
190
- } catch (e) {
191
- return null;
192
- }
193
- }
194
-
195
- private getFileErrors(uri: URI): string[] {
196
- return this.markerService
197
- .getManager()
198
- .getMarkers({
199
- resource: uri.toString(),
200
- severities: MarkerSeverity.Error,
141
+ const attachedFiles = files
142
+ .filter((v) => v.selection)
143
+ .map((file) => {
144
+ const ref = this.docModelManager.getModelReference(file.uri);
145
+ const content = ref!.instance.getText();
146
+ const lineErrors = this.markerService
147
+ .getManager()
148
+ .getMarkers({
149
+ resource: file.uri.toString(),
150
+ severities: MarkerSeverity.Error,
151
+ })
152
+ .map((marker) => marker.message);
153
+
154
+ return {
155
+ content,
156
+ lineErrors,
157
+ path: URI.file(this.appConfig.workspaceDir).relative(file.uri)!.toString(),
158
+ language: ref?.instance.languageId!,
159
+ };
201
160
  })
202
- .map((marker) => marker.message);
161
+ .filter(Boolean);
162
+
163
+ return {
164
+ recentlyViewFiles,
165
+ attachedFiles,
166
+ };
203
167
  }
204
168
  }
@@ -14,16 +14,16 @@
14
14
  padding: 8px 12px;
15
15
  min-width: initial;
16
16
  margin: 0;
17
+
18
+ ::after {
19
+ content: '';
20
+ }
17
21
  }
18
22
 
19
23
  .rce-mbox-text {
20
24
  line-height: 18px;
21
25
  width: inherit;
22
26
  font-size: 12px;
23
-
24
- &::after {
25
- display: none;
26
- }
27
27
  }
28
28
 
29
29
  .rce-smsg {