Project Icon

tmux-fingers

tmux插件实现快速文本复制和跳转的终端效率工具

tmux-fingers插件为tmux用户提供了便捷的文本复制和跳转功能。它能自动识别并高亮显示文件路径、IP地址等关键信息,用户通过简单的按键操作即可快速复制。插件支持自定义匹配模式和多项选择,适合需要在终端中频繁处理文本的开发者使用。

tmux-fingers

演示

使用方法

按下(前缀键 + F)进入**[fingers]**模式,它会在当前窗格中高亮显示相关内容并附带字母提示。通过按下这些字母,高亮的匹配项将被复制到剪贴板。更少的按键操作 == 更高效!

以下是默认高亮显示的内容列表:

  • 文件路径
  • SHA 值
  • 数字(4位及以上)
  • 十六进制数
  • IP 地址
  • Kubernetes 资源
  • UUID
  • git 状态/差异输出

查看内置模式列表

快捷键

在**[fingers]**模式下,你可以使用以下快捷键:

  • a-z:将选中的匹配项复制到剪贴板
  • CTRL + a-z:将选中的匹配项复制到剪贴板并触发@fingers-ctrl-action。默认触发:open:操作,例如用于在浏览器中打开链接。
  • SHIFT + a-z:将选中的匹配项复制到剪贴板并触发@fingers-shift-action。默认触发:paste:操作,自动粘贴选中的匹配项。
  • ALT + a-z:将选中的匹配项复制到剪贴板并触发@fingers-alt-action。默认无操作,可由用户配置。
  • TAB:切换多选模式。第一次按下进入多选模式,允许选择多个匹配项。第二次按下将退出并将选中的匹配项复制到剪贴板。
  • qESCCTRL + c:退出**[fingers]**模式

要求

  • tmux 3.0 或更高版本

安装

使用 Tmux 插件管理器

.tmux.conf 中的 TPM 插件列表中添加以下内容:

set -g @plugin 'Morantron/tmux-fingers'

按下 前缀键 + I 获取并加载插件。首次运行时,会出现一个向导来完成安装。

手动安装

克隆仓库:

$ git clone https://github.com/Morantron/tmux-fingers ~/.tmux/plugins/tmux-fingers

.tmux.conf 中引用它:

run-shell ~/.tmux/plugins/tmux-fingers/tmux-fingers.tmux

通过运行以下命令重新加载 TMUX 配置:

$ tmux source-file ~/.tmux.conf

首次运行时,会出现一个向导来完成安装。

配置

注意:要使更改生效,你需要重新加载 .tmux.conf 文件。

配方:

@fingers-key

默认值:F

自定义进入 fingers 模式的方式。始终需要前缀键:前缀键 + @fingers-key

例如:

set -g @fingers-key F

@fingers-jump-key

默认值:J

自定义进入 fingers 跳转模式的方式。始终需要前缀键:前缀键 + @fingers-jump-key

在跳转模式下,选择提示后,光标将被放置在匹配项的位置。

@fingers-patterns-N

你还可以添加额外的模式来高亮显示更多内容:

# 你可以像这样定义自定义模式
set -g @fingers-pattern-0 'git rebase --(abort|continue)'

# 递增数字并定义更多模式
set -g @fingers-pattern-1 '其他模式'

# 你可以使用命名捕获组,如 (?<match>你的正则表达式)
# 只高亮并复制匹配的部分
set -g @fingers-pattern-2 'capture (?<match>only this)'

# 注意反斜杠!例如正则表达式 \d{50} 匹配 50 个数字。
set -g @fingers-pattern-3 '\d{50}'  # 使用单引号时无需转义
set -g @fingers-pattern-4 "\\d{50}" # 使用双引号时,需要为特殊字符转义反斜杠
set -g @fingers-pattern-5 \\d{50} # 不使用引号时也需要转义

模式使用 PCRE 模式语法

如果引入的正则表达式包含错误,在调用插件时会显示错误。

@fingers-main-action

默认值::copy:

默认情况下,tmux-fingers 会将匹配项复制到 tmux 和系统剪贴板。

如果你想设置自己的自定义命令,可以这样做:

set -g @fingers-main-action '<你的命令>'

该命令还将接收以下内容:

  • MODIFIER:环境变量,设置为 ctrlaltshift,指定选择匹配项时使用的修饰键。
  • HINT:环境变量,所选字母提示本身(例如:qas 等)。
  • stdin:复制的文本将通过管道传递给 @fingers-copy-command

你还可以使用以下特殊值:

  • :paste: 复制匹配项并自动粘贴。
  • :copy: 使用内置系统剪贴板集成复制匹配项。
  • :open: 使用内置打开文件集成打开文件(在默认浏览器中打开 URL,在操作系统文件导航器中打开文件等)。

@fingers-ctrl-action

默认值::open:

@fingers-main-action 相同,但仅在按住 ctrl 选择匹配项时调用

@fingers-alt-action

@fingers-main-action 相同,但仅在按住 alt 选择匹配项时调用

@fingers-shift-action

默认值::paste:

@fingers-main-action 相同,但仅在按住 shift 选择匹配项时调用

@fingers-hint-style

默认值:"fg=green,bold"

使用此选项可以定义字母提示的样式。

你可以使用与 .tmux.conf 中设置状态栏样式相同的语法来自定义样式。

更多信息请参阅 man tmux 中的 STYLES 部分。

支持的样式有:brightbolddimunderscoreitalics

@fingers-highlight-style

默认值:"fg=yellow"

高亮匹配项的自定义样式。更多详情请参阅 @fingers-hint-format

@fingers-backdrop-style

默认值:""

未匹配文本的自定义样式。更多详情请参阅 @fingers-hint-format

@fingers-selected-hint-style

默认值: "fg=blue,bold"

多模式下选中匹配项的提示格式。

@fingers-selected-highlight-style

默认值: "fg=blue"

多模式下选中匹配项的高亮格式。

@fingers-hint-position

默认值: "left"

控制提示渲染的位置。可能的值为 "left""right"

@fingers-keyboard-layout

默认值: "qwerty"

提示生成时会考虑最佳手指移动。你可以选择以下布局:

  • qwerty:默认值,使用所有字母
  • qwerty-left-hand:仅使用左手容易触及的字母
  • qwerty-right-hand:仅使用右手容易触及的字母
  • qwerty-homerow:仅使用主行字母
  • qwertz
  • qwertz-left-hand
  • qwertz-right-hand
  • qwertz-homerow
  • azerty
  • azerty-left-hand
  • azerty-right-hand
  • azerty-homerow
  • colemak
  • colemak-left-hand
  • colemak-right-hand
  • colemak-homerow
  • dvorak
  • dvorak-left-hand
  • dvorak-right-hand
  • dvorak-homerow

@fingers-show-copied-notification

默认值: 0

使用 tmux display-message 显示复制结果的通知消息。

@fingers-enabled-builtin-patterns

默认值: all

以逗号分隔的模式名称列表。内置模式如下:

名称描述示例
ipIPv4 地址192.168.0.1
uuidUUID 标识符f1b43afb-773c-4da2-9ae5-fef1aa6945ce
shaSHA 标识符c8b911e2c7e9a6cc57143eaa12cad57c1f0d69df
digit四位或更多位数字1337
urlURL(支持的协议:http/https/git/ssh/file)https://asdf.com
path文件路径path/to/file
hex十六进制数0x00FF
kubernetesKubernetes 标识符deployment.apps/zookeeper
git-status匹配 git status 输出中的文件路径modified: ./path/to/file
git-status-branch匹配 git status 输出中的分支名Your branch is up to date withname-of-branch
diff匹配 diff 输出中的路径+++ a/path/to/file

使用方法

无需前缀启动 tmux-fingers

你可以通过添加以下绑定来实现无需按 tmux 前缀键就能启动 tmux-fingers:

# tmux.conf

# 按 Alt+F 启动 tmux fingers
bind -n M-f run -b "#{@fingers-cli} start #{pane_id}"

# 按 Alt+J 以跳转模式启动 tmux fingers
bind -n M-j run -b "#{@fingers-cli} start #{pane_id} --mode jump"

仅使用特定模式

你可以使用特定的内置或自定义模式启动 tmux-fingers。

# 使用前缀键 + u 匹配 URL
bind -n u run -b "#{@fingers-cli} start #{pane_id} --patterns url"

# 使用前缀键 + h 匹配哈希值
bind -n h run -b "#{@fingers-cli} start #{pane_id} --patterns sha"

# 使用前缀键 + g 匹配 git 相关内容
bind -n g run -b "#{@fingers-cli} start #{pane_id} --patterns git-status,git-status-branch"

# 使用前缀键 + y 匹配自定义模式
set -g @fingers-pattern-yolo "yolo.*"
bind -n y run -b "#{@fingers-cli} start #{pane_id} --patterns yolo"

致谢和灵感

这个插件深受 tmux-copycat 的启发(tmux-fingers 预定义的搜索模式是从 tmux-copycat "复制"而来的 :trollface:)。

感谢 bruno- 为 tmux 插件开辟了道路!:clap: :clap:

许可证

MIT

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号