git - 将 Git 索引复制到临时文件夹中

标签 git git-checkout

假设我有一个实用程序some-check {baseline_folder} {working_folder},它对文件集(而不是单个文件)进行一些比较。

我想在两个略有不同的用例中使用此实用程序:

  • 根据 HEAD 修订版验证工作树;
  • 索引与 HEAD 的预提交验证

第一个用例非常简单,因为将基线(即 HEAD)放入临时文件夹并不是什么大问题。

真正的问题是如何将索引放入某个文件夹中。我看到的唯一方法是:

  1. 创建一个存储库

  2. 立即应用回来

  3. 使用 git-archive 通过存储引用创建 zip

  4. 将其解压缩到临时文件夹

  5. 放下储藏室

有没有更简洁的方法来做到这一点?

UPD:长话短说:问题是如何获取具有 HEAD+stage 的文件夹,但没有修改/未跟踪。

最佳答案

为了验证索引中的内容,您可以通过以下方式将索引中的所有内容提取到临时工作树中:

tmpdir=$(mktemp -d)                # or your other chosen method
trap "rm -rf $tmpdir" 0 1 2 3 15   # do something different in other languages

GIT_WORK_TREE=$tmpdir git checkout-index --all

确保临时目录存在且为空(此处的 mktemp -d 执行此操作),并确保完成后进行清理(此处的 trap 执行此操作)那个)。

请注意,属性规则将应用于 git checkout-index 步骤。使用 git archive,您可以通过 export-ignoreexport-subst 获得更多控制。如果您想使用该方法,可以使用 git write-tree 将当前索引转换为树对象,然后对该树对象使用 git archive 。 p>

另请注意,git write-tree 方法会引发未 merge 索引的错误,而 git checkout-index 方法只是从目标工作中忽略未 merge 的文件-树。

关于git - 将 Git 索引复制到临时文件夹中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52213050/

相关文章:

Git - 如何验证 Git 是否安装在 Ubuntu 上以及安装在何处

git - 从两个不同的代码库生成 Git 存储库

git - "svn update -r"的 git 等价物是什么?

git - checkout 到名称中包含 '&' 的分支

Git checkout - 切换回 HEAD

android - 从git中删除构建文件夹

linux - 尽管文件在那里,但 Git 无法在远程找到文件

svn - HEAD 和 SVN Master 之间的 Git 差异

通过 telnet 进行 git

ios - GIT:如何从工作目录中 check out 所有文件?