Подробный журнал сервера языка vscode показывает отправляющий запрос 'textDocument / hover - (9)', но сервер не получает сообщение - PullRequest
0 голосов
/ 10 февраля 2019

сервер является исполняемой программой, он использует stdio в качестве репозитория transport.it https://github.com/PMunch/nimlsp журнал показывает, что он получил уведомление об инициализации и текстовый документ не открыли уведомление, почему он не может получить сообщение типа запроса?будь то указатель мыши или запрос определения.

let args:string[] = ["/Users/bung/Nim"]
// If the extension is launched in debug mode then the debug server options are used
// Otherwise the run options are used
let options: ExecutableOptions = {
    cwd: folder.uri.fsPath,
    stdio: 'pipe',  //https://github.com/matarillo/vscode-languageserver-csharp-example/blob/master/client/src/extension.ts
    // env:{"PATH":"/Users/bung/.nimble/bin/"},
    env:process.env,
    detached: false,
    shell: false
}
console.log(serverModule)

const serverOptions: ServerOptions = {
    run:{command:serverModule,args:args,options:options},
    debug:{command:serverModule,args:args,options:options}
}

// Options to control the language client
let clientOptions: LanguageClientOptions = {
    // Register the server for plain text documents
    documentSelector: [{ language: 'nim', scheme: 'file' }],
    diagnosticCollectionName: "nim",
    synchronize: {
        // Notify the server about file changes to '.clientrc files contained in the workspace
        fileEvents: workspace.createFileSystemWatcher('{**/*.nim,**/.nimble}')
    },
    workspaceFolder:folder
};

// Create the language client and start the client.
client = new LanguageClient(
    'nim',
    'nim',
    serverOptions,
    clientOptions,
    // true
);
client.trace = Trace.Verbose;

client.onDidChangeState( (e) => {
    console.log(e)
})



client.onReady().then(() => {
    // client.registerProposedFeatures()
    client.onNotification(DidOpenTextDocumentNotification.type,x =>{
        console.log(x)
    })

    client.onRequest(HoverRequest.type.method,x =>{
        console.log(x)
    })

    console.log(client.initializeResult)
    // client.onRequest( "textDocument/definition", (_,p) => {
    //  console.log(p)
    // } )
})

// Start the client. This will also launch the server
context.subscriptions.push(client.start());

1 Ответ

0 голосов
/ 11 февраля 2019

хм, наконец-то я обнаружил, что проблема связана с nimlsp, в нем есть ошибка, вызывающая цикл infinte, поэтому он не может получить запрос. См. https://github.com/PMunch/nimlsp/issues/19

...