云网站功能,网页游戏大全免费,淄博做网站哪家好,网站建设要素可以将当前未提交的代码自动执行
git addgit commitgit squash
Git 命令安装指南
1. 创建脚本目录
如果目录不存在#xff0c;创建它#xff1a;
mkdir -p ~/.local/bin2. 创建脚本文件
vim ~/.local/bin/git-squash将完整的脚本代码复制到此文件中。
3. 设置脚本权限…可以将当前未提交的代码自动执行
git addgit commitgit squash
Git 命令安装指南
1. 创建脚本目录
如果目录不存在创建它
mkdir -p ~/.local/bin2. 创建脚本文件
vim ~/.local/bin/git-squash将完整的脚本代码复制到此文件中。
3. 设置脚本权限
chmod x ~/.local/bin/git-squash4. 配置 PATH
编辑 shell 配置文件根据你使用的 shell 选择
# 对于 bash
echo export PATH$HOME/.local/bin:$PATH ~/.bashrc# 或对于 zsh
echo export PATH$HOME/.local/bin:$PATH ~/.zshrc重新加载配置
source ~/.bashrc # 或 source ~/.zshrc5. 创建 Git 别名
git config --global alias.allen-squash !git-squash6. 验证安装
检查脚本是否可执行
ls -l ~/.local/bin/git-squash检查脚本是否在 PATH 中
which git-squash检查 git 别名是否设置成功
git config --get-regexp alias.*squash7. 使用方法
可以通过以下两种方式使用
# 直接使用脚本
git-squash# 或使用 git 别名
git allen-squash8. 常见问题排查
命令未找到
检查 PATH
echo $PATH | grep -o ~/.local/bin检查脚本权限
ls -l ~/.local/bin/git-squash检查 git 别名
git config --list | grep allen-squash管理别名
# 删除别名
git config --global --unset alias.allen-squash# 修改别名
git config --global alias.allen-squash !git-squash编辑脚本
vim ~/.local/bin/git-squash9. 备份建议
建议进行以下备份
# 备份脚本
cp ~/.local/bin/git-squash ~/.local/bin/git-squash.backup# 备份 git 配置
cp ~/.gitconfig ~/.gitconfig.backup10. 更新脚本
如需更新脚本
# 编辑脚本
vim ~/.local/bin/git-squash# 确保权限正确
chmod x ~/.local/bin/git-squash注意事项
确保 ~/.local/bin 目录存在并在 PATH 中确保脚本具有可执行权限重启终端或重新加载配置文件后更改才会生效建议在使用前先进行配置备份如果遇到权限问题检查用户权限和文件权限
故障排除
如果命令不能正常工作请按以下步骤检查 确认脚本位置 检查 ~/.local/bin/git-squash 是否存在确认文件权限是否正确 检查 PATH 设置 确认 ~/.local/bin 在 PATH 中检查 shell 配置文件是否正确加载 验证 git 别名 检查别名是否正确设置确认 git 配置文件是否正确
脚本内容
#!/bin/bash# 颜色定义
RED\033[0;31m
GREEN\033[0;32m
YELLOW\033[1;33m
NC\033[0m # No Color# 全局变量
COMMITS_TO_SQUASH0# 错误处理函数
handle_error() {echo -e ${RED}Error: $1${NC}exit 1
}# 获取与main分支的距离和可压缩提交数量
get_commit_info() {# 获取当前分支名current_branch$(git branch --show-current)# 获取当前分支的总提交数total_commits$(git rev-list HEAD --count)# 尝试获取与main分支的距离if git rev-parse --verify main /dev/null 21; thencommits_from_main$(git rev-list --count main..HEAD)echo -e \n${YELLOW}Commit information:${NC}echo -e Current branch: ${GREEN}$current_branch${NC}echo -e Total commits in current branch: ${GREEN}$total_commits${NC}echo -e Commits ahead of main: ${GREEN}$commits_from_main${NC}echo -e Maximum commits that can be squashed: ${GREEN}$commits_from_main${NC}elseecho -e \n${YELLOW}Commit information:${NC}echo -e Current branch: ${GREEN}$current_branch${NC}echo -e Total commits in current branch: ${GREEN}$total_commits${NC}echo -e Main branch not found - cannot calculate distance from mainecho -e Maximum commits that can be squashed: ${GREEN}$total_commits${NC}fi
}# 显示最近的提交历史并获取压缩数量
show_recent_commits() {echo -e \n${YELLOW}Recent commits:${NC}git --no-pager log --oneline -n 5# 计算与main分支的距离commits_ahead$(git rev-list --count main..HEAD)echo -e \n${YELLOW}Valid squash range:${NC}echo -e Minimum commits: ${GREEN}2${NC}echo -e Maximum commits: ${GREEN}$commits_ahead${NC} (number of commits ahead of main)while true; doecho -e \n${YELLOW}How many commits do you want to squash? (${GREEN}2${NC} to ${GREEN}$commits_ahead${NC})${NC}read -r commits_count# 验证输入是否在有效范围内if [[ $commits_count ~ ^[0-9]$ ]] [ $commits_count -ge 2 ] [ $commits_count -le $commits_ahead ]; thenCOMMITS_TO_SQUASH$commits_countbreakelseecho -e ${RED}Please provide a number between 2 and $commits_ahead${NC}fidone
}# 创建备份分支
create_backup() {current_branch$(git branch --show-current)backup_branch${current_branch}_backup_$(date %Y%m%d_%H%M%S)git branch $backup_branch || handle_error Failed to create backup branchecho -e ${GREEN}Created backup branch: $backup_branch${NC}
}# 执行squash操作
do_squash() {local commits_count$1echo -e \n${YELLOW}Will squash last $commits_count commits:${NC}git --no-pager log --oneline -n $commits_countecho -e \n${YELLOW}Do you want to continue? (y/n)${NC}read -r responseif [[ ! $response ~ ^[Yy]$ ]]; thenecho Operation cancelledexit 0fi# 创建备份create_backup# 执行交互式rebaseecho -e \n${YELLOW}Starting interactive rebase...${NC}echo -e ${YELLOW}In the editor:${NC}echo -e 1. Leave the first pick as isecho -e 2. Change pick to s or squash for all other commitsecho -e 3. Save and close the editorecho -e 4. In the next editor, write your combined commit messageif ! git rebase -i HEAD~$commits_count; thenecho -e ${RED}Rebase failed. Restoring from backup...${NC}git rebase --aborthandle_error Rebase failedfi
}# 推送更改
push_changes() {echo -e \n${YELLOW}Do you want to push changes to remote? (y/n)${NC}read -r responseif [[ $response ~ ^[Yy]$ ]]; thencurrent_branch$(git branch --show-current)echo -e ${YELLOW}Using force push with lease for safety...${NC}if git push origin $current_branch --force-with-lease; thenecho -e ${GREEN}Successfully pushed changes${NC}elsehandle_error Push failedfifi
}# 主函数
main() {# 检查是否在git仓库中git rev-parse --git-dir /dev/null 21 || handle_error Not in a git repository# 检查是否有改动需要提交if git diff-index --quiet HEAD -- [ -z $(git ls-files --others --exclude-standard) ]; thenecho -e \n${YELLOW}No changes to stage or commit, skipping...${NC}else# 添加新的暂存和提交步骤echo -e \n${YELLOW}Staging all changes...${NC}git add . || handle_error Failed to stage changesecho -e ${GREEN}Successfully staged all changes${NC}echo -e \n${YELLOW}Creating stage commit...${NC}git commit -m stage commit || handle_error Failed to create commitecho -e ${GREEN}Successfully created stage commit${NC}fi# 显示提交信息get_commit_info# 显示当前提交历史并获取要压缩的提交数show_recent_commits# 执行squash操作do_squash $COMMITS_TO_SQUASH# 推送更改push_changesecho -e \n${GREEN}All operations completed successfully${NC}
}# 执行主函数
main