This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2021-01-26
Channels
- # announcements (5)
- # architecture (79)
- # babashka (48)
- # beginners (148)
- # calva (57)
- # cider (31)
- # clara (2)
- # clj-kondo (4)
- # cljs-dev (6)
- # cljsrn (1)
- # clojure (10)
- # clojure-australia (4)
- # clojure-dev (5)
- # clojure-europe (13)
- # clojure-france (1)
- # clojure-nl (6)
- # clojure-provo (4)
- # clojure-uk (51)
- # clojurescript (38)
- # conjure (20)
- # core-logic (18)
- # cursive (28)
- # datomic (12)
- # duct (2)
- # emacs (16)
- # figwheel-main (3)
- # fulcro (43)
- # honeysql (17)
- # hoplon (3)
- # jobs (1)
- # meander (4)
- # mount (5)
- # off-topic (32)
- # pathom (6)
- # pedestal (5)
- # re-frame (1)
- # reagent (2)
- # reveal (8)
- # shadow-cljs (209)
- # spacemacs (5)
- # tools-deps (37)
- # xtdb (18)
After connecting calva and reveal, all is OK until I happen to edit an edn data file… Then I get an Unhandled REPL handler exception.
clojure -Sdeps '{:deps {nrepl/nrepl {:mvn/version "0.8.3"} cider/cider-nrepl {:mvn/version "0.25.7"}}}' -A:reveal:config
nREPL server started on port 52491 on host localhost -
ERROR: Unhandled REPL handler exception processing message {:op info, :ns user, :symbol resources/public/kidney/edn, :id 15, :session 476d9211-b2ba-41c0-b382-65b4c724e4ff}
That ‘Calva Jack-in Clojure CLI’ terminal then continues to log errors even when returning to edit a clj file. The repl and reveal do both continue to work. Errors logged look like this:
ERROR: Unhandled REPL handler exception processing message {:op info, :ns transplants.configure, :symbol , :id 74, :session 476d9211-b2ba-41c0-b382-65b4c724e4ff}
java.lang.ClassCastException: clojure.lang.Var$Unbound cannot be cast to java.lang.ClassLoader
Still experimenting… comparing 2.0.134 at present - which appears to be working OK with reveal and visiting an EDN file. I’ll upgrade again and try without reveal…
Not sure about 134, but we've added a setting for changing the jack-in versions of dependencies. Thinking it could be something with those...
OK - so it’s possible that EDN is not the trigger. In 2.0.153 again and this time without reveal, and a jack-in gives me:
clojure -Sdeps '{:deps {nrepl/nrepl {:mvn/version "0.8.3"} cider/cider-nrepl {:mvn/version "0.25.7"}}}' -A:config -m nrepl.cmdline --middleware "[cider.nrepl/cider-middleware]"
WARNING: When invoking clojure.main, use -M
nREPL server started on port 52880 on host localhost -
ERROR: Unhandled REPL handler exception processing message {:op info, :ns transplants.configure, :symbol separate, :id 7, :session 01f14827-e8e0-4fbb-bd7b-5b336e17facb}
Things are not consistent here so it’s difficult to report. I closed vscode and retried, and there was no problem (without reveal)
Back to reveal. This time jack-in asks ‘Add port to nREPL if localhost’ - it usually doesn’t. I give it the port where nREPL started and reveal connects. No error when visiting EDN. More weirdness 😞
Lots of dependency weirdness,, indeed. But it’s good you have seen it and investigated it some. As more clues are collected we’ll probably figure it out eventually.
Bump @UCCHXTXV4 about finishing his PR about that port prompt. 😃
I continued working with that set up. But later the exception reappeared - I don’t know what triggered it. Ignoring it for now. Here’s the stack trace: https://gist.github.com/gmp26/7fccddb014559990e82c27139ba2cbec
Weird! I wonder if it's something with some code in your project that's causing cider-nrepl/orchard to throw this error
If it keeps up, and you can provide a repro project + steps to make it happen consistently, an issue with that repro project linked would be good. Soon cider-nrepl will be upgraded to 0.25.8 (next release), and was recently upgraded to 0.25.7, so I wonder if there is something that changed to cause that, and I wonder if it'll be resolved after an upgrade
I wondered that too, but the stack trace doesn’t go near my code. All this weird stuff started happening after the Christmas break and when I go back to the pre Christmas release (134 is my favourite) it stops happening.
I think there's been at least a couple upgrades of jack-in deps, maybe some back around that time, so that could be it.
Wondering if this is related to this: https://github.com/clojure-emacs/orchard/issues/103. I linked your gist there and asked about it
https://github.com/clojure-emacs/orchard/issues/103#issuecomment-767874955 Looks like this is fixed now. Hopefully with the next Calva release which includes a cider-nrepl update, you won't see this error any more.
When I try to evaluate a bad code like this (assoc [] [:foo :bar] 42)
I get no feedback at all. In 2.0.152 it works as expected throws an error:
; Execution error (IllegalArgumentException) at zelark.aoc.maze/eval6016 (REPL:26).
; Key must be integer
Is it a known issue?
I get that error in 2.0.153. Not sure what could be going on. Have you tried reloading your VS Code / repl?
After restarting the editor it has gone. Thanks.
But seems like there is some other problem that is related to namespaces switching. I’ll try to reproduce it and make a capture of my screen.
I can’t figure out how to make it reproducible firmly, but it happens time to time to me. When I try evaluate some bad code as in the example above, I don’t see any feedback.
(ns app.foo
(:require [app.bar :as bar]))
In this case app.bar doesn’t exist. When I tried evaluate it, nothing happened.In the video zelark.maze
doesn’t exist.
An important note: after I downgraded to 152, it seems the issue doesn’t appear at all.
@U051BLM8F I wonder can it be related to the latest fix in Orchard https://github.com/clojure-emacs/orchard/blob/master/CHANGELOG.md#064-2021-01-25
Yeah, there was an issue there, that's already fixed in the next Orchard/cider-nrepl release.
In which case you can solve this for your install, @U067R559Q, by using the jack-in dependency settings: https://calva.io/customizing/#jack-in-dependency-versions
Oh, that’s a good point, I forgot about it. But it’s better to update for all calva users.
Yeah an update to cider-nrepl 0.25.8 is in the dev branch already, will go out next release
Hey! Just installed calva and I have run into a weird problem. Getting bunch of unresolved symbol errors. Why could that happen?
I feel like this should be in a suggestion box somewhere? It took me unusually long to find the answer to this in regular documentation when I first ran into it. Could, upon the detection of a macro with an unresolved symbol, this trigger some sort of suggestion box? Maybe that's a new feature suggestion for clj-kondo? Just sharing some thoughts
Yeah, I think if anything it would be a clj-kondo concern, but I'm not sure what more could be done to assist. CC @U04V15CAJ
clj-kondo doesn’t provide the lsp here, right? It reports a linting issue. I think the more plausible options for providing tips on how to handel it are clojure-lsp, or Calva, through lsp middleware.
I think adding a link to the docs would best since there is often not one best way to solve a problem. Adding ignores all over the place would maybe prevent people from reading the docs
@U0ETXRFEW If I'm not mistaken the message they're concerned about is from clj-kondo, and the config they're looking for is clj-kondo config. Clojure-lsp is just the middleman here.
I'm not sure what options lsp has to provide any help here, as it's merely providing diagnostics via the protocol structure, and VS Code is the thing that renders the diagnostics in that way.
But that would seem maybe a bit too much / crowded. I don't know off hand how we can control what pops up there when they hover, is what I mean. Maybe there is a way though. If we were to try to make lsp provide a link via the hover lsp message, then it would need to cross reference diagnostics on the server before providing hover content. Other than than, I suppose maybe Calva could add a hover provider and reference the diagnostics received from lsp. Seems a bit complex for something like this though, but probably doable.