-
-
Notifications
You must be signed in to change notification settings - Fork 648
Description
Is your feature request related to a problem? Please describe.
Some people are always frustrated that CIDER requires some additional setup (namely the need for cider-nrepl
) and would prefer if they had a limited subset of functionality, but everything worked out of the box.
I resisted this idea in the past, but now I've come to realize that my ideological purity is not necessarily the right thing. There are also some other practical benefits from a more flexible approach - namely you could connect to any random nREPL server and get a bit more than just basic evaluation.
Describe the solution you'd like
We'd simply put some fallback for cider-nrepl powered commands (when possible) that's simple evaluation of Clojure code. Ideally we'd have to come up with code that's bundled with Clojure but we can also add some checks for common libraries on the classpath (e.g. orchard, compliment, etc).
I think the most important things we should aim to support with this eval fallback are:
- completion
- jump to definition
- doc
- eldoc
- running tests
Note: all such evaluations should happen in the tooling session, so their results won't mess up *1
, *2
, etc.
Describe alternatives you've considered
There are no real alternatives to this (at least I can't think of any), and the eval approach will become even more feasible when we implement sideloading in nREPL.
Additional context
CIDER used to have such a fallback mechanism prior to version 0.8, so we can restore a bit of functionality from there. I know @arichiardi will be happy about this direction. :-)