我有 a
) 一个没有 .git
目录的工作目录和 b
) 一个存储库。 a
是 b
历史中间的一些修改。
我如何找出 a
与 b
匹配的版本?
我想到了一个 shellscript 从工作目录到所有修订执行 diff
并选择差异最小(希望为 0)的那个。
这会有点原始(而且我不确定该怎么做),有没有更简单的方法?
最佳答案
你可以写一个脚本来运行diff gitdir workdir | wc -c
每次提交。然后你可以整理结果并说出差异最小的提交(由 wc -c
衡量)是最接近裸工作目录的提交。
这是它在 Python 中的样子:
find_closest_sha1.py:
#!/usr/bin/env python
import subprocess
import shlex
import sys
import os
import operator
gitdir,workdir=map(os.path.realpath,sys.argv[1:3])
os.chdir(gitdir)
proc=subprocess.Popen(shlex.split('git rev-list --all'),stdout=subprocess.PIPE)
shas,err=proc.communicate()
shas=shas.split()
head=shas[0]
data={}
for sha1 in shas:
subprocess.Popen(shlex.split('git checkout {s}'.format(s=sha1)),
stderr=open('/dev/null')).wait()
proc=subprocess.Popen(shlex.split('diff {g} {w}'.format(g=gitdir,w=workdir)),
stdout=subprocess.PIPE)
out,err=proc.communicate()
distance=len(out)
data[sha1]=distance
answer=min(data.items(),key=operator.itemgetter(1))[0]
print('closest match: {s}'.format(s=answer))
subprocess.Popen(shlex.split('git checkout {h}'.format(h=head)),
stderr=open('/dev/null')).wait()
示例:
% rsync -a gitdir/ workdir/
% cd workdir
% git checkout HEAD~10
HEAD is now at b9fcebf... fix foo
% cd ..
% /bin/rm -rf workdir/.git
% find_closest_sha1.py gitdir workdir
closest match: b9fcebfb170785c19390ebb4a9076d11350ade79
关于git - 查找缺少 .git 目录的工作目录的 Git 修订版,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7779369/