This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2020-06-29
Channels
- # announcements (10)
- # babashka (18)
- # beginners (136)
- # calva (9)
- # cider (14)
- # clara (12)
- # clj-kondo (32)
- # cljsrn (3)
- # clojure (133)
- # clojure-europe (21)
- # clojure-nl (4)
- # clojure-uk (15)
- # clojurescript (60)
- # conjure (40)
- # cursive (12)
- # datomic (6)
- # emacs (2)
- # fulcro (19)
- # jackdaw (25)
- # jobs-discuss (3)
- # kaocha (3)
- # leiningen (5)
- # off-topic (99)
- # pedestal (1)
- # re-frame (49)
- # reagent (4)
- # ring (5)
- # rum (5)
- # shadow-cljs (53)
- # spacemacs (2)
- # sql (13)
- # timbre (2)
- # tools-deps (23)
- # vim (11)
- # xtdb (7)
Hey all - I was working on my dev env with vim-iced
and tmux
. When I was working on it, I would fire up vim in one tmux pane, and open the repl with iced repl
in another tmux pane. Evaluating the buffer (`\eb`) or any code would cause it to evaluate in the repl session in the right hand side, which is the behavoir I want.
Now when I open the same setup, code within vim is executed but it does not effect the state of the repl in the second tmux pane. Is this intended/how the nREPL connections should work? Is there a way around this that anyone knows?
@U0M0R1LUC i don't know the answer to your question, but @UBL24PLE6 might
@U0M0R1LUC it depends if you've started another JVM or not.
So after a lot of tinkering I've found that if I connect via vim-iced prior to connecting to a repl with iced repl
, then the context is shared between the two sessions. For now it's working though, although if anyone has some documentation/references about how nRPEL contexts work, I'd be very intruiged
I'm not sure what you're uncertain about here. To be clear (and risking telling you things you already know): • a single jvm clojure only has one global state for namespaces • a single namespace has one global state for vars if your changes in one repl aren't reflected in the other, this is because the repls are talking to two different vms
nREPL contexts are instances of nrepl client objects, each one is dedicated to a specific remote vm
if you want an editor and terminal repl to be connected to the same vm, the simplest thing is to start the repl (with server) in the terminal, and connect (and not start a new vm) with the client
@U051SS2EU that actually clears things up a lot, thanks. I wasn't aware that there was a single global state for namespaces, but that makes it much easier to ration about. I'm not sure how my repls were connecting but clearly the order of operations was spinning up multiple vms
one more thing: if you are using neovim/nvim the neoterm package lets you define a shortcut to send a region to a terminal in the editor https://github.com/kassio/neoterm - I use this to send parts of a file over to a repl client (just make sure the namespaces match)
but maybe the tmux integration is the same / better