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 地址

相关推荐
有梦想的刺儿15 分钟前
webWorker基本用法
前端·javascript·vue.js
cy玩具36 分钟前
点击评论详情,跳到评论页面,携带对象参数写法:
前端
customer081 小时前
【开源免费】基于SpringBoot+Vue.JS周边产品销售网站(JAVA毕业设计)
java·vue.js·spring boot·后端·spring cloud·java-ee·开源
qq_390161771 小时前
防抖函数--应用场景及示例
前端·javascript
John.liu_Test2 小时前
js下载excel示例demo
前端·javascript·excel
Yaml42 小时前
智能化健身房管理:Spring Boot与Vue的创新解决方案
前端·spring boot·后端·mysql·vue·健身房管理
PleaSure乐事2 小时前
【React.js】AntDesignPro左侧菜单栏栏目名称不显示的解决方案
前端·javascript·react.js·前端框架·webstorm·antdesignpro
哟哟耶耶2 小时前
js-将JavaScript对象或值转换为JSON字符串 JSON.stringify(this.SelectDataListCourse)
前端·javascript·json