mac电脑.sh文件,用来清除git当前分支
#!/bin/bashecho "正在检查Git仓库..."
if ! git rev-parse --is-inside-work-tree >/dev/null 2>&1; thenecho "错误:当前目录不是Git仓库!"exit 1
fiecho "警告:这将丢弃所有未提交的更改和本地提交!"
read -p "Are you sure to continue? (Y/N): " confirmif [[ "$confirm" != "Y" && "$confirm" != "y" ]]; thenecho "Operation cancelled."exit 0
fiecho "正在强制同步当前分支到远程状态..."
git reset --hard HEAD || {echo "错误:重置分支失败!"exit 1
}git clean -fd || {#!/bin/bashecho "正在检查Git仓库..."
if ! git rev-parse --is-inside-work-tree >/dev/null 2>&1; thenecho "错误:当前目录不是Git仓库!"exit 1
fi# 获取当前分支名
current_branch=$(git symbolic-ref --short HEAD 2>/dev/null)
if [ -z "$current_branch" ]; thenecho "错误:无法确定当前分支!"exit 1
fiecho "警告:这将丢弃所有未提交的更改和本地提交!"
echo "当前分支: $current_branch"
read -p "Are you sure to continue? (Y/N): " confirmif [[ "$confirm" != "Y" && "$confirm" != "y" ]]; thenecho "操作已取消。"exit 0
fi# 首先获取远程最新状态
echo "正在获取远程最新状态..."
if ! git fetch origin "$current_branch"; thenecho "错误:获取远程分支失败!"exit 1
fi# 重置到远程分支状态
echo "正在强制重置分支到远程状态..."
if ! git reset --hard "origin/$current_branch"; thenecho "错误:重置分支失败!"exit 1
fi# 清理未跟踪文件
echo "正在清理未跟踪文件..."
git clean -fd || {echo "警告:清理未跟踪文件时遇到问题,但继续操作"
}# 再次拉取确保同步
if ! git pull; thenecho "警告:git pull 执行失败,但同步操作已完成"
fiecho "同步完成!当前状态:"
git status
read -p "按回车键继续..."echo "错误:清除未跟踪文件失败!"exit 1
}if ! git pull; thenecho "警告:git pull 执行失败,但同步操作已完成"
figit 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