from Hacker News

Bcvi – run vi over a 'back-channel' (2010)

by leonry on 3/6/25, 6:55 PM with 26 comments

  • by loskutak on 3/7/25, 2:01 PM

    Nice!

    I do something like this with WezTerm. When I ssh into a server where I work, I can run

        e some/path/whatever
    
    which just prints a special string containing some control characters, the server hostname and the path. The local wezterm parses it and calls emacsclient with the appropriate TRAMP path. So ssh to server, work there, call `e ~/.bashrc` and the remote file immediately opens in my local emacs. This is really useful when I am in some deep directory structure.

    I use the same mechanism to play remote videos - running `mpv experiment/output_foobar.mp4` just prints the special string, which the WezTerm terminal emulator parses and plays the video using my laptop mpv video player. Really really useful for me every day. I run some experiments, can inspect the results immediately. I also have the "reverse scp" which I use from time to time. `rscp foobar.py /tmp/` causes my laptop to download the foobar.py from the current working directory on the remote server into local /tmp/.

    The mechanism is explained here [1] and here [2]

    The bash function `e` on the server just prints the special string to SetUserVar with name remotemacs and value hostname---path. In wezterm config I have:

        wezterm.on('user-var-changed',
            function(win, pane, name, value)
                if name == "remotemacs" then
             -- remotemacs:hostname---path
             local match_start, match_end, hostname, path = string.find(value, "^(.-)[-][-][-](.-)$")
             local tramp_path = "/ssh:" .. hostname .. ":" .. path
             wezterm.background_child_process {'sh', '/home/loskutak/scripts/remotemacs', tramp_path}
    
    [1] https://wezterm.org/config/lua/window-events/user-var-change...

    [2] https://wezterm.org/recipes/passing-data.html

  • by cycomanic on 3/6/25, 9:33 PM

    I was actually looking for something like this 2-3 months ago. Did not find anything and was considering writing my own, but got distracted. Quite cool, I encounter situations where I would like to do this all the time.
  • by darrenf on 3/6/25, 8:42 PM

    If I’m reading this right, it’s “open a local vi(m) on a remote file”, by invoking a remote command. Is that right?

    I’m wondering how it’s different in effect to just using

        vim sftp://host/path/to/file
  • by mgarciaisaia on 3/8/25, 1:05 AM

    I'd expect the next generation of terminals to do this out of the box when using SSH.

    I never want to run the server's vi[m]/emacs/nano if I already have my own local one completely set up. I don't want to run the remote's bash - I have mine already customized! I want to open a new tab in my terminal - and have it connected to the remote, as if I opened a new tab on the server's terminal.

    It's the remote's files and process tree and resources what I want to interact with - but I'd rather leverage my local settings as much as possible.

  • by pvg on 3/6/25, 7:08 PM

  • by twiclo on 3/7/25, 3:13 AM

    I prefer sshfs for something like this. Then I can create files the regular way and edit files with my local neovim config.
  • by t-3 on 3/6/25, 7:14 PM

    This is pretty cool. I probably don't have much real use case for it because this is basically how I already do things when I use nfs or sshfs to bring the work to my local machine while keeping the files remote, but with more work involved.
  • by kazinator on 3/7/25, 5:20 AM

    This could use forwarding. Has anybody tried to get that working? I mean, you ssh from host A to B, and from B to C. Then from C you bcvi a file such that you're editing on A.
  • by zelcon on 3/7/25, 4:48 AM

    Look at what they need to mimic a fraction of our power (TRAMP)