-
-
Notifications
You must be signed in to change notification settings - Fork 223
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Wrong path 'Go to Definition' when working in a Docker container #2699
Comments
Hi! Thanks for reporting. Can you try with latest nrepl and cider-nrepl and see if the issue persists (I think it will, but for good measure). If you are using Jack-in, these settings should do it: "calva.jackInDependencyVersions": {
"nrepl": "1.3.0",
"cider-nrepl": "0.51.0",
"cider/piggieback": "0.5.3"
}, Also, if you enable nrepl logging, via the command Calva Diagnostics: Toggle nREPL Logging Enabled, we can see if the nrepl server may already be trying to help Calva with the issue. There is also a "calva.definitionProviderPriority": [
"repl",
"lsp"
], I think that clojure-lsp will be using the local file paths, so you can hopefully use that as a workaround while we figure out how to make the REPL provider do the right thing. |
Thanks a lot for the workaround. As suggested I set "calva.definitionProviderPriority": [
"lsp",
"repl"
] and now 'Go to Definition' works 🥳 One strange thing was that the settings in the UI always switches back to the default, despite the fact that you get the correct one if you use 'Copy Settings as JSON'. Maybe a Cursor-only issue: I also looked at the
|
Thanks! The Settings UI glitch is hopefully tracked on VS Code. I notice that the response message has two entries with what looks like a relative path. Maybe Calva could check if the Did you try with the latest nrepl dependencies any? About the workaround. May go without saying, but now you go to definition for a different truth. It's not the REPL truth. Sometimes it makes sense to go for the static truth, like if you have edited the files, but not recompiled (but why would you not recompile changes?). Sometimes it doesn't make as much sense as the REPL truth, like if you have redefined the function in some rich comment or a fiddle file, or the REPL prompt, and compiled that. I'm a REPL truth person 😄 generally. |
The absolute path for CLJS files comes from Orchard. I found the code that is responsible for that, but I'm not sure I can "fix" that, I'm not that familiar with CLJS and its nuances. The CLJ files that are local to the project arrive as relative paths in |
I'm sorry for wasting everybody's time here 😅 I switched to the most recent versions of: nrepl/nrepl {:mvn/version "1.3.1"}
cider/cider-nrepl {:mvn/version "0.51.1"} And I switched back to 'REPL truth' and now 'Go to Definition' works flawlessly 👍 Thanks again for all your help. |
Awesome! If you don't mind I'd like to keep this issue open. 😄 It should probably be fixed by us bumping the default nrepl dependencies. @alexander-yakushev did you fix something between 0.51.0 and 0.51.1 pertaining this issue? |
I don't think so, at least not intentionally. |
First of all, thanks a lot for creating Calva, it is awesome 🎉
We develop our project inside a Docker container, so that all developers have the same dev environment. While VSCode runs on the docker host. In our case the source code resides inside the
/app/
folder within the Docker container. When we use right-click -> 'Go to Definition' we get the error shown in the screenshot. It uses the path from within the container, which does not exist on the Docker host. One way to fix this might be to use the relative path to the source file and always prepend the path of the current VSCode project (which should be a path on the Docker host).The text was updated successfully, but these errors were encountered: