改.bashrc,直观地判断本地repo是否有改动

preface

添加到.bashrc末尾

bash 复制代码
# ==================== Git 增强提示符 ====================              yan add may18
git_prompt() {
    if ! git rev-parse --is-inside-work-tree >/dev/null 2>&1; then
        return
    fi

    local git_root
    git_root=$(git rev-parse --show-toplevel 2>/dev/null)

    # 如果 HOME 本身是 git 仓库,则不显示,避免到处都有提示
    if [ "$git_root" = "$HOME" ]; then
        return
    fi

    local branch
    branch=$(git branch --show-current 2>/dev/null)

    if [ -z "$branch" ]; then
        branch="detached"
    fi

    local ahead=0
    local behind=0

    # 如果当前分支设置了 upstream,比如 origin/main
    if git rev-parse --abbrev-ref --symbolic-full-name @{u} >/dev/null 2>&1; then
        ahead=$(git rev-list --count @{u}..HEAD 2>/dev/null || echo 0)
        behind=$(git rev-list --count HEAD..@{u} 2>/dev/null || echo 0)
    fi

    local dirty
    dirty=$(git status --porcelain 2>/dev/null | wc -l)

    local cyan=$'\001\033[1;36m\002'
    local red=$'\001\033[31m\002'
    local yellow=$'\001\033[33m\002'
    local reset=$'\001\033[0m\002'

    local info="(${cyan}${branch}${reset}"

    if [ "$dirty" -gt 0 ]; then
        info+=" ${red}⚡${reset}"
    fi

    if [ "$ahead" -gt 0 ]; then
        info+=" ${yellow}↑${ahead}${reset}"
    fi

    if [ "$behind" -gt 0 ]; then
        info+=" ${red}↓${behind}${reset}"
    fi

    info+=")"

    printf " %s" "$info"
}

PS1='\u@\h:\w$(git_prompt) \$ '

一、解释脚本

1. ahead / behind 判断本地和远程repo版本

bash 复制代码
ahead=$(git rev-list --count HEAD..origin/"$branch" 2>/dev/null || echo 0)
behind=$(git rev-list --count origin/"$branch"..HEAD 2>/dev/null || echo 0)

含义是:

bash 复制代码
HEAD..origin/branch        # 远程有、本地没有 => 本地落后 behind
origin/branch..HEAD        # 本地有、远程没有 => 本地超前 ahead

2. 颜色代码

在 Bash 里,用:

bash 复制代码
$'\033[1;36m'

或者:

bash 复制代码
$'\e[1;36m'

可以显示颜色,更直观


二、更新.bashrc

然后执行:

bash 复制代码
source ~/.bashrc

显示效果大概是

如果你在 main 分支,本地比远程多 2 个提交:

bash 复制代码
ubuntu@:~/(main ↑2) $

如果本地落后远程 3 个提交:

bash 复制代码
ubuntu@:~/(main ↓3) $

如果有未提交修改:

bash 复制代码
ubuntu@:~/(main ⚡) $

如果既有修改,又超前又落后:

bash 复制代码
ubuntu@:~/(main ⚡ ↑1 ↓2) $

额外检查一下 upstream

如果你发现一直不显示 ,可能是当前分支没有绑定远程分支。

进入项目目录后执行:

bash 复制代码
git branch -vv

如果看不到类似:

bash 复制代码
main abc1234 [origin/main] commit message

那就绑定一下:

bash 复制代码
git branch --set-upstream-to=origin/main main

或者首次推送时:

bash 复制代码
git push -u origin main

一、

相关推荐
AlfredZhao2 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
戴为沐3 天前
Linux内存扩容指南
linux
zylyehuo3 天前
Linux 彻底且安全地删除文件
linux
用户805533698034 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户034095297914 天前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux
Web3探索者6 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo6 天前
Linux系统中网线与USB网络共享冲突
linux
Sokach10157 天前
Linux Shell 脚本从零到能用:一个新手的一天学习总结
linux
AlfredZhao7 天前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone
zzzzzz3109 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql