[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-6677":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":17,"stars7d":18,"stars30d":19,"stars90d":16,"forks30d":16,"starsTrendScore":20,"compositeScore":21,"rankGlobal":10,"rankLanguage":10,"license":22,"archived":23,"fork":23,"defaultBranch":24,"hasWiki":25,"hasPages":23,"topics":26,"createdAt":10,"pushedAt":10,"updatedAt":35,"readmeContent":36,"aiSummary":37,"trendingCount":16,"starSnapshotCount":16,"syncStatus":38,"lastSyncTime":39,"discoverSource":40},6677,"cmux","manaflow-ai\u002Fcmux","manaflow-ai","Ghostty-based macOS terminal with vertical tabs and notifications for AI coding agents","https:\u002F\u002Fcmux.com",null,"Swift",21786,1664,29,1266,0,107,829,5056,512,44.66,"Other",false,"main",true,[27,28,29,30,31,32,33,34],"amp","claude-code","codex","gemini","ghostty","opencode","terminal","tmux","2026-06-12 02:01:28","\u003Ch1 align=\"center\">cmux\u003C\u002Fh1>\n\u003Cp align=\"center\">A Ghostty-based macOS terminal with vertical tabs and notifications for AI coding agents\u003C\u002Fp>\n\n\u003Cp align=\"center\">\n  \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fmanaflow-ai\u002Fcmux\u002Freleases\u002Flatest\u002Fdownload\u002Fcmux-macos.dmg\">\n    \u003Cimg src=\".\u002Fdocs\u002Fassets\u002Fmacos-badge.png\" alt=\"Download cmux for macOS\" width=\"180\" \u002F>\n  \u003C\u002Fa>\n\u003C\u002Fp>\n\n\u003Cp align=\"center\">\n  English | \u003Ca href=\"README.ja.md\">日本語\u003C\u002Fa> | \u003Ca href=\"README.vi.md\">Tiếng Việt\u003C\u002Fa> | \u003Ca href=\"README.zh-CN.md\">简体中文\u003C\u002Fa> | \u003Ca href=\"README.zh-TW.md\">繁體中文\u003C\u002Fa> | \u003Ca href=\"README.ko.md\">한국어\u003C\u002Fa> | \u003Ca href=\"README.de.md\">Deutsch\u003C\u002Fa> | \u003Ca href=\"README.es.md\">Español\u003C\u002Fa> | \u003Ca href=\"README.fr.md\">Français\u003C\u002Fa> | \u003Ca href=\"README.it.md\">Italiano\u003C\u002Fa> | \u003Ca href=\"README.da.md\">Dansk\u003C\u002Fa> | \u003Ca href=\"README.pl.md\">Polski\u003C\u002Fa> | \u003Ca href=\"README.ru.md\">Русский\u003C\u002Fa> | \u003Ca href=\"README.bs.md\">Bosanski\u003C\u002Fa> | \u003Ca href=\"README.ar.md\">العربية\u003C\u002Fa> | \u003Ca href=\"README.no.md\">Norsk\u003C\u002Fa> | \u003Ca href=\"README.pt-BR.md\">Português (Brasil)\u003C\u002Fa> | \u003Ca href=\"README.th.md\">ไทย\u003C\u002Fa> | \u003Ca href=\"README.tr.md\">Türkçe\u003C\u002Fa> | \u003Ca href=\"README.km.md\">ភាសាខ្មែរ\u003C\u002Fa> | \u003Ca href=\"README.uk.md\">Українська\u003C\u002Fa>\n\u003C\u002Fp>\n\n\u003Cp align=\"center\">\n  \u003Ca href=\"https:\u002F\u002Fx.com\u002Fmanaflowai\">\u003Cimg src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002F@manaflow-555?logo=x\" alt=\"X \u002F Twitter\" \u002F>\u003C\u002Fa>\n  \u003Ca href=\"https:\u002F\u002Fdiscord.gg\u002FxsgFEVrWCZ\">\u003Cimg src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FDiscord-555?logo=discord\" alt=\"Discord\" \u002F>\u003C\u002Fa>\n  \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fmanaflow-ai\u002Fcmux\">\u003Cimg src=\"https:\u002F\u002Fimg.shields.io\u002Fgithub\u002Fstars\u002Fmanaflow-ai\u002Fcmux?style=flat&logo=github&label=stars&color=4c71f2\" alt=\"GitHub stars\" \u002F>\u003C\u002Fa>\n\u003C\u002Fp>\n\n\u003Cp align=\"center\">\n  \u003Cimg src=\".\u002Fdocs\u002Fassets\u002Fmain-first-image.png\" alt=\"cmux screenshot\" width=\"900\" \u002F>\n\u003C\u002Fp>\n\n\u003Cp align=\"center\">\n  \u003Ca href=\"https:\u002F\u002Fwww.youtube.com\u002Fwatch?v=i-WxO5YUTOs\">▶ Demo video\u003C\u002Fa> · \u003Ca href=\"https:\u002F\u002Fcmux.com\u002Fblog\u002Fzen-of-cmux\">The Zen of cmux\u003C\u002Fa>\n\u003C\u002Fp>\n\n## Features\n\n\u003Ctable>\n\u003Ctr>\n\u003Ctd width=\"40%\" valign=\"middle\">\n\u003Ch3>Notification rings\u003C\u002Fh3>\nPanes get a blue ring and tabs light up when coding agents need your attention\n\u003C\u002Ftd>\n\u003Ctd width=\"60%\">\n\u003Cimg src=\".\u002Fdocs\u002Fassets\u002Fnotification-rings.png\" alt=\"Notification rings\" width=\"100%\" \u002F>\n\u003C\u002Ftd>\n\u003C\u002Ftr>\n\u003Ctr>\n\u003Ctd width=\"40%\" valign=\"middle\">\n\u003Ch3>Notification panel\u003C\u002Fh3>\nSee all pending notifications in one place, jump to the most recent unread\n\u003C\u002Ftd>\n\u003Ctd width=\"60%\">\n\u003Cimg src=\".\u002Fdocs\u002Fassets\u002Fsidebar-notification-badge.png\" alt=\"Sidebar notification badge\" width=\"100%\" \u002F>\n\u003C\u002Ftd>\n\u003C\u002Ftr>\n\u003Ctr>\n\u003Ctd width=\"40%\" valign=\"middle\">\n\u003Ch3>In-app browser\u003C\u002Fh3>\nSplit a browser alongside your terminal with a scriptable API ported from \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fvercel-labs\u002Fagent-browser\">agent-browser\u003C\u002Fa>\n\u003C\u002Ftd>\n\u003Ctd width=\"60%\">\n\u003Cimg src=\".\u002Fdocs\u002Fassets\u002Fbuilt-in-browser.png\" alt=\"Built-in browser\" width=\"100%\" \u002F>\n\u003C\u002Ftd>\n\u003C\u002Ftr>\n\u003Ctr>\n\u003Ctd width=\"40%\" valign=\"middle\">\n\u003Ch3>Vertical + horizontal tabs\u003C\u002Fh3>\nSidebar shows git branch, linked PR status\u002Fnumber, working directory, listening ports, and latest notification text. Split horizontally and vertically.\n\u003C\u002Ftd>\n\u003Ctd width=\"60%\">\n\u003Cimg src=\".\u002Fdocs\u002Fassets\u002Fvertical-horizontal-tabs-and-splits.png\" alt=\"Vertical tabs and split panes\" width=\"100%\" \u002F>\n\u003C\u002Ftd>\n\u003C\u002Ftr>\n\u003Ctr>\n\u003Ctd width=\"40%\" valign=\"middle\">\n\u003Ch3>SSH\u003C\u002Fh3>\n\u003Ccode>cmux ssh user@remote\u003C\u002Fcode> creates a workspace for a remote machine. Browser panes route through the remote network so localhost just works. Drag an image into a remote session to upload via scp.\n\u003C\u002Ftd>\n\u003Ctd width=\"60%\">\n\u003Cimg src=\".\u002Fdocs\u002Fassets\u002Fssh.png\" alt=\"cmux SSH\" width=\"100%\" \u002F>\n\u003C\u002Ftd>\n\u003C\u002Ftr>\n\u003Ctr>\n\u003Ctd width=\"40%\" valign=\"middle\">\n\u003Ch3>Claude Code Teams\u003C\u002Fh3>\n\u003Ccode>cmux claude-teams\u003C\u002Fcode> runs Claude Code's teammate mode with one command. Teammates spawn as native splits with sidebar metadata and notifications. No tmux required.\n\u003C\u002Ftd>\n\u003Ctd width=\"60%\">\n\u003Cimg src=\".\u002Fdocs\u002Fassets\u002Fclaude-code-teams.png\" alt=\"Claude Code Teams\" width=\"100%\" \u002F>\n\u003C\u002Ftd>\n\u003C\u002Ftr>\n\u003C\u002Ftable>\n\n- **Browser import** — Import cookies, history, and sessions from Chrome, Firefox, Arc, and 20+ browsers so browser panes start authenticated\n- **Custom commands** — Define project-specific actions in [`cmux.json`](https:\u002F\u002Fcmux.com\u002Fdocs\u002Fcustom-commands) that launch from the command palette\n- **Scriptable** — CLI and socket API to create workspaces, split panes, send keystrokes, and automate the browser\n- **Native macOS app** — Built with Swift and AppKit, not Electron. Fast startup, low memory.\n- **Ghostty compatible** — Reads your existing `~\u002F.config\u002Fghostty\u002Fconfig` for themes, fonts, and colors\n- **GPU-accelerated** — Powered by libghostty for smooth rendering\n\n## Install\n\n### DMG (recommended)\n\n\u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fmanaflow-ai\u002Fcmux\u002Freleases\u002Flatest\u002Fdownload\u002Fcmux-macos.dmg\">\n  \u003Cimg src=\".\u002Fdocs\u002Fassets\u002Fmacos-badge.png\" alt=\"Download cmux for macOS\" width=\"180\" \u002F>\n\u003C\u002Fa>\n\nOpen the `.dmg` and drag cmux to your Applications folder. cmux auto-updates via Sparkle, so you only need to download once.\n\n### Homebrew\n\n```bash\nbrew tap manaflow-ai\u002Fcmux\nbrew install --cask cmux\n```\n\nTo update later:\n\n```bash\nbrew upgrade --cask cmux\n```\n\nOn first launch, macOS may ask you to confirm opening an app from an identified developer. Click **Open** to proceed.\n\n## Why cmux?\n\nI run a lot of Claude Code and Codex sessions in parallel. I was using Ghostty with a bunch of split panes, and relying on native macOS notifications to know when an agent needed me. But Claude Code's notification body is always just \"Claude is waiting for your input\" with no context, and with enough tabs open I couldn't even read the titles anymore.\n\nI tried a few coding orchestrators but most of them were Electron\u002FTauri apps and the performance bugged me. I also just prefer the terminal since GUI orchestrators lock you into their workflow. So I built cmux as a native macOS app in Swift\u002FAppKit. It uses libghostty for terminal rendering and reads your existing Ghostty config for themes, fonts, and colors.\n\nThe main additions are the sidebar and notification system. The sidebar has vertical tabs that show git branch, linked PR status\u002Fnumber, working directory, listening ports, and the latest notification text for each workspace. The notification system picks up terminal sequences (OSC 9\u002F99\u002F777) and has a CLI (`cmux notify`) you can wire into agent hooks for Claude Code, OpenCode, etc. When an agent is waiting, its pane gets a blue ring and the tab lights up in the sidebar, so I can tell which one needs me across splits and tabs. Cmd+Shift+U jumps to the most recent unread.\n\nThe in-app browser has a scriptable API ported from [agent-browser](https:\u002F\u002Fgithub.com\u002Fvercel-labs\u002Fagent-browser). Agents can snapshot the accessibility tree, get element refs, click, fill forms, and evaluate JS. You can split a browser pane next to your terminal and have Claude Code interact with your dev server directly.\n\nEverything is scriptable through the CLI and socket API — create workspaces\u002Ftabs, split panes, send keystrokes, open URLs in the browser.\n\n## The Zen of cmux\n\ncmux is not prescriptive about how developers hold their tools. It's a terminal and browser with a CLI, and the rest is up to you.\n\ncmux is a primitive, not a solution. It gives you a terminal, a browser, notifications, workspaces, splits, tabs, and a CLI to control all of it. cmux doesn't force you into an opinionated way to use coding agents. What you build with the primitives is yours.\n\nThe best developers have always built their own tools. Nobody has figured out the best way to work with agents yet, and the teams building closed products definitely haven't either. The developers closest to their own codebases will figure it out first.\n\nGive a million developers composable primitives and they'll collectively find the most efficient workflows faster than any product team could design top-down.\n\n## Documentation\n\nFor more info on how to configure cmux, [head over to our docs](https:\u002F\u002Fcmux.com\u002Fdocs\u002Fgetting-started?utm_source=readme).\n\n## Keyboard Shortcuts\n\n### Workspaces\n\n| Shortcut | Action |\n|----------|--------|\n| ⌘ N | New workspace |\n| ⌘ 1–8 | Jump to workspace 1–8 |\n| ⌘ 9 | Jump to last workspace |\n| ⌃ ⌘ ] | Next workspace |\n| ⌃ ⌘ [ | Previous workspace |\n| ⌘ ⇧ W | Close workspace |\n| ⌘ ⇧ R | Rename workspace |\n| ⌥ ⌘ E | Edit workspace description |\n| ⌘ B | Toggle sidebar |\n| ⌘ ⇧ E | Focus right sidebar |\n| ⌃ 1 \u002F ⌃ 2 \u002F ⌃ 3 | Switch Files \u002F Sessions \u002F Feed when the right sidebar is focused |\n\n### Surfaces\n\n| Shortcut | Action |\n|----------|--------|\n| ⌘ T | New surface |\n| ⌘ ⇧ ] | Next surface |\n| ⌘ ⇧ [ | Previous surface |\n| ⌃ Tab | Next surface |\n| ⌃ ⇧ Tab | Previous surface |\n| ⌃ 1–8 | Jump to surface 1–8 |\n| ⌃ 9 | Jump to last surface |\n| ⌘ W | Close surface |\n\n### Split Panes\n\n| Shortcut | Action |\n|----------|--------|\n| ⌘ D | Split right |\n| ⌘ ⇧ D | Split down |\n| ⌥ ⌘ ← → ↑ ↓ | Focus pane directionally |\n| ⌘ ⇧ H | Flash focused panel |\n\n### Browser\n\nBrowser developer-tool shortcuts follow Safari defaults and are customizable in `Settings → Keyboard Shortcuts`.\nCommand palette navigation shortcuts, including ⌃ P, are also customizable and can be cleared so the keypress reaches the active terminal.\n\n| Shortcut | Action |\n|----------|--------|\n| ⌘ ⇧ L | Open browser in split |\n| ⌘ L | Focus address bar |\n| ⌘ [ | Back |\n| ⌘ ] | Forward |\n| ⌘ R | Reload page |\n| ⌥ ⌘ I | Toggle Developer Tools (Safari default) |\n| ⌥ ⌘ C | Show JavaScript Console (Safari default) |\n\n### Notifications\n\n| Shortcut | Action |\n|----------|--------|\n| ⌘ I | Show notifications panel |\n| ⌘ ⇧ U | Jump to latest unread |\n\n### Find\n\n| Shortcut | Action |\n|----------|--------|\n| ⌘ F | Find |\n| ⌘ G \u002F ⌘ ⇧ G | Find next \u002F previous |\n| ⌘ ⇧ F | Hide find bar |\n| ⌘ E | Use selection for find |\n\n### Terminal\n\n| Shortcut | Action |\n|----------|--------|\n| ⌘ K | Clear scrollback |\n| ⌘ C | Copy (with selection) |\n| ⌘ V | Paste |\n| ⌘ + \u002F ⌘ - | Increase \u002F decrease font size |\n| ⌘ 0 | Reset font size |\n\n### Window\n\n| Shortcut | Action |\n|----------|--------|\n| ⌘ ⇧ N | New window |\n| ⌘ ⇧ O | Reopen previous session |\n| ⌘ , | Settings |\n| ⌘ ⇧ , | Reload configuration |\n| ⌘ Q | Quit |\n\n## Nightly Builds\n\n[Download cmux NIGHTLY](https:\u002F\u002Fgithub.com\u002Fmanaflow-ai\u002Fcmux\u002Freleases\u002Fdownload\u002Fnightly\u002Fcmux-nightly-macos.dmg)\n\ncmux NIGHTLY is a separate app with its own bundle ID, so it runs alongside the stable version. Built automatically from the latest `main` commit and auto-updates via its own Sparkle feed.\n\nReport nightly bugs on [GitHub Issues](https:\u002F\u002Fgithub.com\u002Fmanaflow-ai\u002Fcmux\u002Fissues) or in [#nightly-bugs on Discord](https:\u002F\u002Fdiscord.gg\u002FxsgFEVrWCZ).\n\n## Session restore\n\nQuitting cmux saves the current session. On relaunch, cmux restores:\n- Window\u002Fworkspace\u002Fpane layout\n- Working directories\n- Terminal scrollback (best effort)\n- Browser URL and navigation history\n- Saved Claude Code and Codex sessions, when cmux has a resume token for the panel\n\nIf you need to reapply the last saved snapshot manually, use:\n- `File > Reopen Previous Session`\n- `⌘ ⇧ O`\n- `cmux restore-session`\n\ncmux does **not** restore arbitrary live terminal process state. tmux, vim, shells, and other tools without a cmux resume flow still reopen as normal terminals rather than resuming in-process state.\n\n## Star History\n\n\u003Ca href=\"https:\u002F\u002Fstar-history.com\u002F#manaflow-ai\u002Fcmux&Date\">\n \u003Cpicture>\n   \u003Csource media=\"(prefers-color-scheme: dark)\" srcset=\"https:\u002F\u002Fapi.star-history.com\u002Fsvg?repos=manaflow-ai\u002Fcmux&type=Date&theme=dark\" \u002F>\n   \u003Csource media=\"(prefers-color-scheme: light)\" srcset=\"https:\u002F\u002Fapi.star-history.com\u002Fsvg?repos=manaflow-ai\u002Fcmux&type=Date\" \u002F>\n   \u003Cimg alt=\"Star History Chart\" src=\"https:\u002F\u002Fapi.star-history.com\u002Fsvg?repos=manaflow-ai\u002Fcmux&type=Date\" width=\"600\" \u002F>\n \u003C\u002Fpicture>\n\u003C\u002Fa>\n\n## Contributing\n\nWays to get involved:\n\n- Follow us on X for updates [@manaflowai](https:\u002F\u002Fx.com\u002Fmanaflowai), [@lawrencecchen](https:\u002F\u002Fx.com\u002Flawrencecchen), and [@austinywang](https:\u002F\u002Fx.com\u002Faustinywang)\n- Join the conversation on [Discord](https:\u002F\u002Fdiscord.gg\u002FxsgFEVrWCZ)\n- Create and participate in [GitHub issues](https:\u002F\u002Fgithub.com\u002Fmanaflow-ai\u002Fcmux\u002Fissues) and [discussions](https:\u002F\u002Fgithub.com\u002Fmanaflow-ai\u002Fcmux\u002Fdiscussions)\n- Let us know what you're building with cmux\n\n## Community\n\n- [Discord](https:\u002F\u002Fdiscord.gg\u002FxsgFEVrWCZ)\n- [GitHub](https:\u002F\u002Fgithub.com\u002Fmanaflow-ai\u002Fcmux)\n- [X \u002F Twitter](https:\u002F\u002Ftwitter.com\u002Fmanaflowai)\n- [YouTube](https:\u002F\u002Fwww.youtube.com\u002Fchannel\u002FUCAa89_j-TWkrXfk9A3CbASw)\n- [LinkedIn](https:\u002F\u002Fwww.linkedin.com\u002Fcompany\u002Fmanaflow-ai\u002F)\n- [Reddit](https:\u002F\u002Fwww.reddit.com\u002Fr\u002Fcmux\u002F)\n\n## Founder's Edition\n\ncmux is free, open source, and always will be. If you'd like to support development and get early access to what's coming next:\n\n**[Get Founder's Edition](https:\u002F\u002Fbuy.stripe.com\u002F3cI00j2Ld0it5OU33r5EY0q)**\n\n- **Prioritized feature requests\u002Fbug fixes**\n- **Early access: cmux AI that gives you context on every workspace, tab and panel**\n- **Early access: iOS app with terminals synced between desktop and phone**\n- **Early access: Cloud VMs**\n- **Early access: Voice mode**\n- **My personal iMessage\u002FWhatsApp**\n\n## License\n\ncmux is open source under [GPL-3.0-or-later](LICENSE).\n\nIf your organization cannot comply with GPL, a commercial license is available. Contact [founders@manaflow.com](mailto:founders@manaflow.com) for details.\n","cmux 是一个基于 Ghostty 的 macOS 终端，具有垂直标签页和针对 AI 编码代理的通知功能。其核心特点包括通知环、通知面板、内置浏览器以及支持垂直和水平标签页布局，这些设计旨在提高开发者的效率与体验。通过在需要时高亮显示标签并提供集中查看所有待处理通知的界面，cmux 使开发者能够更容易地管理多任务环境下的工作流。此外，它还允许用户在一个窗口内同时操作终端和网页浏览，非常适合需要频繁切换工具或希望简化工作流程的软件工程师使用。",2,"2026-06-11 03:08:14","top_language"]