This commit is contained in:
锦恢 2024-09-23 16:16:00 +08:00
parent 1860d19627
commit e4205ffddd
7 changed files with 18 additions and 28 deletions

View File

@ -166,8 +166,8 @@
const message = event.data;
const command = message.command;
const netlist = JSON.parse(message.netlist);
console.log(typeof netlist);
console.log(netlist);
// console.log(typeof netlist);
// console.log(netlist);
switch (command) {
case 'netlist' :

View File

@ -8,6 +8,7 @@ import { hdlMonitor } from './monitor';
import { extensionUrl } from '../resources/hdlParser';
import * as lspClient from './function/lsp-client';
import { refreshArchTree } from './function/treeView';
@ -37,9 +38,15 @@ async function launch(context: vscode.ExtensionContext) {
location: vscode.ProgressLocation.Window,
title: 'Initialization (Digtial-IDE)'
}, async () => {
// 初始化解析
await manager.prjManage.initialise(context);
// 这里是因为 pl 对象在 initialise 完成初始化,此处再注册它的行为
manager.registerManagerCommands(context);
// 刷新结构树
refreshArchTree();
hdlMonitor.start();
});

View File

@ -190,7 +190,6 @@ function makeRightDirection(rightPorts: HdlModulePort[]): string {
const portCaption = makePortCaption(port, 'right');
let portArrow = makePortArrow(port, 'right');
portArrow = portArrow.replace('-0.5 -0.5 125 45', '20 -0.5 125 45');
console.log(portArrow);
const arrow = `<div class="arrow-wrapper">${portCaption}${portArrow}</div>`;
rightDirection += arrow;

View File

@ -48,8 +48,6 @@ function selectFieldValue(obj: any, subName: string, ws: string, name: string):
function makeTableFromObjArray(md: MarkdownString, array: any[], name: string, fieldNames: string[], displayNames: string[]) {
const ws = hdlPath.toSlash(opeParam.workspacePath) + '/';
console.log('enter showhtml');
if (array.length === 0) {
md.addText(`no ${name} info`);
} else {
@ -82,7 +80,6 @@ async function patchComment(path: AbsPath, ports: (HdlModulePort | HdlModulePara
}
const ranges = ports.map(port => port.range);
const comments = await getSymbolComments(path, ranges);
console.log(ranges);
for (let i = 0; i < ports.length; ++ i) {
let inlineComment = comments[i].replace(/\n/, ' ');

View File

@ -128,7 +128,7 @@ function bin2float(bin: string, exp: number, fra: number): number | undefined {
function getFullSymbolInfoVlog(document: vscode.TextDocument, range: Range) {
const comments = [];
const currentLine = range.start.line;
const currentLine = range.start.line - 1;
const currentText = document.lineAt(currentLine).text;
// 往上找到第一个非空行
@ -203,8 +203,6 @@ function getFullSymbolInfoVlog(document: vscode.TextDocument, range: Range) {
}
}
// 情况 2.1:单行注释
if (currentText.includes('//')) {
const singleLineCommentStartIndex = currentText.indexOf('//');
@ -262,8 +260,8 @@ async function getFullSymbolInfo(document: vscode.TextDocument, range: Range, no
if (document.languageId !== 'vhdl') {
comments.push(...getFullSymbolInfoVlog(document, range));
let resultComment = '';
for (const c of comments.reverse()) {
resultComment += c.trim() + '\n';
for (const c of comments) {
resultComment += c.trim() + '<br>';
}
return resultComment;

View File

@ -23,7 +23,7 @@ export const LspClient: IDigitalIDELspClient = {
*/
export const CustomRequestType = new RequestType<void, number, void>('custom/request');
export const CustomParamRequestType = new RequestType<ICommonParam, number, void>('custom/paramRequest');
export const DoFastRequestType = new RequestType('api/fast');
export const DoFastRequestType = new RequestType<IDoFastParam, Fast, void>('api/fast');
export interface ITextDocumentItem {
uri: vscode.Uri,
@ -37,5 +37,5 @@ export interface ICommonParam {
}
export interface IDoFastParam {
path: string
}

View File

@ -11,20 +11,9 @@ async function doFastApi(path: string): Promise<Fast | undefined> {
const client = LspClient.MainClient;
const langID = hdlFile.getLanguageId(path);
if (client) {
const response = await client.sendRequest(DoFastRequestType, { path }) as { fast: any };
if (response.fast instanceof Array) {
const rawModules = response.fast as RawHdlModule[];
return {
content: rawModules,
languageId: langID,
macro: {
errors: [],
defines: [],
includes: [],
invalid: []
}
};
}
const response = await client.sendRequest(DoFastRequestType, { path });
response.languageId = langID;
return response;
}
} catch (error) {
console.error("error happen when run doFastApi, " + error);