添加本地C++服务集成功能,在保存NUT文件时发送文件路径和内容到本地服务

- 新增localClient.ts模块,用于向本地HTTP服务发送文件数据
- 修改extension.ts,在文件保存时调用本地服务发送功能
- 实现与C++客户端示例兼容的JSON数据格式

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
睿 安
2025-09-18 16:04:07 +08:00
parent fe15f52be5
commit 6741e9c408
4 changed files with 174 additions and 1 deletions

93
dist/localClient.js vendored Normal file
View File

@@ -0,0 +1,93 @@
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
exports.sendFileToCppService = sendFileToCppService;
const http = __importStar(require("http"));
/**
* 构建JSON数据
* @param filePath 文件路径
* @param content 文件内容
* @returns JSON字符串
*/
function buildJsonData(filePath, content) {
const data = {};
data[filePath] = content;
return JSON.stringify(data);
}
/**
* 发送文件内容到本地C++服务
* @param filePath 文件路径
* @param content 文件内容
* @returns Promise<boolean> 是否发送成功
*/
async function sendFileToCppService(filePath, content) {
return new Promise((resolve) => {
const jsonData = buildJsonData(filePath, content);
const postData = jsonData;
const options = {
hostname: '127.0.0.1',
port: 26000,
path: '/send_data',
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Content-Length': Buffer.byteLength(postData)
}
};
const req = http.request(options, (res) => {
let data = '';
res.on('data', (chunk) => {
data += chunk;
});
res.on('end', () => {
console.log(`[Squirrel] 已发送文件到C++服务: ${filePath}, 状态码: ${res.statusCode}`);
if (res.statusCode === 200) {
resolve(true);
}
else {
console.error(`[Squirrel] 发送失败,状态码: ${res.statusCode}, 响应: ${data}`);
resolve(false);
}
});
});
req.on('error', (error) => {
console.error(`[Squirrel] 发送文件到C++服务失败: ${error.message}`);
resolve(false);
});
req.write(postData);
req.end();
});
}
//# sourceMappingURL=localClient.js.map

1
dist/localClient.js.map vendored Normal file
View File

@@ -0,0 +1 @@
{"version":3,"file":"localClient.js","sourceRoot":"","sources":["../src/localClient.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsBA,oDA0CC;AAhED,2CAA6B;AAG7B;;;;;GAKG;AACH,SAAS,aAAa,CAAC,QAAgB,EAAE,OAAe;IACpD,MAAM,IAAI,GAA8B,EAAE,CAAC;IAC3C,IAAI,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC;IAEzB,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;AAChC,CAAC;AAED;;;;;GAKG;AACI,KAAK,UAAU,oBAAoB,CAAC,QAAgB,EAAE,OAAe;IACxE,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC3B,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QAClD,MAAM,QAAQ,GAAG,QAAQ,CAAC;QAE1B,MAAM,OAAO,GAAwB;YACjC,QAAQ,EAAE,WAAW;YACrB,IAAI,EAAE,KAAK;YACX,IAAI,EAAE,YAAY;YAClB,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACL,cAAc,EAAE,kBAAkB;gBAClC,gBAAgB,EAAE,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC;aAChD;SACJ,CAAC;QAEF,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;YACtC,IAAI,IAAI,GAAG,EAAE,CAAC;YAEd,GAAG,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE;gBACrB,IAAI,IAAI,KAAK,CAAC;YAClB,CAAC,CAAC,CAAC;YAEH,GAAG,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE;gBACf,OAAO,CAAC,GAAG,CAAC,2BAA2B,QAAQ,UAAU,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC;gBAC3E,IAAI,GAAG,CAAC,UAAU,KAAK,GAAG,EAAE,CAAC;oBACzB,OAAO,CAAC,IAAI,CAAC,CAAC;gBAClB,CAAC;qBAAM,CAAC;oBACJ,OAAO,CAAC,KAAK,CAAC,wBAAwB,GAAG,CAAC,UAAU,SAAS,IAAI,EAAE,CAAC,CAAC;oBACrE,OAAO,CAAC,KAAK,CAAC,CAAC;gBACnB,CAAC;YACL,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;YACtB,OAAO,CAAC,KAAK,CAAC,4BAA4B,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;YAC3D,OAAO,CAAC,KAAK,CAAC,CAAC;QACnB,CAAC,CAAC,CAAC;QAEH,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QACpB,GAAG,CAAC,GAAG,EAAE,CAAC;IACd,CAAC,CAAC,CAAC;AACP,CAAC"}

View File

@@ -12,6 +12,7 @@ import { OnTypeFormattingProvider } from './providers/onTypeFormattingProvider';
import { DocumentFormattingProvider } from './providers/documentFormattingProvider'; import { DocumentFormattingProvider } from './providers/documentFormattingProvider';
import { CodeErrorProvider } from './providers/codeErrorProvider'; import { CodeErrorProvider } from './providers/codeErrorProvider';
import { ApiParser } from './providers/apiParser'; import { ApiParser } from './providers/apiParser';
import { sendFileToCppService } from './localClient';
export function activate(context: vscode.ExtensionContext) { export function activate(context: vscode.ExtensionContext) {
console.log('Squirrel NUT Explorer 正在激活...'); console.log('Squirrel NUT Explorer 正在激活...');
@@ -140,7 +141,8 @@ export function activate(context: vscode.ExtensionContext) {
const saveListener = vscode.workspace.onDidSaveTextDocument(async (doc) => { const saveListener = vscode.workspace.onDidSaveTextDocument(async (doc) => {
if (doc.uri.scheme === 'squirrel') { if (doc.uri.scheme === 'squirrel') {
const filePath = doc.uri.path.substring(1); // 去掉开头的 '/' const filePath = doc.uri.path.substring(1); // 去掉开头的 '/'
const success = await model.saveFileContent(filePath, doc.getText()); const fileContent = doc.getText();
const success = await model.saveFileContent(filePath, fileContent);
if (success) { if (success) {
output.appendLine(`[Squirrel] 文件 ${filePath} 保存成功`); output.appendLine(`[Squirrel] 文件 ${filePath} 保存成功`);
@@ -148,6 +150,18 @@ export function activate(context: vscode.ExtensionContext) {
// 更新函数缓存 // 更新函数缓存
await functionExtractor.updateFileCache(model, filePath); await functionExtractor.updateFileCache(model, filePath);
// 发送文件内容到本地C++服务
try {
const sendSuccess = await sendFileToCppService(filePath, fileContent);
if (sendSuccess) {
output.appendLine(`[Squirrel] 文件 ${filePath} 已发送到C++服务`);
} else {
output.appendLine(`[Squirrel] 文件 ${filePath} 发送到C++服务失败`);
}
} catch (error) {
output.appendLine(`[Squirrel] 发送文件到C++服务时发生错误: ${error}`);
}
} else { } else {
output.appendLine(`[Squirrel] 文件 ${filePath} 保存失败`); output.appendLine(`[Squirrel] 文件 ${filePath} 保存失败`);
} }

65
src/localClient.ts Normal file
View File

@@ -0,0 +1,65 @@
import * as http from 'http';
import * as vscode from 'vscode';
/**
* 构建JSON数据
* @param filePath 文件路径
* @param content 文件内容
* @returns JSON字符串
*/
function buildJsonData(filePath: string, content: string): string {
const data: { [key: string]: string } = {};
data[filePath] = content;
return JSON.stringify(data);
}
/**
* 发送文件内容到本地C++服务
* @param filePath 文件路径
* @param content 文件内容
* @returns Promise<boolean> 是否发送成功
*/
export async function sendFileToCppService(filePath: string, content: string): Promise<boolean> {
return new Promise((resolve) => {
const jsonData = buildJsonData(filePath, content);
const postData = jsonData;
const options: http.RequestOptions = {
hostname: '127.0.0.1',
port: 26000,
path: '/send_data',
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Content-Length': Buffer.byteLength(postData)
}
};
const req = http.request(options, (res) => {
let data = '';
res.on('data', (chunk) => {
data += chunk;
});
res.on('end', () => {
console.log(`[Squirrel] 已发送文件到C++服务: ${filePath}, 状态码: ${res.statusCode}`);
if (res.statusCode === 200) {
resolve(true);
} else {
console.error(`[Squirrel] 发送失败,状态码: ${res.statusCode}, 响应: ${data}`);
resolve(false);
}
});
});
req.on('error', (error) => {
console.error(`[Squirrel] 发送文件到C++服务失败: ${error.message}`);
resolve(false);
});
req.write(postData);
req.end();
});
}