git - 查找缺少 .git 目录的工作目录的 Git 修订版

标签 git find revision working-directory

我有 a) 一个没有 .git 目录的工作目录和 b) 一个存储库。 ab 历史中间的一些修改。

我如何找出 ab 匹配的版本?

我想到了一个 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/

相关文章:

git - git 别名中的 `find -exec`

ruby-on-rails - 如何让 Rails 中的 named_scope 返回一个值而不是数组?

linux - shell中 `find . -name`和 `find -name`的区别?

backup - 自动文件版本控制(例如Dropbox)

version-control - Monotone - 只拉取存储库的最新版本

git - 如何使用ssh从当前分支中 pull

git - 如何永久链接到 GitHub 中的行号?

git - 你能按提交时间戳来订购 git log 吗?

eclipse - Eclipse 中不修改大小写进行替换

windows - 当其中一个文件有错误时,如何获取特定 Mercurial 修订版的内容?