7

我有一个小型应用程序,它管理多个类似于 Github/Gitorious 的 git 存储库。Github 允许内联文件编辑,我想知道是否有人对他们如何管理这个有任何想法。

我最初的想法是它会对存储库进行完整的克隆,使用您的提交来替换文件、提交和推送,但这对于像 linux 内核这样的大型存储库来说似乎是一项非常昂贵的操作。

关于更有效地向裸存储库添加和编辑文件的方法有什么想法吗?

4

1 回答 1

8

您可以使用管道命令。

获取您当前的 HEAD,从那里获取树,然后获取您的 blob。

获得 blob 后,您可以将内容放入文本框中。完成后,您只需对新 blob 进行哈希处理,创建新树、新提交和 tadaam。是“推”的。

PS:记住你在一个裸存储库中,所以检查你使用的每个命令都不需要索引也不需要工作目录。


正如这里所问的那样,这是一个分步示例。

首先我们获取当前文件内容:

> git cat-file -p HEAD:var/test/text.txt
test

我们对该内容进行了少量修改,现在有一个新内容可以推送了。为了保存该内容,我们将对其进行哈希处理:

> git hash-object -t blob -w var/test/text.txt
9764d221e6b50063b83c0268544c5d5b745ec9c5

这将保存它,并返回该对象(blob)的 sha-1,下一步是创建一个test包含我们text.txt文件的新文件夹。但首先让我们看看当前test文件夹是什么样的:

> git ls-tree HEAD:var/test
100644 blob 9daeafb9864cf43055ae93beb0afd6c7d144bfa4    text.txt

所以我们在这里要做的就是用9daeafb...新的 ( ) 替换以前的 SHA-1 ( ) 并在9764d22...此基础上生成一个新树(注意\t)。

> echo -e "100644 blob 9764d221e6b50063b83c0268544c5d5b745ec9c5\ttext.txt" | git mktree
b7788f9e8e9a24be31188167a6a0bc1de9e41d24

太好了,所以现在我们有了新文件text.txt和父文件夹test,我们现在需要var.

> git ls-tree HEAD:var
040000 tree 9bfb857f532d280ecd7704beb40a2ea4ba332f5a    test

> echo -e "040000 tree b7788f9e8e9a24be31188167a6a0bc1de9e41d24\ttest" | git mktree
536f33626a47138499fade7df6d02327f75d80be

现在我们需要var(这是我们存储库的根)的父级:

> git ls-tree HEAD
040000 tree 31a6ee5e7d14a0569721632a05234185a109d6bd    var

> echo -e "040000 tree 536f33626a47138499fade7df6d02327f75d80be\tvar" | git mktree
7db3d6bc14cce98ff89ccc285b9d17965f5ca92b

完成了,我们的树已经准备好了。唯一缺少的是实际提交:

> git commit-tree -p HEAD -m "commit message" 7db3d6bc14cce98ff89ccc285b9d17965f5ca92b
4aa2de2cf9e3e4f5470bcd1ee1e83ef6e4025eaf

但它还没有准备好,现在我们希望提交成为 HEAD,所以最后一步是:

> git update-ref HEAD 4aa2de2cf9e3e4f5470bcd1ee1e83ef6e4025eaf

现在我们完成了。


资源:

于 2011-07-27T14:42:59.753 回答