在git repo的tar / untar之后,gitk显示“本地未提交的更改,未签入索引”

时间:2018-04-23 21:42:37

标签: git tar

我有一个包含小git存储库的目录。

git status和gitk --all,不显示任何未提交的更改。

如果我使用以下命令来压缩/压缩此目录:

tar czf git-repo.tar.gz git-repo/

然后将此tar文件传输到测试目录并解压缩:

tar xzf git-repo.tar.gz

当我

cd test/git-repo/ gitk --all

gitk在所有提交的顶部显示一行(使用通常的红点):

“本地未提交的更改,未签入索引”

git status仍显示:

On branch master nothing to commit, working tree clean

使用以下方法测试差异:

diff -r git-repo/ test/git-repo/

没有差异。

如果我运行git clean,这条线就会消失。

我已经尝试git clean -i希望看到有问题的文件名,但是它完成后却没有要求交互式确认干净。此后gitk没有显示任何未提交的更改。

我正在运行:git版本2.11.0

向客户解释“为什么会有未提交的更改?”这有点复杂。实际上没有。

感谢您的任何见解...

1 个答案:

答案 0 :(得分:3)

gitk正在查看索引中的缓存信息,以确定您的工作目录是否脏。索引存储有关当前工作目录状态的信息,因此不需要分析文件。

当您运行git status时,它会将HEAD的内容与索引的内容进行比较,以显示分阶段的更改。这很简单快捷;如果文件的ID不同,则其内容必须不同。但是,确定文件是否具有未分级更改的计算成本更高。该文件必须计算其SHA1,然后与索引中的值进行比较。

为了避免这种代价高昂的计算,git会在索引中缓存有关工作目录内容的struct stat信息:

README.md
  ctime: 1516120578:638662531
  mtime: 1516120578:638662531
  dev: 16777220 ino: 1752439
  uid: 501      gid: 20
  size: 13224   flags: 0

现在,当您运行git status时,它只能stat工作目录的内容。如果任何文件具有相同的大小,inode,ctime,mtime等,则git假定文件未更改。这样,当您拥有未更改的文件时,git status可以保持高效。但是,如果任何文件具有不同的值,那么它将散列该文件。如果文件具有相同的哈希(即,您只是在文件上运行touch而不更改内容),则将使用新的缓存信息更新索引。如果您实际更改了文件,则git status将报告未分期更改。

然而,

gitk并不打算对文件进行散列以确定它是否已真正更改。你可以通过一个简单的例子来看到这一点。在这里,我有一个包含一个文件foo的存储库,没有任何更改。

enter image description here

如果在命令行上触摸该文件,则更新其时间戳:

% touch foo

现在,gitk报告我的存储库有未提交的更改:

enter image description here

但是,如果我在命令行上再次运行git status,它将更新索引中的缓存信息,现在gitk将了解确实不是<\ n < / em>任何未分级的更改:

enter image description here

当您解压缩存储库时 - 使用工作目录 - 您将磁盘放在一个工作目录中,该目录与索引中的缓存信息不匹配。 git实际上会重新整理内容,以确定您的工作目录实际上并不脏,但gitk没有。

复制git存储库和工作目录通常是个好主意;一般来说,你应该检查一个新的工作目录。