- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
vscode插件git-graph可以方便查看git-commit-graph,效果很好,关键是交互性很好。 点选任意commit即可预览提交内容,实在是太方便了,比我之前用命令行上git log --graph --oneline强太多了。 但同时带来的困扰是能看到的信息(commit历史)太多了,让我眼花缭绕。 例如,为了修复一个issue,前后进行了10次git commit --amend。也就是一共11次提及历史记录。 git graph大概长这样 。
。
实际上当我合并这次的修改之后,我只想保留最后一次的记录在reflog里,其他的10次提交历史都不要了。这就涉及到了git reflog修剪了.
首先,git 是通过HEAD找commit hash ID,然后每个commit都有parent commit,如此组成一条链式结构。 commit是描绘git-graph的主要依据,其实只要删掉一个commit就能改变git-graph的结果。 每一次提交都会在.git/objects目录下生成至少一个commit类型的文件,其完整的文件路径为.git/objects/12/34567xx... (这里假设这个commit hash id 是1234567xx...) git cat-file -t可以查看.git/objects目录下的文件是tree、commit还是blob类型。 例如: 注意:不能删除当前分支上可达的commit,不然链就断了,git就无法正常工作了。前面提到的"其他的10次提交历史" 因为在当前分支已经不可达,所以可以删除 。
例如我想从git-graph删除一个hash为 1234567的commit 那么步骤为:
因为git commit hash有缩写形式、引用形式、完整形式,但是.git/objects/下的文件名都是完整形式,这种事情当然要写个脚本来一劳永逸了.
#!/bin/bash function zlipd() { printf "\x1f\x8b\x08\x00\x00\x00\x00\x00" | cat - $@ | gzip - dc 2> /dev/null } function move_intermediate_obj() { local dst_path dst_path=$1; shift while [ -n "$1" ]; do if [ -f .git /objects/ "${1:0:2}" / "${1:2}" ]; then mv - v .git /objects/ "${1:0:2}" / "${1:2}" "$dst_path/$1" fi shift done } # function migrate_intermediate_obj() { # [ ! -d ./.git ] && { echo ".git dir not exist"; return; } # [ ! -d ./intermediate_obj ] && mkdir -p intermediate_obj # for f in $(git rev-list -n "${2:-1}" "${1:?params not enough}") # do # # echo "$f" # move_intermediate_obj "$f" # done # } migrate_intermediate_obj () { [ ! -d ./.git ] && { echo ".git dir not exist" ; return }; local dst_dir [ -d . /output ] && dst_dir=. /output/intermediate_obj ; [ -z $dst_dir ] && dst_dir=. /intermediate_obj ; mkdir -p $dst_dir if [ $ # -eq 1 ] then move_intermediate_obj $dst_dir "$1" ; elif expr $2 + 0 > /dev/null 2>&1 # test $2 whether is number otherwise $? neq 0/1 if $2 non-integer argument then for f in $(git rev-list -n "${2:-1}" "${1:?params not enough}" ); do move_intermediate_obj $dst_dir "$f" ; done else move_intermediate_obj $dst_dir "$@" ; fi }
脚本使用方法: source script.sh migrate_intermediate_obj 1234567 。
脚本将会在当前目录下创建一个文件intermediate_obj,并将commit文件移动进去。 PS: 在git gc的时候有些commit会被打包到.git/objects/pack文件夹下的pack后缀的文件里,这样的话在.git/objects/下就找不到这些commit文件了。 解决办法是使用git unpack-objects < .git/*.pack文件解压出来。(pack文件和index文件要事先从.git/objects/pack移出去该命令才会有效果) PS2: git verify-pack -v .git/objects/pack/pack-xx.pack可以查看哪个pack文件包含你要的commit 。
最后此篇关于如何修剪gitreflog历史的文章就讲到这里了,如果你想了解更多关于如何修剪gitreflog历史的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我是一名优秀的程序员,十分优秀!