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

相关推荐
切糕师学AI5 分钟前
前后端分离架构中,Node.js的底层实现原理与线程池饥饿问题解析
前端·vue.js·node.js
妄小闲24 分钟前
网页设计模板 HTML源码网站模板下载
前端·html
icebreaker40 分钟前
tailwindcss 究竟比 unocss 快多少?
前端·css·github
卢叁1 小时前
Flutter之自定义TabIndicator
前端·flutter
每天吃饭的羊1 小时前
state和ref
前端·javascript·react.js
GEO_YScsn1 小时前
Vite:Next-Gen Frontend Tooling 的高效之道——从原理到实践的性能革命
前端·javascript·css·tensorflow
GISer_Jing1 小时前
滴滴二面(准备二)
前端·javascript·vue·reactjs
ningmengjing_1 小时前
webpack打包方式
前端·爬虫·webpack·node.js·逆向
Yuner20001 小时前
Webpack开发:从入门到精通
前端·webpack·node.js
GISer_Jing1 小时前
滴滴二面准备(一)
前端·javascript·面试·ecmascript