iTerm2 启动时默认进入 Tmux 模式

介绍一个最快速的方式使 iTerm2 启动默认进入 Tmux 模式。默认情况下,每次启动 iTerm2,还需要一步输入 tmux attach 进入到 tmux 模式下。

我用 Tmux 是为了管理不同项目的工作区,常见的 IDE 一般够提供了打开提供给用户一个选择项目的界面。自然而然,iTerm2 + Tmux 是否也能实现类似的能力呢?

非常简单!

核心脚本介绍

首先,一段 bash 脚本:

bash 复制代码
tmux ls && read -p "Select a session<default>:" tmux_session && tmux attach -t ${tmux_session:-default} || tmux new -s ${tmux_session:-default}

这段脚本的说明如下:

  • tmux ls, 先输出当前可用的 session 列表,供用户输入使用;
  • read xxx, 读取用户输入,将希望打开的会话名称存入 tmux_session 中;
  • tmux attach,尝试打开会话,如果 tmux_session 为空,打开 default 会话;
  • tmux new,如果开启失败,尝试创建一个新的会话;

说明:由于 read 命令使用了-p,必须要使用 bash 运行这段脚本。

配置 iTerm2 启动加载

选择 Preference -> Profile -> General -> Command -> Select "Login Sell",并将代码放到 "Send text at start" 的输入框即可。

效果如下:

bash 复制代码
hello: 1 windows (created Tue Sep 12 17:13:54 2023) (group hello) (attached)
default: 1 windows (created Wed Sep 13 19:54:36 2023) (group default)
Select a session<default>:

输入 "hello",即可进入 "hello" 会话。简洁高效,有点想 IDE 启动的之后,让我们选择项目的感觉。

如果希望会话列表足够简洁,只有会话名称,可用 tmux ls 的输出格式化默认,将 tmux ls 进化为 tmux -F '\#{session_name}'

bash 复制代码
hello
default

尝试升级改进

能不能只输入索引编号,实现快速选择呢?这种简单的 shell script 不容易实现。写了一段 Python 脚本,如下所示:

python 复制代码
#!/usr/bin/env python
import os

output = os.popen("tmux ls -F \\#{session_name}").read()
sessions = output.strip().split("\n")

print("Sessions:")
for index in range(len(sessions)):
    print(f"{index} - {sessions[index]}")

input_value = input("Please select a session <Index or Name>(default):")
if input_value.isdigit():
    sess_name = sessions[int(input_value)]
elif not input_value:
    sess_name = "default"
else:
    sess_name = input_value

if sess_name not in sessions:
    answer = input(f"New a session `{sess_name}`?(Y/N)")
    answer == "Y" and os.system(f"tmux new -s {sess_name}")  # pyright: ignore
else:
    os.system(f"tmux attach -t {sess_name}")

按上面的方式将脚本配置到 iTerm2 中,启动效果:

bash 复制代码
❯ ~/tmux_selector
Sessions:
0 - hello
1 - default
Please select a session <Index or Name>(default):

这里只是一个小 demo,tmux ls 的输入还有其他格式化变量,有兴趣可以继续扩展。代码片段 github 地址

相关推荐
土豆12501 分钟前
Tailwind CSS 精通指南:提升效率、可维护性与最佳实践
前端·css
花生了什么树lll1 分钟前
面试中被问到过的前端八股(四)
前端·面试
zqlcoding2 分钟前
使用el-table表格动态渲染表头数据之后,导致设置fixed的列渲染出现问题
前端·javascript·vue.js
健康的猪2 分钟前
golang的cgo的一点小心得
开发语言·后端·golang
斜月4 分钟前
一个服务预约系统该如何设计?
spring boot·后端
爱吃的强哥13 分钟前
vue3 使用 vite 管理多个项目,实现各子项目独立运行,独立打包
前端·javascript·vue.js
M1A113 分钟前
云原生第一步:Windows Go环境极速配置
后端·go
谈不譚网安22 分钟前
CSRF请求伪造
前端·网络安全·csrf
TT模板28 分钟前
苹果cmsV10主题 MXonePro二开优化修复开源版
前端·html5
拖孩28 分钟前
【Nova UI】十一、组件库中 Icon 组件的测试、使用与全局注册全攻略
前端·javascript·vue.js·ui·sass