当前位置: 首页 > news >正文

Zsh Alias Preview 预览 zsh 中的命令缩写

原文链接https://www.castamerego.com/blog/zshAliasPreview

alias 用多了之后就有一个问题:敲gco的时候记得它是git checkout,但gcb是什么来着?dcu又是什么?通常的做法是which gcb看一眼再回来重敲一遍,挺打断思路的。笔者写了个 Zsh 插件,在敲命令的时候直接把 alias 展开后的内容显示在 message area,免去这一步

缘起

笔者~/.zshrc里 alias 越攒越多 —— eza 的几个变体、git 的若干缩写、docker compose 一坨。短 alias 敲起来是省事,但回头看历史记录或者教别人用的时候,经常要which xxx一下才想起来到底展开成什么

之前也想过把which绑个快捷键,但本质上还是要打断输入流。笔者想要的是 IDE 里那种 inline hint —— 边敲边看,眼角余光扫一眼就够了。Zsh 的 message area(提示符下面那一行)正好闲着,于是就有了这个插件

功能

主要功能有:

  • 实时预览 alias 展开后的命令,显示在 message area
  • 可以配置只对感兴趣的命令展示,避免被ll之类的低价值预览刷屏
  • 长命令自动截断,不会撑爆下面那一行
  • 仅在内容变化时重绘,避免输入过程中的闪烁

安装

如果还没装过 Zsh 和 Oh My Zsh,可以先看 配置 Linux 终端 (zsh) 把基础环境搭好

目前是 Oh My Zsh manual install。先把仓库 clone 到 custom plugins 目录:

git clone https://github.com/Casta-mere/zsh-alias-preview \ ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-alias-preview

然后在~/.zshrcplugins=(...)里加上zsh-alias-preview,最后 source 一下:

source ~/.zshrc

配置

默认只对gitdocker这两个命令的 alias 显示预览 —— 笔者的高频场景就这俩,其他的不太常需要看展开。想加别的命令,在~/.zshrc里做如下修改即可:

~/.zshrc

typeset -ga ALIAS_PREVIEW_COMMANDS=(git docker ls kubectl)

规则很简单:alias 展开后第一个 token 在数组里就显示预览,不在就什么都不做。例如gco='git checkout'会显示,ll='ls -alF'默认不会,加ls进去之后就会

实现思路

整个插件没有引入任何依赖,全靠 Zsh 自身的 ZLE (Zsh Line Editor) 机制。核心就三件事

挂钩重绘事件。Zsh 提供了add-zle-hook-widget,可以在 ZLE 的几个生命周期点(line-init/line-pre-redraw/line-finish等)注入自己的 widget。这里挂在line-pre-redraw上 —— 每次行内容变化、重绘前都会触发:

add-zle-hook-widget line-pre-redraw _preview_alias_message

解析当前命令行的第一个 token。ZLE 把当前输入暴露在$BUFFER变量里。去掉前导空格、取第一个空格之前的部分,就是用户正在敲的命令。然后用${aliases[$first_word]}查 Zsh 内置的aliases关联数组(所有 alias 都在这里),有就拿到展开字符串:

local trimmed="${BUFFER#"${BUFFER%%[! ]*}"}" local first_word="${trimmed%% *}" local expanded="${aliases[$first_word]}"

写到 message area。zle -M <text>就是往提示符下面那行写消息的标准 API,输入下一个字符就会自然刷新。再配一个_alias_preview_last缓存,避免内容没变时的重复重绘 —— 这就是「不闪烁」的全部秘密:

zle -M " ↳ 💡: ${expanded}"

剩下两个细节:

  • 过滤命令${ALIAS_PREVIEW_COMMANDS[(Ie)$exp_cmd]}——(Ie)是 Zsh 数组的精确匹配下标语法,返回索引,存在则非零
  • 避开补全菜单通过判断$LASTWIDGET是否包含complete等关键字,否则会和_complete冲突,把补全列表覆盖掉

后记

插件还很新,已知有几个地方没处理好,记录一下:

  • 嵌套 alias 不展开。如果gco='git checkout'gcm='gco main',敲gcm时只会看到gco main这一层,不会再继续把gco展开成git checkout
  • function 形式的 alias 看不到。Zsh 里很多人会用function name() { ... }替代 alias,这种东西不在${aliases[]}里,本插件不处理
  • 全局 alias(alias -g)没考虑。全局 alias 可以出现在命令的任意位置,按「第一个 token」匹配的策略会漏掉
  • 截断长度暂时写死 80。之后想抽成可配置项

笔者自己用够了,先这样。有边界情况欢迎开 issue 或者 PR
Github zsh-alias-previewhttps://github.com/Casta-mere/zsh-alias-preview

http://www.jsqmd.com/news/675011/

相关文章:

  • 郭老师-人脉的本质:你强,世界才温柔
  • 2026年比较好的常州除虫/常州捕鼠/常州除四害/常州杀虫本地公司推荐 - 品牌宣传支持者
  • 智能问数上生产难?5层架构实战解决卡点,中小团队也能快速搭建!
  • nli-MiniLM2-L6-H768代码实例:curl/API/Python SDK三种调用方式完整示例
  • vue2+element ui的必填、禁用的背景色
  • 第8天 合并两个有序数组
  • Gemma-3-12b-it多卡GPU利用率优化教程:显存扩展段与通信冲突规避
  • 2026年大学生学术论文AI写作工具排行榜(论文指导老师专属版)
  • Python系列AI系列(仅供参考):PyCharm+Ollama+DeepSeek-Coder+CodeGPT构建本地大模型编程工具
  • 2026年知名的一次性印花抹布/环保可降解印花抹布厂家推荐与选型指南 - 品牌宣传支持者
  • Real-Anime-Z应用场景:短视频平台动漫滤镜底层模型技术解析
  • 1998-2026年EarthScope波形数据集
  • GLM-4.1V-9B-Base与Claude对比分析:多模态理解与代码生成能力评测
  • 04-12-02 技术小组长 - 学习笔记
  • 图片旋转判断在增强现实中的关键作用
  • VOOHU:组合电感在多相DC-DC变换器中的选型与应用解析
  • 2026年知名的家居除尘印花抹布/宁波印花抹布批量采购厂家推荐 - 行业平台推荐
  • AI+3D赋能文科教学:15个可直接使用的高质量可视化Prompt(历史/地理/文化)
  • AI修图师行业落地:教育领域课件插图智能编辑实践
  • quot;健身会员管理系统:一键注册预约全攻略quot;
  • Phi-3-mini-128k-instruct部署指南:vLLM引擎配置参数详解(tensor-parallel等)
  • 04-12-03 管理员工 - 学习笔记
  • 为什么要学习AI大模型?掌握AI大模型:抢占未来职场制高点,成为高薪抢手人才!
  • 鸿蒙6设备数破5500万!今日正式发布鸿蒙6.1,40+系列机型可体验
  • Python的__getattribute__方法性能瓶颈与属性访问缓存优化在热点路径
  • CSS如何实现响应式图片懒加载动画_结合CSS关键帧与占位符技术
  • 企业级开源治理的进阶选择:深度解析Gitee CodePecker SCA的核心优势
  • 华为坤灵,如何解闽商智能化之需? - 科技行者
  • 集成测试多步骤 Agent 工作流
  • egergergeeert惊艳效果:12张干净背景+高细节插画的生成效果合集