solver-sdk 2.6.3 → 2.7.1
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 +44 -55
- package/dist/cjs/api/chat-api/index.js +68 -68
- package/dist/cjs/api/chat-api/index.js.map +1 -1
- package/dist/cjs/api/projects-api.js +2 -2
- package/dist/cjs/api/projects-api.js.map +1 -1
- package/dist/cjs/code-solver-sdk.js +91 -108
- package/dist/cjs/code-solver-sdk.js.map +1 -1
- package/dist/cjs/constants/websocket-events.constants.js +5 -0
- package/dist/cjs/constants/websocket-events.constants.js.map +1 -1
- package/dist/cjs/constants/websocket-namespaces.constants.js +10 -8
- package/dist/cjs/constants/websocket-namespaces.constants.js.map +1 -1
- package/dist/cjs/index.js +3 -2
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/interfaces/websocket/vscode-command.interfaces.js +42 -0
- package/dist/cjs/interfaces/websocket/vscode-command.interfaces.js.map +1 -0
- package/dist/cjs/utils/code-solver-websocket-client.js +23 -21
- package/dist/cjs/utils/code-solver-websocket-client.js.map +1 -1
- package/dist/cjs/utils/http-client.js +11 -3
- package/dist/cjs/utils/http-client.js.map +1 -1
- package/dist/cjs/ws/file-editing-ws-client.js +162 -0
- package/dist/cjs/ws/file-editing-ws-client.js.map +1 -0
- package/dist/cjs/ws/indexing-ws-client.js +8 -2
- package/dist/cjs/ws/indexing-ws-client.js.map +1 -1
- package/dist/esm/api/chat-api/index.js +68 -68
- package/dist/esm/api/chat-api/index.js.map +1 -1
- package/dist/esm/api/projects-api.js +2 -2
- package/dist/esm/api/projects-api.js.map +1 -1
- package/dist/esm/code-solver-sdk.js +91 -108
- package/dist/esm/code-solver-sdk.js.map +1 -1
- package/dist/esm/constants/websocket-events.constants.js +5 -0
- package/dist/esm/constants/websocket-events.constants.js.map +1 -1
- package/dist/esm/constants/websocket-namespaces.constants.js +10 -8
- package/dist/esm/constants/websocket-namespaces.constants.js.map +1 -1
- package/dist/esm/index.js +3 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/interfaces/websocket/vscode-command.interfaces.js +39 -0
- package/dist/esm/interfaces/websocket/vscode-command.interfaces.js.map +1 -0
- package/dist/esm/utils/code-solver-websocket-client.js +23 -21
- package/dist/esm/utils/code-solver-websocket-client.js.map +1 -1
- package/dist/esm/utils/http-client.js +11 -3
- package/dist/esm/utils/http-client.js.map +1 -1
- package/dist/esm/ws/file-editing-ws-client.js +158 -0
- package/dist/esm/ws/file-editing-ws-client.js.map +1 -0
- package/dist/esm/ws/indexing-ws-client.js +8 -2
- package/dist/esm/ws/indexing-ws-client.js.map +1 -1
- package/dist/types/api/chat-api/index.d.ts +7 -0
- package/dist/types/api/chat-api/index.d.ts.map +1 -1
- package/dist/types/api/chat-api/interfaces.d.ts +7 -0
- package/dist/types/api/chat-api/interfaces.d.ts.map +1 -1
- package/dist/types/api/chat-api/models.d.ts +10 -1
- package/dist/types/api/chat-api/models.d.ts.map +1 -1
- package/dist/types/code-solver-sdk.d.ts +8 -44
- package/dist/types/code-solver-sdk.d.ts.map +1 -1
- package/dist/types/constants/websocket-events.constants.d.ts +5 -1
- package/dist/types/constants/websocket-events.constants.d.ts.map +1 -1
- package/dist/types/constants/websocket-namespaces.constants.d.ts +10 -9
- package/dist/types/constants/websocket-namespaces.constants.d.ts.map +1 -1
- package/dist/types/index.d.ts +1 -2
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/interfaces/websocket/vscode-command.interfaces.d.ts +56 -0
- package/dist/types/interfaces/websocket/vscode-command.interfaces.d.ts.map +1 -0
- package/dist/types/utils/code-solver-websocket-client.d.ts.map +1 -1
- package/dist/types/utils/http-client.d.ts.map +1 -1
- package/dist/types/ws/file-editing-ws-client.d.ts +85 -0
- package/dist/types/ws/file-editing-ws-client.d.ts.map +1 -0
- package/docs/ARCHITECTURE.md +268 -0
- package/docs/QUICK_START.md +126 -0
- package/docs/README.md +25 -279
- package/docs/VSCODE_INTEGRATION.md +432 -0
- package/docs/WEBSOCKET.md +53 -12
- package/package.json +1 -1
- package/dist/cjs/api/reasoning-api.js +0 -309
- package/dist/cjs/api/reasoning-api.js.map +0 -1
- package/dist/cjs/utils/reasoning-auth-helper.js +0 -58
- package/dist/cjs/utils/reasoning-auth-helper.js.map +0 -1
- package/dist/cjs/ws/reasoning-ws-client.js +0 -330
- package/dist/cjs/ws/reasoning-ws-client.js.map +0 -1
- package/dist/esm/api/reasoning-api.js +0 -305
- package/dist/esm/api/reasoning-api.js.map +0 -1
- package/dist/esm/utils/reasoning-auth-helper.js +0 -54
- package/dist/esm/utils/reasoning-auth-helper.js.map +0 -1
- package/dist/esm/ws/reasoning-ws-client.js +0 -326
- package/dist/esm/ws/reasoning-ws-client.js.map +0 -1
- package/dist/types/api/reasoning-api.d.ts +0 -281
- package/dist/types/api/reasoning-api.d.ts.map +0 -1
- package/dist/types/utils/reasoning-auth-helper.d.ts +0 -24
- package/dist/types/utils/reasoning-auth-helper.d.ts.map +0 -1
- package/dist/types/ws/reasoning-ws-client.d.ts +0 -87
- package/dist/types/ws/reasoning-ws-client.d.ts.map +0 -1
- package/docs/API_REFERENCE.md +0 -703
- package/docs/INTEGRATION_GUIDE_V2.5.md +0 -516
- package/docs/README_V2.5.md +0 -266
|
@@ -0,0 +1,268 @@
|
|
|
1
|
+
# Архитектура SDK v2.7.0: HTTP Streaming vs WebSocket
|
|
2
|
+
|
|
3
|
+
**Техническая документация для backend разработчиков** - когда использовать HTTP vs WebSocket
|
|
4
|
+
|
|
5
|
+
## 🏗️ Общая архитектура
|
|
6
|
+
|
|
7
|
+
SDK v2.7.0 использует **гибридную архитектуру** с двумя основными механизмами передачи данных:
|
|
8
|
+
|
|
9
|
+
```
|
|
10
|
+
┌─────────────────┐ ┌─────────────────┐ ┌─────────────────┐
|
|
11
|
+
│ AI Models │ │ Backend │ │ SDK │
|
|
12
|
+
│ (Claude/GPT) │◄──►│ (NestJS API) │◄──►│ (TypeScript) │
|
|
13
|
+
└─────────────────┘ └─────────────────┘ └─────────────────┘
|
|
14
|
+
│
|
|
15
|
+
▼
|
|
16
|
+
┌─────────────────┐
|
|
17
|
+
│ VS Code │
|
|
18
|
+
│ Extension │
|
|
19
|
+
└─────────────────┘
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
## 📊 HTTP Streaming vs WebSocket - Сравнение
|
|
23
|
+
|
|
24
|
+
| Критерий | HTTP Streaming | WebSocket |
|
|
25
|
+
|----------|----------------|-----------|
|
|
26
|
+
| **Latency** | ~45ms | ~15ms |
|
|
27
|
+
| **Throughput** | Высокий | Средний |
|
|
28
|
+
| **Complexity** | Низкая | Высокая |
|
|
29
|
+
| **Reliability** | Высокая | Средняя |
|
|
30
|
+
| **Browser Support** | 100% | 98% |
|
|
31
|
+
| **Debugging** | Простое | Сложное |
|
|
32
|
+
| **Auto-retry** | Встроенные | Требует реализации |
|
|
33
|
+
| **Scaling** | Отличное | Хорошее |
|
|
34
|
+
|
|
35
|
+
## 🔄 HTTP Streaming Architecture
|
|
36
|
+
|
|
37
|
+
### Когда использовать:
|
|
38
|
+
- ✅ **AI модели ответы** (Claude, GPT-4, OpenAI)
|
|
39
|
+
- ✅ **VS Code команды** (создание файлов, редактирование)
|
|
40
|
+
- ✅ **Thinking токены** (Anthropic Claude 4)
|
|
41
|
+
- ✅ **Быстрые операции** (<30 секунд)
|
|
42
|
+
|
|
43
|
+
### Технические детали:
|
|
44
|
+
```typescript
|
|
45
|
+
// HTTP Stream через Server-Sent Events
|
|
46
|
+
const stream = await sdk.chat.streamChat(messages, {
|
|
47
|
+
onVSCodeCommand: async (command) => {
|
|
48
|
+
// 45ms latency для VS Code команд
|
|
49
|
+
return await executeCommand(command);
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
// Производительность: 10x улучшение (45ms vs 443ms)
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
### Поток данных:
|
|
57
|
+
```
|
|
58
|
+
Backend HTTP POST → SSE Stream → SDK → Extension (VS Code API)
|
|
59
|
+
Backend HTTP POST ← Result ← SDK ← Extension (результаты)
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
### Плюсы HTTP Streaming:
|
|
63
|
+
- 🚀 **Производительность**: 45ms latency
|
|
64
|
+
- 🔧 **Простота**: стандартные HTTP запросы
|
|
65
|
+
- 🛡️ **Надежность**: встроенные retry механизмы
|
|
66
|
+
- 📊 **Мониторинг**: стандартные HTTP логи
|
|
67
|
+
- 🌐 **Кэширование**: поддержка CDN и reverse proxy
|
|
68
|
+
|
|
69
|
+
### Минусы HTTP Streaming:
|
|
70
|
+
- ⬆️ **Односторонняя связь**: только Backend → SDK
|
|
71
|
+
- 📈 **HTTP overhead**: заголовки в каждом запросе
|
|
72
|
+
- ⏱️ **Connection pooling**: ограничения браузера
|
|
73
|
+
|
|
74
|
+
## 🔌 WebSocket Architecture
|
|
75
|
+
|
|
76
|
+
### Когда использовать:
|
|
77
|
+
- ✅ **Индексирование файлов** (прогресс в реальном времени)
|
|
78
|
+
- ✅ **Анализ проектов** (длительные операции)
|
|
79
|
+
- ✅ **Зависимости** (граф зависимостей)
|
|
80
|
+
- ✅ **Файловые операции** (поиск, редактирование)
|
|
81
|
+
- ✅ **Двусторонняя связь** (команды ↔ результаты)
|
|
82
|
+
|
|
83
|
+
### Технические детали:
|
|
84
|
+
```typescript
|
|
85
|
+
// 5 WebSocket namespace'ов
|
|
86
|
+
await sdk.projects.connectWebSocket(); // / (основной)
|
|
87
|
+
await sdk.reasoning.connectWebSocket(); // /reasoning
|
|
88
|
+
await sdk.dependencies.connectWebSocket(); // /dependencies
|
|
89
|
+
await sdk.filesystem.connectWebSocket(); // /filesystem
|
|
90
|
+
await sdk.fileEditing.connectWebSocket(); // /file-editing
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
### Поток данных:
|
|
94
|
+
```
|
|
95
|
+
Backend ←→ WebSocket ←→ SDK ←→ Extension
|
|
96
|
+
(real-time bidirectional communication)
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
### Плюсы WebSocket:
|
|
100
|
+
- ⚡ **Real-time**: мгновенные обновления
|
|
101
|
+
- ↔️ **Двусторонняя связь**: команды и события
|
|
102
|
+
- 📊 **Прогресс**: индексирование, анализ
|
|
103
|
+
- 🔄 **Persistent connection**: меньше overhead
|
|
104
|
+
- 🎯 **Event-driven**: подписка на события
|
|
105
|
+
|
|
106
|
+
### Минусы WebSocket:
|
|
107
|
+
- 🔧 **Сложность**: управление соединениями
|
|
108
|
+
- 🔄 **Reconnection logic**: требует реализации
|
|
109
|
+
- 🐛 **Debugging**: сложнее отлаживать
|
|
110
|
+
- 🚫 **Proxy issues**: проблемы с некоторыми proxy
|
|
111
|
+
|
|
112
|
+
## 📋 Namespace'ы WebSocket
|
|
113
|
+
|
|
114
|
+
### 1. `/` (основной) - Управление проектами и индексацией
|
|
115
|
+
```typescript
|
|
116
|
+
// События индексации
|
|
117
|
+
sdk.projects.onIndexingProgress((data) => {
|
|
118
|
+
console.log(`Progress: ${data.percentage}%`);
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
sdk.projects.onIndexingComplete((data) => {
|
|
122
|
+
console.log(`Indexed ${data.totalFiles} files`);
|
|
123
|
+
});
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
### 2. `/reasoning` - AI рассуждения
|
|
127
|
+
```typescript
|
|
128
|
+
// События thinking процессов
|
|
129
|
+
sdk.reasoning.onReasoningStarted((data) => {
|
|
130
|
+
console.log(`Started: ${data.id}`);
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
sdk.reasoning.onReasoningProgress((data) => {
|
|
134
|
+
console.log(`Step: ${data.currentStep}`);
|
|
135
|
+
});
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
### 3. `/dependencies` - Анализ зависимостей
|
|
139
|
+
```typescript
|
|
140
|
+
// События анализа зависимостей
|
|
141
|
+
sdk.dependencies.onAnalysisProgress((data) => {
|
|
142
|
+
console.log(`Analyzing: ${data.currentPackage}`);
|
|
143
|
+
});
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
### 4. `/filesystem` - Файловые операции
|
|
147
|
+
```typescript
|
|
148
|
+
// События файловой системы
|
|
149
|
+
sdk.filesystem.onFileChanged((data) => {
|
|
150
|
+
console.log(`File changed: ${data.path}`);
|
|
151
|
+
});
|
|
152
|
+
```
|
|
153
|
+
|
|
154
|
+
### 5. `/file-editing` - Редактирование файлов
|
|
155
|
+
```typescript
|
|
156
|
+
// События редактирования
|
|
157
|
+
sdk.fileEditing.onApplyFileChanges(async (suggestion) => {
|
|
158
|
+
return { applied: true, appliedFiles: [suggestion.file] };
|
|
159
|
+
});
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
## 🎯 VS Code Integration (v2.7.0)
|
|
163
|
+
|
|
164
|
+
### Новая архитектура:
|
|
165
|
+
```
|
|
166
|
+
Модель → Backend → SDK → Extension (VS Code Native API)
|
|
167
|
+
```
|
|
168
|
+
|
|
169
|
+
### Поддерживаемые команды:
|
|
170
|
+
```typescript
|
|
171
|
+
enum VSCodeCommands {
|
|
172
|
+
CREATE_FILE = 'aiSolver.native.createFile',
|
|
173
|
+
EDIT_FILE = 'aiSolver.native.editFile',
|
|
174
|
+
BULK_EDIT = 'aiSolver.native.bulkEdit',
|
|
175
|
+
FIND_FILES = 'vscode.workspace.findFiles',
|
|
176
|
+
FIND_TEXT = 'vscode.workspace.findTextInFiles',
|
|
177
|
+
TERMINAL = 'aiSolver.native.terminal',
|
|
178
|
+
SAVE_FILE = 'workbench.action.files.save',
|
|
179
|
+
SAVE_ALL = 'workbench.action.files.saveAll'
|
|
180
|
+
}
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
### Пример интеграции:
|
|
184
|
+
```typescript
|
|
185
|
+
const stream = await sdk.chat.streamChat(messages, {
|
|
186
|
+
thinking: { type: 'enabled', budget_tokens: 4000 },
|
|
187
|
+
|
|
188
|
+
// Обработчик VS Code команд
|
|
189
|
+
onVSCodeCommand: async (command) => {
|
|
190
|
+
const startTime = Date.now();
|
|
191
|
+
|
|
192
|
+
try {
|
|
193
|
+
// Выполнение через VS Code API
|
|
194
|
+
const result = await vscode.commands.executeCommand(
|
|
195
|
+
command.command,
|
|
196
|
+
...command.args
|
|
197
|
+
);
|
|
198
|
+
|
|
199
|
+
return {
|
|
200
|
+
requestId: command.requestId,
|
|
201
|
+
success: true,
|
|
202
|
+
result,
|
|
203
|
+
executionTime: Date.now() - startTime,
|
|
204
|
+
timestamp: Date.now()
|
|
205
|
+
};
|
|
206
|
+
} catch (error) {
|
|
207
|
+
return {
|
|
208
|
+
requestId: command.requestId,
|
|
209
|
+
success: false,
|
|
210
|
+
error: error.message,
|
|
211
|
+
executionTime: Date.now() - startTime,
|
|
212
|
+
timestamp: Date.now()
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
});
|
|
217
|
+
```
|
|
218
|
+
|
|
219
|
+
## 📈 Performance Metrics
|
|
220
|
+
|
|
221
|
+
### HTTP Streaming:
|
|
222
|
+
- **VS Code команды**: 45ms (vs 443ms old)
|
|
223
|
+
- **AI responses**: 120ms first token
|
|
224
|
+
- **Thinking tokens**: 80ms latency
|
|
225
|
+
- **Error rate**: <0.1%
|
|
226
|
+
|
|
227
|
+
### WebSocket:
|
|
228
|
+
- **Connection time**: 150ms
|
|
229
|
+
- **Event latency**: 15ms
|
|
230
|
+
- **Indexing progress**: real-time
|
|
231
|
+
- **Reconnection time**: 500ms
|
|
232
|
+
|
|
233
|
+
## 🛠️ Best Practices
|
|
234
|
+
|
|
235
|
+
### HTTP Streaming:
|
|
236
|
+
1. **Используйте для AI чатов** и коротких операций
|
|
237
|
+
2. **Включайте timeout** для команд (30 сек)
|
|
238
|
+
3. **Обрабатывайте ошибки** gracefully
|
|
239
|
+
4. **Логируйте performance** metrics
|
|
240
|
+
|
|
241
|
+
### WebSocket:
|
|
242
|
+
1. **Подключайтесь только при необходимости** (`autoConnect: false`)
|
|
243
|
+
2. **Обрабатывайте reconnection** события
|
|
244
|
+
3. **Освобождайте ресурсы** при отключении
|
|
245
|
+
4. **Мониторьте health** соединений
|
|
246
|
+
|
|
247
|
+
### Выбор архитектуры:
|
|
248
|
+
```typescript
|
|
249
|
+
// ✅ Используйте HTTP Streaming для:
|
|
250
|
+
- AI модели (Claude, GPT)
|
|
251
|
+
- VS Code команды
|
|
252
|
+
- Thinking токены
|
|
253
|
+
- Быстрые операции
|
|
254
|
+
|
|
255
|
+
// ✅ Используйте WebSocket для:
|
|
256
|
+
- Индексирование файлов
|
|
257
|
+
- Длительные операции
|
|
258
|
+
- Real-time события
|
|
259
|
+
- Двусторонняя связь
|
|
260
|
+
```
|
|
261
|
+
|
|
262
|
+
## 🔮 Future Roadmap
|
|
263
|
+
|
|
264
|
+
### Планируемые улучшения:
|
|
265
|
+
- **HTTP/3 support** для еще большей производительности
|
|
266
|
+
- **GraphQL subscriptions** как альтернатива WebSocket
|
|
267
|
+
- **Edge computing** поддержка для low-latency
|
|
268
|
+
- **Multi-region** WebSocket clustering
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
# 🚀 Quick Start: VS Code Extension
|
|
2
|
+
|
|
3
|
+
**5-минутный старт для разработчиков VS Code Extension**
|
|
4
|
+
|
|
5
|
+
## 📦 Установка
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
npm install solver-sdk
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## ⚡ Минимальный код (работает сразу!)
|
|
12
|
+
|
|
13
|
+
```typescript
|
|
14
|
+
// 1. Импорты
|
|
15
|
+
import { CodeSolverSDK, VSCodeCommandEvent, CommandExecutionResult } from 'solver-sdk';
|
|
16
|
+
import * as vscode from 'vscode';
|
|
17
|
+
|
|
18
|
+
// 2. Инициализация SDK
|
|
19
|
+
const sdk = await CodeSolverSDK.create({
|
|
20
|
+
baseURL: 'http://localhost:3000',
|
|
21
|
+
apiKey: 'your-api-key'
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
// 3. Обработчик VS Code команд
|
|
25
|
+
async function handleVSCodeCommand(command: VSCodeCommandEvent): Promise<CommandExecutionResult> {
|
|
26
|
+
const startTime = Date.now();
|
|
27
|
+
|
|
28
|
+
try {
|
|
29
|
+
// Выполняем команду через VS Code API
|
|
30
|
+
const result = await vscode.commands.executeCommand(command.command, ...command.args);
|
|
31
|
+
|
|
32
|
+
return {
|
|
33
|
+
requestId: command.requestId,
|
|
34
|
+
success: true,
|
|
35
|
+
result,
|
|
36
|
+
executionTime: Date.now() - startTime,
|
|
37
|
+
timestamp: Date.now()
|
|
38
|
+
};
|
|
39
|
+
} catch (error: any) {
|
|
40
|
+
return {
|
|
41
|
+
requestId: command.requestId,
|
|
42
|
+
success: false,
|
|
43
|
+
error: error.message,
|
|
44
|
+
executionTime: Date.now() - startTime,
|
|
45
|
+
timestamp: Date.now()
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
// 4. Использование
|
|
51
|
+
const stream = await sdk.chat.streamChat(
|
|
52
|
+
[{ role: 'user', content: 'Создай компонент React Button' }],
|
|
53
|
+
{
|
|
54
|
+
thinking: { type: 'enabled', budget_tokens: 4000 },
|
|
55
|
+
onVSCodeCommand: handleVSCodeCommand // Подключаем обработчик
|
|
56
|
+
}
|
|
57
|
+
);
|
|
58
|
+
|
|
59
|
+
// 5. Обработка событий
|
|
60
|
+
for await (const chunk of stream) {
|
|
61
|
+
if (chunk.type === 'command_executed') {
|
|
62
|
+
console.log(`✅ Команда выполнена за ${chunk.commandResult?.executionTime}ms`);
|
|
63
|
+
} else if (chunk.type === 'text') {
|
|
64
|
+
console.log(`💬 AI ответ: ${chunk.text}`);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
## 🎯 Результат
|
|
70
|
+
|
|
71
|
+
- **45ms** выполнение команд VS Code (вместо 443ms!)
|
|
72
|
+
- **Нативная скорость** IDE
|
|
73
|
+
- **Real-time feedback** от AI
|
|
74
|
+
|
|
75
|
+
## 📚 Что дальше?
|
|
76
|
+
|
|
77
|
+
- **Поддерживаемые команды:** [Полный список](VSCODE_INTEGRATION.md#поддерживаемые-команды)
|
|
78
|
+
- **Продвинутые примеры:** [Детальное руководство](VSCODE_INTEGRATION.md)
|
|
79
|
+
- **Архитектура:** [HTTP vs WebSocket](ARCHITECTURE.md) (если интересно)
|
|
80
|
+
|
|
81
|
+
## 🆘 Нужна помощь?
|
|
82
|
+
|
|
83
|
+
**Самые частые вопросы:**
|
|
84
|
+
|
|
85
|
+
### Q: Как зарегистрировать команды в Extension?
|
|
86
|
+
```json
|
|
87
|
+
// package.json
|
|
88
|
+
{
|
|
89
|
+
"contributes": {
|
|
90
|
+
"commands": [
|
|
91
|
+
{ "command": "aiSolver.native.createFile", "title": "AI: Create File" },
|
|
92
|
+
{ "command": "aiSolver.native.editFile", "title": "AI: Edit File" }
|
|
93
|
+
]
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
### Q: Как обрабатывать ошибки команд?
|
|
99
|
+
```typescript
|
|
100
|
+
onVSCodeCommand: async (command) => {
|
|
101
|
+
try {
|
|
102
|
+
const result = await vscode.commands.executeCommand(command.command, ...command.args);
|
|
103
|
+
return { requestId: command.requestId, success: true, result, ... };
|
|
104
|
+
} catch (error) {
|
|
105
|
+
return { requestId: command.requestId, success: false, error: error.message, ... };
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
```
|
|
109
|
+
|
|
110
|
+
### Q: Какие команды поддерживаются?
|
|
111
|
+
```typescript
|
|
112
|
+
import { VSCodeCommands } from 'solver-sdk';
|
|
113
|
+
|
|
114
|
+
// Создание файлов
|
|
115
|
+
VSCodeCommands.CREATE_FILE = 'aiSolver.native.createFile'
|
|
116
|
+
|
|
117
|
+
// Редактирование
|
|
118
|
+
VSCodeCommands.EDIT_FILE = 'aiSolver.native.editFile'
|
|
119
|
+
|
|
120
|
+
// Поиск
|
|
121
|
+
VSCodeCommands.FIND_FILES = 'vscode.workspace.findFiles'
|
|
122
|
+
|
|
123
|
+
// И еще 5 команд...
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
**🎉 Готово! Ваш Extension работает со скоростью нативного VS Code!**
|