mac电脑.sh文件,用来清除git当前分支

powershell 复制代码
#!/bin/bash

echo "正在检查Git仓库..."
if ! git rev-parse --is-inside-work-tree >/dev/null 2>&1; then
    echo "错误:当前目录不是Git仓库!"
    exit 1
fi

echo "警告:这将丢弃所有未提交的更改和本地提交!"
read -p "Are you sure to continue? (Y/N): " confirm

if [[ "$confirm" != "Y" && "$confirm" != "y" ]]; then
    echo "Operation cancelled."
    exit 0
fi

echo "正在强制同步当前分支到远程状态..."
git reset --hard HEAD || {
    echo "错误:重置分支失败!"
    exit 1
}

git clean -fd || {#!/bin/bash

echo "正在检查Git仓库..."
if ! git rev-parse --is-inside-work-tree >/dev/null 2>&1; then
    echo "错误:当前目录不是Git仓库!"
    exit 1
fi

# 获取当前分支名
current_branch=$(git symbolic-ref --short HEAD 2>/dev/null)
if [ -z "$current_branch" ]; then
    echo "错误:无法确定当前分支!"
    exit 1
fi

echo "警告:这将丢弃所有未提交的更改和本地提交!"
echo "当前分支: $current_branch"
read -p "Are you sure to continue? (Y/N): " confirm

if [[ "$confirm" != "Y" && "$confirm" != "y" ]]; then
    echo "操作已取消。"
    exit 0
fi

# 首先获取远程最新状态
echo "正在获取远程最新状态..."
if ! git fetch origin "$current_branch"; then
    echo "错误:获取远程分支失败!"
    exit 1
fi

# 重置到远程分支状态
echo "正在强制重置分支到远程状态..."
if ! git reset --hard "origin/$current_branch"; then
    echo "错误:重置分支失败!"
    exit 1
fi

# 清理未跟踪文件
echo "正在清理未跟踪文件..."
git clean -fd || {
    echo "警告:清理未跟踪文件时遇到问题,但继续操作"
}

# 再次拉取确保同步
if ! git pull; then
    echo "警告:git pull 执行失败,但同步操作已完成"
fi

echo "同步完成!当前状态:"
git status
read -p "按回车键继续..."
    echo "错误:清除未跟踪文件失败!"
    exit 1
}

if ! git pull; then
    echo "警告:git pull 执行失败,但同步操作已完成"
fi

git status
echo "提示:nothing to commit, working tree clean后,完成!"
read -p "按回车键继续..."

使用说明:

1、将脚本保存为 reset_git.sh

2、打开终端,赋予执行权限:chmod +x reset_git.sh

3、在 Git 仓库文件加打开终端,在中运行:./reset_git.sh

相关推荐
Sunshine~L&H6 小时前
Mac 上使用 mysql -u root -p 命令,出现“zsh: command not found: mysql“?如何解决
数据库·mysql·macos
Mr.stupidCoder6 小时前
Git将本地文件推送到GitHub仓库
git·elasticsearch·github
a4576368768 小时前
Objective-c protocol 练习
开发语言·macos·objective-c
BAGAE9 小时前
Flutter 与原生技术(Objective-C/Swift,java)的关系
java·开发语言·macos·objective-c·cocoa·智慧城市·hbase
Elastic 中国社区官方博客11 小时前
JavaScript 中的 ES|QL:利用 Apache Arrow 工具
大数据·开发语言·javascript·elasticsearch·搜索引擎·全文检索·apache
热血的柯基破防了13 小时前
Git命令与代码仓库管理
git·gitee
C++ 老炮儿的技术栈14 小时前
visual studio 2022更改主题为深色
c语言·开发语言·c++·ide·windows·git·visual studio
南棱笑笑生14 小时前
20250614在Ubuntu20.04.6下分步骤编译Rockchip的RK3576原厂SDK
java·开发语言·git
Jooolin16 小时前
Git 与 GitHub 的最佳协作范式:从 Fork 到 Pull Request,打开开源贡献之门
git·github·ai编程