Seeking for help
- 
 Thank you for pointing this out, I hope I have fixed the problem now. 
- 
 It doesn’t seem to be running my attempt at the Perl one (which might be because the Perl::LanguageServer server that I’m running was a pain to get to install correctly, so I just might not have it set up right, and I don’t have any LSP client for checking if that side of things is working), so I defined a dummy python entry { "lspservers": { "perl": { "pipe": "io", "executable": "C:\\USR\\LOCAL\\APPS\\BERRYBREW\\PERLS\\SYSTEM\\PERL\\BIN\\perl.exe", "args": ["-MPerl::LanguageServer", "-e", "Perl::LanguageServer::run"], "auto_start_server": false, }, "python": { "pipe": "io", "executable": "C:\\Windows\\System32\\cmd.exe", "args": ["/C", "start"], "auto_start_server": false } } }but whether I try to just start a new cmd.exe window, or do "args": ["/C", "echo", "hi"],or"args": ["/K", "prompt"],I can see no evidence that it’s running anything.The steps I take: - Installed your plugin
- Plugins > nppLspClient > Open configuration file
- saved the above file
- tried either Plugins > nppLspClient > Apply Current Configuration or restarting Notepad++
- turn on the LSP output console
- open a dummy python file
- Start Server for Current Language
- Nothing shows up in the console, and no new windows are popped open
 Thus, I cannot tell whether the plugin is just not trying to run my command, or what. (I was hoping for that I could just prove to myself that it was launching something. For the perl command, if I run perl -MPerl::LanguageServer -e Perl::LanguageServer::runfrom a command line, it pauses waiting for input, and Task Manager shows that perl is running:
  But if I try to Start Server for Current Language with a perl file active in Notepad++, it doesn’t seem to be trying to launch the server process. (But maybe it launches it, then it dies too quickly for me to see it in Task Manager) The only time I see anything in the LSP output console with either perl or python is if I try to restart the current language’s server, when I see the console tells me: initialized = falseIs there some dummy configuration that would show me the plugin is actually trying to launch the server, even if it doesn’t do anything else? Or, barring that, where can I get the pyls.exe for trying the plugin for real with python? 
- 
 @PeterJones said in Seeking for help: It doesn’t seem to be running my attempt at the Perl one I did get the Perl one “running”  Text copy of output: perl server is running on_init: 13232 Content-Length: 2347 {"jsonrpc": "2.0", "id": 1, "method": "initialize", "params": {"processId": 13232, "clientInfo":{"name": "NppLspClient", "version": "0.0.1"}, "rootUri": "file:///C%3A/Users/mvincent/tmp", "initializationOptions": {}, "capabilities": {"workspace": {"applyEdit": false, "workspaceEdit": {"documentChanges": false}, "didChangeConfiguration": {"dynamicRegistration": false}, "didChangeWatchedFiles": {"dynamicRegistration": false}, "symbol": {"dynamicRegistration": false, "symbolKind": {"valueSet": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26]}}, "executeCommand": {"dynamicRegistration": false}, "configuration": false, "workspaceFolders": false}, "textDocument": {"publishDiagnostics": {"relatedInformation": false}, "synchronization": {"dynamicRegistration": false, "willSave": false, "willSaveWaitUntil": false, "didSave": true}, "completion": {"dynamicRegistration": false, "contextSupport": false, "completionItem": {"snippetSupport": false, "commitCharactersSupport": false, "documentationFormat": ["plaintext"], "deprecatedSupport": false}, "completionItemKind": {"valueSet": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25]}}, "hover": {"dynamicRegistration": false, "contentFormat": ["plaintext"]}, "signatureHelp": {"dynamicRegistration": false, "signatureInformation": {"documentationFormat": ["plaintext"]}}, "definition": {"dynamicRegistration": false}, "references": {"dynamicRegistration": false}, "documentHighlight": {"dynamicRegistration": false}, "documentSymbol": {"dynamicRegistration": false, "symbolKind": {"valueSet": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26]}}, "codeAction": {"dynamicRegistration": false}, "codeLens": {"dynamicRegistration": false}, "formatting": {"dynamicRegistration": false}, "rangeFormatting": {"dynamicRegistration": false}, "onTypeFormatting": {"dynamicRegistration": false}, "rename": {"dynamicRegistration": false}, "documentLink": {"dynamicRegistration": false}, "typeDefinition": {"dynamicRegistration": false}, "implementation": {"dynamicRegistration": false}, "colorProvider": {"dynamicRegistration": false}, "foldingRange": {"dynamicRegistration": false, "rangeLimit": 100, "lineFoldingOnly": true}}}, "trace": "off", "workspaceFolders": null}} on_message_received: tcp server start listen on port 7070and my config: "perl": { "pipe": "tcp", "port": 7070, "tcpretries" : 3, "executable": "C:\\Strawberry\\perl\\bin\\perl.exe", "args": ["-MPerl::LanguageServer", "-e", "Perl::LanguageServer::run", "--", "--port 7070"] }It doesn’t seem to work though when I hover or try command completion. Upon further examination of the text negotiation string, you can see all the capabilities return “false” - so perhaps that’s the reason? I did get the Python (one from the example using pyls) working, but wonky: and return to complete yields:  Which actually puts the text “value” as the example in the actual document and then you have to arrow key back to delete it and put the actual value (e.g., 1). Could certainly be what pylsis delivering - I’m used to using your PythonScript “IDE” script and that usingjedioffers the methods without example parameter data.Off to a great start though! You are aware of @dail 's NppLSP (stalled) project , correct? Chance to collaborate? Cheers. 
- 
 @PeterJones 
 First thank you for testing.
 You are right, there is not much info when something goes wrong. I will build a V.0.0.2 today as I’ve did a couple of fixes and make sure to have debug statements enabled to make it
 easier to find out what is causing the issue.
- 
 Many thanks to you as well. 
 I had, hopefully solved - crossing fingers, problems with the synchronisation of documents, which I have fixed with my changes that will be included in a V.0.0.2.
 I know its NppLsp project, but unfortunately I have no C++ knowledge. :-(
 As for the Perl, it looks like the language server uses tcp and that is not implemented yet, only stdin/stdout messaging.
- 
 
- 
 @PeterJones 
 For the python one I would recommend using a local python installation and then using pip to install it.
 Likepip install 'python-lsp-server[all]'
 Sources are available here.
- 
 I’m afraid the only lsp server for Python that doesn’t use Jedi under the hood is, as far as I know, the new Pylance addon for VSCode. 
 But MS hasn’t made it public. Jedi is a bit slow.
- 
 @Ekopalypse said in Seeking for help: Many thanks to you as well. I think a Npp language server client would be awesome - I just don’t have the chops to create it. Happy there are others that see the value and I appreciate you taking on the enormous task. Happy to help test / troubleshoot / contribute how I can. Cheers. 
- 
 Even when I set my config up like @Michael-Vincent’s for perl, I don’t see messages in the LSP output console. It may be that my IT department is blocking some aspects (I just got a notification that Notepad++ was being virus scanned when reloading it, which I normally never see). I think at this point, I will have to give up on LSP at work (which is unfortunate, because I do a lot more coding at work than at home); maybe I’ll run some experiments at home, where I know IT cannot be getting in my way. ;-) 
- 
 I have now had a chance to use your plugin and as an alpha release I am mightily impressed. I have tested using pylsp.exe and with all options installed. Got a bit of a fright on my 3000 line plus python file I decided to test it on (perhaps I should have been so ambitious) but it even worked on this file if a little slowly at times, which may be the pylsp implementation as much as anything as I have all options enabled in pylsp so it is doing a lot, but I was able to work through the issue and the annotations and console helped. A couple of things, which at present would be very much nice to have and are not essential would be: - 
Ability to configure the colours of the various styles of messages in the console, I still use a white background and the default colours are a bit washed out. Also would be good for the annotations as well. 
- 
Add hotspot links to the diagnostic info message in the console, i.e. line:3284 - Cyclomatic complexity too high: 15 (threshold 15), so that they could be clicked to take you to the line in the file being edited. I know these appear as annotations in the edited file but with a large file and the console shown it would be good to just click on the messages and be taken to that line in the file. 
- 
If the completion list is empty do not show it, not sure what the issue is but I was getting an empty completion dropdown on entering ‘.’ in some cases. 
- 
Not sure how well this is interacting with the Undo CTRL-Z functionality as that seemed to pop up completion lists (empty again) and trigger seemingly multiple call to the lsp, not sure how well scintilla notifies this so you might not be able to do much about it. 
 So far so good, and keep up the good work, I have also downloaded the source code and the V language has peeked my interest, not one I have had much exposure to yet amongst the seemingly hundreds I have used during a 35 year development career, but one I am going to have to become more familiar with even if only to possibly contribute to this project. Just need to get GCC installed and working first though. 
- 
- 
 Thanks for testing and the kind words. 
 As for GCC, the V community seems to prefer builds from https://winlibs.com/#download-release.
 Just unzip and make sure gcc is in the path or can be found.Unfortunately pyls is very slow compared to other language servers I’ve tested and I’m pretty sure jedi is the culprit. 
 I read that the author of jedi wants to rewrite it with rust, that should give a good performance boost.Doh, of course, colors need to be customizable. 
 Will be included in the next version (I assume tomorrow).Currently I am toying with how such diagnostic messages should be displayed. On the one hand I want them in the Scintilla editor, on the other hand I hate it when they are constantly shown and hidden. Maybe it is an option to use an indicator, a squiggled line (?) while typing and annotations, as is the case now, when saving the file !? V is a very young language that has potential, but whether it can use it, only the future will probably tell, I think. :-) As long as the plugin is in alpha status, I’ll try to implement the functions needed first. 
 In beta status, I then plan refinements such as hotspot links etc…
 Please don’t misunderstand, I’m absolutely happy about the thoughts you made, they make total sense. Thanks again.
- 
 Thanks for the hint re GCC, all downloaded and working now, time to do some more learning of V. I assume you use Notepad++ for V, if so do you know of a lexer, I have found a UDL which does a half way decent job but is easily confused with things like ‘\\’? 
- 
 Yes, I wrote a lexer for V, but unfortunately it doesn’t help you because 
 it doesn’t work with a 32bit npp because, as far as I’ve investigated/understood,
 x86 code handles the thiscall needed for the cpp-lexer methods differently.
 X64 code handles this the same way as stdcall and this is supported by V.
 I haven’t had the muse to follow this up yet, if you want to do that, I can provide my lexer code.
- 
 I have a portable x64 version I could use for V, so the lexer would be much appreciated. It’s just I haven’t switched over to x64 version of my main customised/built from source version yet because of issue with a missing x64 version of one of the plugins I use quite a lot, I could replicate the functionality in x64 with my own plugin but I haven’t had the time of yet. 
- 
 @nick-brown said in Seeking for help: a missing x64 version of one of the plugins Which one? Not to hijack the thread, but this was my reason for not switching from 32-bit to 64-bit, but I was able to find alternative workflows / tools / scripting that solved the issue and I moved to 64-bit a few years back. Cheers. 
- 
 Automation Scripts or NppScripts.dll as the plugin dll is called, I believe the author has released a x64 version but I could not get my scripts to work in that version, possibly due to incompatibly .net versions, I don’t know I haven’t really looked into it, the scripts I use are c#.net so should be easily transferrable to a plugin when I get around to it,. 
- 
 @nick-brown - done, uploaded here. 
 I have been using it for 2-3 months and never had any stability problems.
 There is one thing that I am not sure if it has been fixed or is still a problem. Occasionally it happened, twice in my case, that the folding gets corrupted. This is also why the plugin has the menu itemToggle Fold Debug Margin.
 If you see this and are able to reproduce it, I would ask you to let me know.
- 
 I just found this thread now, but I’ve also been working on an LSP plugin off and on for the last several months. I don’t know how much you have implemented, I only have a couple methods but I have pretty much all the infrastructure. It’s in C++ and depends on libraries that I have written for my other plugins (as well as some third party libraries). https://sourceforge.net/p/kered13-notepad-plugins/code/ci/default/tree/NPP LSP/src/ 
- 
 Hello, thank you for this tip. 
 I would love to collaborate with you, but my cpp knowledge is weak at best and in reality non-existent.
 Is there already a plugin that Npp users can use?
 I hope others who read this and know about cpp will take this as inspiration and start contributing to your project.As of today, I have defined all requests, notifications and responses for version 3.16. 
 33% are technically implemented, meaning you should be able to use them,
 but they may not be as well integrated into Npp as they could be.
 For example, diagnostic messages are displayed as a squiggly line and the textual
 representation is available in the console window, but you can’t hover over them
 to see what they mean.
 In my opinion, this 33% are the most important.
 Code errors, completion hints, signature info, goto definition/implementation/declaration,
 find references, code formatting and hovering over code symbols (as I said, hovering over error/warning indicators is not possible at the moment).My current plan is to finish the open 67% and then start integrating it into Npp in a more meaningful way. 
 I’m really bad at estimating how long it will take to implement the remaining 67%, but if I can keep up my current
 pace I hope to finish it within the next 2 weeks.
 Let’s see what real life has to say about it :-)Btw. what language server do you use for testing? 
 I find gopls, which I found recently, is a good one to get hints on errors in client / server communication, while pyls seems to be the most forgiving, which is not really good if you want to develop a generic lsp client :-D



