个人项目,不需要协作,所以才敢这么折腾。 今天翻 git log ,发现历史里一堆 "update"、"fix"、"改一下" 这种毫无信息量的 commit message ,看着就难受。于是让 AI 把所有这类"废话 message"挑出来,结合实际 diff 分析改动内容,重新生成了有意义的描述。担心它改错,顺手让它写了个批处理 bash 脚本:
bash#!/usr/bin/env bash
set -euo pipefail
# 用法:./rewrite.sh [分支名] [--yes] [--dry-run]
# 旧 commit hash -> 新 message
declare -A MESSAGES=(
["69298b6141"]="chore(tasks): remove vendored tasks source"
["b3aaeff723"]="chore(claude): add local permissions config"
["032c032074"]="fix(testing): set mobile initial path"
# ... 其他映射
)
# 解析参数
TARGET="${1:-$(git branch --show-current)}"
AUTO_YES=0
DRY_RUN=0
[[ "$*" =~ --yes ]] && AUTO_YES=1
[[ "$*" =~ --dry-run ]] && DRY_RUN=1
# 预览变更
echo "目标分支: $TARGET"
for commit in "${!MESSAGES[@]}"; do
echo " $commit -> ${MESSAGES[$commit]}"
done
# dry-run 模式
if [ $DRY_RUN -eq 1 ]; then
echo "干运行模式,不实际修改"
exit 0
fi
# 二次确认
if [ $AUTO_YES -eq 0 ]; then
read -p "确认重写提交消息?[y/N] " -r
[[ ! $REPLY =~ ^[Yy] ]] && exit 0
fi
# 自动备份
BACKUP="backup-$(date +%Y%m%d-%H%M%S)"
git branch "$BACKUP" "$TARGET"
# 执行重写
git filter-branch -f --msg-filter '
case "$GIT_COMMIT" in
'"$(for hash in "${!MESSAGES[@]}"; do
echo "$hash) echo \"${MESSAGES[$hash]}\" ;;"
done)"'
*) cat ;;
esac
' -- "$TARGET"
echo "完成!备份分支: $BACKUP"
echo "如需恢复: git reset --hard $BACKUP"跑完脚本,看着 git log 整整齐齐,莫名被治愈了。
1
sddyzm PRO AI 马上要迎来奇点
|
2
fds 12 小时 48 分钟前
git 的话直接在新分支改呗,改好 reset 过去就行。
目前写 tests 这种脏活累活都交给 AI 了,非常爽。 |
3
lel020 11 小时 15 分钟前
确实 git 写的 commit log 比较赏心悦目,尤其对于英文不好又强迫自己使用英文的,哪怕纯 AI 不审核都比自己手写无意义 log 强得多,
|
4
lulaolu 11 小时 0 分钟前
个人项目的 commit message 可以让自己看一眼就知道改动内容,要的是熟悉; AI 写的虽然精致,但很陌生。当然无论如何都比完全无意义的 message 要强。
自己写的简单 message > AI 写的精致 message > 完全无意义的 message 。 |
5
dotfun 6 小时 37 分钟前
这都是你提交的偷的懒,本应该自己按照规范提交
|