alt.hn

5/21/2026 at 9:22:00 AM

Show HN: Rmux – A programmable terminal multiplexer with a Playwright-style SDK

https://github.com/helvesec/rmux

by shideneyu

5/21/2026 at 11:42:36 AM

Congrats on the launch. If emacs was unavailable and I needed tmux, I would try it. I am old school, and use emacs daemons for all shell multiplexing. The agents dont need explanations and know how to use emacsclient to create, read, or send inputs to named buffers that run the shells. Elisp is powerful, so manipulating windows is a breeze. Lots of people on tmux would benefit from this design though.

by pama

5/21/2026 at 3:55:26 PM

Are there any guides on accomplishing this with Emacs? Perhaps something that might be useful for someone coming from Tmux?

by evanjrowley

5/21/2026 at 8:13:31 PM

Not sure, tbh. I use emacs -daemon to start a server; emacsclient -nw to connect. I use ssh and start a server on the remote. I spawn multiple shells with infinte buffer size and dumb terminals (M-x shell) so I can seamlessly edit. (These are based on comint, a neat command interpreter.) I use my own hacks for named shells (https://github.com/pjj/Emacs-nsh) and for rearranging/splitting windows, but any of the latest powerful LLMs can help with ergonomic modifications to M-x shell or the various improved terminal emulators (vterm, eat, ansi-term) or with renaming and moving/splitting windows. The Emacs manual is excellent but long; worth it IMHO, but focus on things you use. The tutorial is quick; worth it. I avoid curses programs (fancy TUI) or write wrappers around some of them. I love the -p option in codex/claude/copilot.

by pama

5/21/2026 at 1:29:58 PM

I didn't know you could do this with Emacs

by sroerick

5/21/2026 at 2:30:45 PM

It's just too bad Emacs doesn't also include a decent text editor, right?

by scottyeager

5/21/2026 at 7:22:46 PM

Eh? Not sure what you mean by that...

by smaudet

5/21/2026 at 10:32:30 AM

The paragraph on the website inviting us to switch to rmux from tmux claims that tmux is programmed in C++. tmux is made in C.

by florianist

5/21/2026 at 10:42:13 AM

wupsy ! thanks, I just fixed it

by shideneyu

5/21/2026 at 9:42:36 AM

The website is a little too obviously made by Claude. The first thing I noticed is the classic "pill with pulsing green dot that says something is active or live" claudism.

by Sirental

5/21/2026 at 9:56:07 AM

The video of the front page is assisted by AI, I am not a vfx artist; please check rmux code architecture instead, I put a lot of efforts on it

by shideneyu

5/21/2026 at 1:38:26 PM

FWIW, I did suspect AI was probably used when looking through the README, but it also didn't really impact my opinion much because the value proposition of "I can use a Rust library to control this through the same primitives the tool itself uses instead of writing a bunch of shell scripts" far outweighs that. I haven't had a chance to try it out yet but plan to later today, and ultimately the experience I have is going to matter a lot more to me than what tools you used to generate the README visuals.

I've tried out plenty of things that seemed promising but turned out to have sloppy implementations before the LLM days, and I've also used some things that are ostensibly vibe-coded but had shockingly high quality of UX compared to the alternatives because the creators put in time and effort into polish beyond what people who make software the "traditional" way tend to, so to me, the important signal is what level of care went into the creation of the software. I'm hoping that this project turns out to be one of the good ones, and if it is, the people who dismiss it because of vibes (pun intended) will be the ones missing out.

by saghm

5/21/2026 at 4:11:03 PM

I wouldn't worry too much about it. I think the big AI standout (not your fault) is the classic GenAI lightning that behaves more like a weird viscous liquid. Another one I see a lot is the number of avian creatures flapping their wings with all the subtlety and grace of an ornithopter going in reverse.

Feedback

Your site needs some work on the responsiveness. At around 1200 pixels width on my browser, half of the video just gets cut off. It just doesn't scale correctly.

by vunderba

5/21/2026 at 1:19:38 PM

For what it's worth I genuinely loved your landing page. I casually clicked through and got an immediate unexpected chuckle at the giant animated crab.

It's obviously AI assisted but I interpreted it as a nod to itself on that and really appreciated it.

by powvans

5/21/2026 at 1:57:11 PM

Thank you ! I am proud of my little blue crab haha. I got it thanks to a lot of iteration between gpt image 2.0 and see dance 2

by shideneyu

5/21/2026 at 11:13:21 AM

"site made by ai" is the new "bootstrap template" criticism that honestly gets tiring after a while. just read the content.

by ookblah

5/21/2026 at 4:05:08 PM

If there’s anything I don’t mind being done with AI, it’s a product landing page. There are only so many ways to creatively design one, so who cares how it was made?

by herrj

5/21/2026 at 3:01:20 PM

And the site is actually quite cool I believe , I put a lot of efforts in the design.

by shideneyu

5/21/2026 at 9:43:30 AM

I’m genuinely interested in what you find to be the problem with that?

It’s a landing page.

by redrove

5/21/2026 at 4:13:12 PM

The usual answer is some handwavy nonsense about "well if you were too lazy to write the text, why should I read it?" said by the same people too lazy to write the code...

by xienze

5/21/2026 at 10:32:19 AM

commonlisp (sbcl) is one of the best sleeper techs out there. one of those if you're in the know type industry secrets. part of it is because their website looks like something out of the 90's. clearly having a nice website and some level of marketing is necessary to get adoption. Im more than happy to see devs use AI to automate that so they have more time to focus on their creations.

by cultofmetatron

5/21/2026 at 11:08:42 AM

Isn't lisp getting advertisement every couple months here or so. After so many decades I don't believe the reason lisp doesn't have traction is just marketing.

by alcasa

5/21/2026 at 1:41:35 PM

Given that Hacker News somewhat famously was written in lisp, "an advertisement every couple of months here" probably translates to an order of magnitude less in places that have a lower density of long-time lisp fans from the early days.

by saghm

5/21/2026 at 10:17:09 AM

and why this is a problem? I found the landing page covering exactly what the product does, with nice demos and examples.

by Oras

5/21/2026 at 10:33:02 AM

Not to mention those absolutely horrible scroll animations.

by stefanfisk

5/21/2026 at 10:47:02 AM

you don't like parallax effects ? maybe I'm too 2010 for you

by shideneyu

5/21/2026 at 1:40:54 PM

I think the issue is that the parallax is choppy in your page. For whatever it's worth, I typically don't care much about parallax in itself but I thought the same thing about the scrolling not being smooth.

by backwardsponcho

5/21/2026 at 1:43:21 PM

As someone new to this site, I understand wanting to keep the AI Slop at bay, but for some of us, it's been a boon to get our ideas into an actual working application. I have decades of IT/Network/Enterprise experience, but creating and writing a complex tool would have been well beyond my abilities or patience. I had a friend say that AI is a "scourge on the intellectually lazy" and I couldn't really refute that, but I had to add that it is a boon to a lazy intellectual, which I consider myself to be.

by perseusai

5/21/2026 at 10:16:53 AM

So?

by jarym

5/21/2026 at 10:53:36 AM

@jarym what don't you like with the homepage ? I am curious how I can improve

by shideneyu

5/21/2026 at 11:26:18 AM

I like it

by FergusArgyll

5/21/2026 at 11:36:07 AM

Cool project, I like the idea of having tmux-compatible CLI. I used Zellij to get better UX, but many agent tools integrate with tmux. This way agent tools can still integrate tmux as a defacto standard for programmatic interface while having better interface for users.

But I wonder if tmux/rmux design is suboptimal since it couples session persistence and window management together. Do you have an opinion the design which separates the responsibilities? An example that pioneered this approach is abduco, and libghostty-based zmx being a modern implementation.

by kloud

5/21/2026 at 12:02:56 PM

I thought I was too zealous because I created 11 crates respecting single responsibility principles.. I would have been all in to risk it further and separating responsibilities for session and window management but it would have diverged too much from tmux. I wanted a 1-1 port for now

by shideneyu

5/21/2026 at 12:32:44 PM

Fair point, given it is more unconventional design, it is a riskier way in order to get something that works.

by kloud

5/21/2026 at 8:29:16 PM

correct... it's sad but recognition is a lot. After putting months of efforts, it's a risk I didn't want to take. And following tmux was like a red thread of life to code. Maybe in the future !

by shideneyu

5/21/2026 at 4:58:03 PM

It's not clear to me what this does that tmux doesn't? Agents can already interact with tmux, so what does this provide?

by SwellJoe

5/21/2026 at 8:22:06 PM

gobdovan nailed it. The CLI is a drop-in for existing tmux workflows; the SDK eases your flow when you'd otherwise be writing brittle send-keys + sleep + capture loop. But that's just one one of the use cases. rmux should be used to make beautiful TUI, something very dirty to do with tmux. Especially the day you want to do integration testing (playwright style)

by shideneyu

5/21/2026 at 6:40:35 PM

  I think it's trying to be like a code-first/API alternative to Tmux. So instead of:
``` tmux new-session -d -s a

tmux send-keys -t a 'npm test' Enter

sleep 2

tmux capture-pane -p -t a ```

  you'd do something like:
``` pane.send_text("npm test\n").await?;

pane.wait_for_text("Tests passed").await?;

let snapshot = pane.snapshot().await?; ```

  I don't know why it would be better for agents, maybe the author also works on an LLM agent harness.

by gobdovan

5/21/2026 at 12:18:30 PM

Very cool! I think the hype around “agents are so good that you never actually need to see the underlying commands they are running or interact with the terminal session that they’re running” misses out on a lot of very important use cases, particularly around long running processes that may be shared across multiple agents. This will be very cool to see how best practices evolve!

by btown

5/21/2026 at 12:33:13 PM

Same ! TUI are becoming more and more mainstream so there is a need for automated multiplexing , not used by humans but by programs (and agents)

by shideneyu

5/21/2026 at 10:07:37 AM

I found the project quite interesting but what's the advantage over just using tmux with a hotkey to send keys?

by luizfwolf

5/21/2026 at 1:47:43 PM

Writing shell scripts to orchestrate things is not a particularly great experience. "Shell scripts are annoying to write compared to the programming languages we use for other things" isn't a universal opinion, but it's not exactly uncommon; I've heard plenty of people talk about switching to Python as soon as anything gets even moderately complex. (I often tend to go with the lines "my bar for when to switch to a real programming language is as soon as I have to write an if statement" and "the number of times I've had to write a for loop in bash is the same as the number of times I've had to google the syntax for a for loop in bash", which are only slight exaggerations). Having an actual library for interactions that isn't just a wrapper around the CLI seems like it would be a huge improvement for anything that isn't a one-off interaction.

by saghm

5/21/2026 at 10:22:07 AM

windows support, and the sdk. native async "wait until" something appears on your terminal, so you don't spam send-keys

by shideneyu

5/21/2026 at 6:31:44 PM

this might fit very nicely with gascity/gastown which orchestrates other coding agent over tmux.

currently, i finds it's tmux orchestration code is too complex.

will check it out

by shadowfax92

5/21/2026 at 6:33:08 PM

> got tired of scraping output with grep and sleeps to automate anything.

curious, what was the usecase here?

by shadowfax92

5/21/2026 at 8:22:57 PM

Hehe. I am building a multi agent orchestration system of course ;) I believe this is the future, agents speaking to one each other. It's very dirty with tmux

by shideneyu

5/21/2026 at 10:04:16 AM

a week ago I was using cmux but its osx only and doen't work on remote terminals. then I switched to herdr which is great so far except its not s great at managing panes. I can't move them around or change ordering. now another terminal multiplexer. I'm getting whiplash.

all that said, none of the existing solutions are perfect and rust codebases are nice. how easy is it to reorder panes? is there a cli that lets me control the panel layout via a skill file and allow my opencode session to target and send data to other panes?

by cultofmetatron

5/21/2026 at 10:15:32 AM

I started using cmux a month ago and it had made my life a lot easier. Finally I have a pane with all my projects open all the time, I can switch between them, have multiple terminals for each one.

What do you mean by remote terminals?

by Oras

5/21/2026 at 10:36:13 AM

my plan is to eventually move my entire workflow to a remote workmachine over ssh. with kernal, I can automate all my smoketests entirely from a headless machine rendering my laptop overkill to run agentic workflows. I'd rather be using it to watch movies, learn new stuff or hand code in my downtime. if your workflow requires cmux, you're stuck running your agents on your local machine.

To be clear, That doesn't make cmux bad. if you WANT to do everythign on your mac, cmux is fantastic. its just not designed with the remote ssh control use case in mind.

by cultofmetatron

5/21/2026 at 5:22:25 PM

Exactly, the whole point of having a laptop is that you can close it at some point. Once you move to these newfangled workflows it is all gone. That is why I have been slow on uptake with all these new apps they are releasing like Codex GUI and Claude GUI and all that stuff. I like that work continues when I close my laptop, but also I like that it continues on my hardware, not somewhere in the cloud being a supply chain attacked by who knows what.

by vardalab

5/21/2026 at 11:27:17 AM

I'm one of the creators of cmux. I'm moving a lot of my own dev work to Mac Minis, so I'm starting to feel quite a lot of the pain you mentioned... will try to make this better!

by lawrencechen

5/21/2026 at 8:33:25 PM

please do and let me know ! quick story fast, I'm working a loooot remotely. I'm using https://github.com/sanchxt/yoop to synchronize my keyboard. Since I'm using moonlight it's blazing fast. But when I work in the train I'm back to ssh. My quick tip would be to: build your own tools, build them once, use them forever. and rmux is exactly made for that, it's prefect for TUIs over ssh and low connection that needs to stay alive even if you get disconnected

by shideneyu

5/21/2026 at 11:40:11 AM

I built https://zmx.sh to make it easier to interact with your terminal sessions programmatically. 1 window = 1 session which might feel like a negative but it makes programmatic access easy and agents can use it just by pointing it at the zmx help command. Basically, an agent just needs 2 commands (run and write) for full control and the commands are synchronous so you don’t need to do any polling.

by qudat

5/21/2026 at 8:27:43 PM

nice, zmx is a very nice approach. I did not want to take risks and change the expected behavior of the renown tmux. My main goal was 1) to rewrite tmux the modern way more elegantly (async, rust) and give it windows support 2) to give it a SDK. I think 1 window = 1 session is the right way, but it's a risky market move I didn't want to tackle for adoption. Maybe on a breaking v2 !

by shideneyu

5/21/2026 at 10:23:15 AM

no skill file, you get the same 90 commands of tmux. and if you build a rust app you can have many more cool stuff like "wait for" some text to appear, asyncly

by shideneyu

5/21/2026 at 10:40:12 AM

well it looks great so far but Its a no go for me for now until you have at least a cli that a coding harness can use to drive it. thats going to be the killer feature going forward for all these multiplexers. last week I vibecoded a plugin that lets me open a line specific input box that sends the context of my code along with my prompt into my opencode session running on a seperate pane. its a game changer when it comes to moving faster.

excited to check back in on the progress as you work on it though! I think these kinds of tools are going to be much more relevant going forward as we all move to agentic workflows.

by cultofmetatron

5/21/2026 at 10:46:23 AM

ok will check it out then ! Thank you, putting it on my todo list

by shideneyu

5/21/2026 at 11:33:30 AM

Getting this error when installing from git bash:

$ curl -fsSL https://rmux.io/install.sh | sh rmux install: unsupported OS: MINGW64_NT-10.0-26200

by 0x1ceb00da

5/21/2026 at 4:48:52 PM

noted, I'll check this out, thank you

by shideneyu

5/21/2026 at 2:29:52 PM

Very nice!

I created `ygg`[0] a while back to easily spawn a new worktree when working with Claude/codex, and it also spawns that in a dedicated zellij tab. I think making the terminal multiplexer pluggable, so it would be easy to integrate something like this.

[0] https://github.com/joch/ygg

by joch

5/21/2026 at 8:30:53 PM

nice tool ! totally. rmux is lightweight, I believe it would be easy

by shideneyu

5/21/2026 at 11:48:48 AM

Scriptable terminal multiplexer?

Interesting portable scripting thingy. But it would only work with portable tools, not just everything. Especially with Windows tools.

by notorandit

5/21/2026 at 11:55:22 AM

I wrote it for rust apps in mind, same usecase as for Ratatui. You’re right maybe I need to expose more tools with the cli

by shideneyu

5/21/2026 at 9:56:12 AM

Hey, I automate tmux all the time with send keys and capture.. how is your project improves vs tmux or zellij?

by kosolam

5/21/2026 at 10:24:53 AM

rmux is much faster than tmux or zellj, I did some internal benchmark and it's promising. rmux is a multiplexer engine, meaning that you can rewrite entirely zellij using rmux.. I created a mini zellij in a few hundred lines of rust. You can check the demoes on the repo

by shideneyu

5/21/2026 at 10:50:02 AM

But wait, I’m a user of tmux or zellij which for me was basically another tmux and I went back to tmux eventually. I’m not looking to develop another tmux or something. Is this project more of a library to create tmux like apps?

by kosolam

5/21/2026 at 11:06:05 AM

As of today you can replace tmux by rmux. Its behavior should be 1-1 iso; tmux is more stable though, it has been battle tested with a dozen of years of edge cases refinement. rmux is a faster and more elegant clone of tmux + windows support + programmable sdk

by shideneyu

5/21/2026 at 10:19:45 AM

I don't get it as well, everything mentioned in the readme is already trivially possible with tmux or zellij

by Galanwe

5/21/2026 at 10:28:24 AM

windows support + async + public sdk. You can rewrite zellij with rmux, but not the opposite. rmux is a multiplexer engine

by shideneyu

5/21/2026 at 10:09:06 AM

I mean, the obvious immediate answer is “windows”, which tmux flat out doesn't support (except via WSL and a shared mount).

by noodletheworld

5/21/2026 at 11:33:18 AM

I used to use ghostty's applescript and built that into a claude skill. It worked like a charm. But this feels super interesting for programmability

by cat-whisperer

5/21/2026 at 9:50:33 AM

Never had the need to do playwright automation for tmux, so not sure why I would use this above tmux which works well.

by small_model

5/21/2026 at 9:57:13 AM

with rmux you can finally do acceptance/integration tests on your terminal user interfaces. tmux is made for humans, rmux is made for both humans and machines

by shideneyu

5/21/2026 at 12:01:00 PM

Floating panes seems not possible, or are they?

by yes_but_no

5/21/2026 at 12:04:23 PM

Not part of the current version, it’s on my roadmap :)

by shideneyu

5/21/2026 at 10:22:31 AM

Can someone describe the pros/cons vs zellij?

by elromulous

5/21/2026 at 10:27:03 AM

You can rewrite Zellij entirely with rmux , that's the main difference. I put a demo on the repo. Because rmux is an engine. I wrote it to be the multiplexer of multiplexers

by shideneyu

5/21/2026 at 11:25:42 AM

1. ask Claude to rewrite X in Rust

2. ask Claude to make a website and claim R is better than X because it's Rust

3. advertise on HN, X and Reddit

4. ???

5. profit!

by DeathArrow

5/21/2026 at 11:41:03 AM

If the tokens are already burned, it's better for the environment to share the result for everyone to use it.

by miroljub

5/21/2026 at 7:18:12 PM

[dead]

by agentifysh

5/21/2026 at 1:13:26 PM

[flagged]

by eddyaipt

5/21/2026 at 3:00:14 PM

Yes exactly. And it enables integration testing too. I hope it will foster the release of more cool TUIs.

by shideneyu

5/21/2026 at 7:28:56 PM

[dead]

by abdullahob

5/21/2026 at 4:44:16 PM

[dead]

by tomaspiaggio12

5/21/2026 at 2:49:14 PM

[dead]

by perkovsky

5/21/2026 at 10:17:37 AM

[dead]

by nikhilpareek13