I just started a new job where I have to ssh into a remote linux vm to work on a qt driven c++ project. I don’t really have a lot of leeway on what can be added to the remote environment, and I don’t think local development is possible. The vm has vim and qtcreator.
I’m from a Java background and I’m learning c++ for this role, while I’m comfortable in vim, I’d really like to have a tool that can give me autocomplete, jump to definition and linting. I know these things can be set up in neovim, but I asked about having that put on the box and was not given a good reaction.
I also know tools like vscode and possibly clion can be set up to do remote work via ssh. Does anyone have experience with this and suggestion on a good setup?
Depending on what restrictions you have, you could try VSCode? That's what students were told to do at my university for remote C / C++ development off the school's servers
I’m interested to know why it’s done like that. It seems awful. Do you have some SCM like git? Do you have restrictions like working for the army? So many questions.
I’m asking because I’ve seen that a lot in the past and it was always due to bad practices that no one wanted or could change.
We have a similar setup where I work (enough different to think they don't work with me, but who knows). It was done like that in our case because we ship embedded linux. Because we are building on linux and targeting linux we kept running into problems with people linking local system libraries that were not compatible with the target even though they had the same name. We eventfully wrote out own package management tool which locked things down so you can't make that mistake - the same month we hit 1.0 conan did their first public release, if canan has been 2 years sooner we would have just contributed to that instead and saved a ton of effort, but now we have too many sunk costs in our current tools and so it isn't worth changing to a new one.
do you know how the VM was created? can you recreate the dependencies?
which OS are you on?
you mention qtcreator - do you have remote desktop session?
I ask these questions because my preliminary solutions without knowing all the details would be
recreate the VM locally, install the tools you need
mount the project on your machine with sshfs, use the tools you require locally
use the VM as a proxy if you're using it to access an internal git to clone the repo to your local machine and use local tools there
create a remote desktop session and forward it locally either via ssh x11 forwarding or connect to it via some RDP client like remmina, krdc, or whatever your OS uses
qtcreator has code completion btw, so you can use it for your development tasks.
The application is very resource heavy and is also designed for specific hardware, it can’t be run on the windows laptops we are provided. There are security concerns as well, which limit what I am allowed to do.
Currently I’m using vnc viewer to open a shell where I can run applications like qtcreator and get a gui interface. I’m sure I could run a local ide and ssh into the vm with it, but I know that can be tricky getting proper code coverage for jump to references to work. I guess I’ll try it and see what happens!
Sshfs should work with a local IDE like CLion from Jetbrains (although that's pay to use, it's the best C++ IDE I know of).
Out of curiosity, what's wrong with qtcreator in VNC viewer? Qtcreator should provide code completion, going to definitions, expanding macros, and so on.
Vim has its own plugin system that can provide all of the things on your list. Most people used to use a plugin manager like vim-plug or pathogen, but plugins can also be installed manually.
With vim 8 there is built in plugin management. Just open the editor and type
:help packages
Plugins (including the plugin managers which are plugins themselves) get installed in your user's home directory, so you can install them yourself without affecting other users or involving the sysadmins who are giving you pushback on installing other applications system-wide.
Interesting, I’ll probably still have to ask for permission to pull anything from the outside onto the vm, but hopefully will get less push back if it’s for a tool already installed and in use.
About a year or 2 ago i used doom emacs to ssh into my home server, it's almost the same as opening a file in my own computer so the experience is really seamless
That doesn't really solve his issue because what he wants depends on having servers (lint, lsp) running local to the codebase/machine. Anything with emacs will be a major pain unless it's a really small project.
not sure what you're talking about but there's two things here.
TRAMP is great and you can run the lsp on the remote machine without installing anything assuming the linters and lsp are already installed. for comparison, vscode remote downloads and runs a shim thing when you connect.
I use doom emacs at work for large codebases all the time and haven't run into any problems. why does it only work for really small projects?
If you are on Linux locally, you could try using sshfs, to "mount" the remote system to your local one and use your local dev tools. Though I suspect that would be against the spirit of what company is hoping for.