git - git repo 的 tar/untar 之后,gitk 显示 "Local uncommitted changes, not checked in to index"

标签 git tar

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

git status 和 gitk --all,显示没有未提交的更改。

如果我用 tar/compress 这个目录:

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

然后将此 tar 文件传输到测试目录并使用以下命令解压缩:

tar xzf git-repo.tar.gz

当我

cd 测试/git-repo/ gitk --all

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

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

git 状态仍然显示:

在分支 master 上 没有什么可提交的,工作树干净

测试差异:

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

没有差异。

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

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

我正在运行:git 版本 2.11.0

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

感谢您的任何见解...

最佳答案

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就会明白,确实有不是任何未暂存的更改:

enter image description here

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

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

关于git - git repo 的 tar/untar 之后,gitk 显示 "Local uncommitted changes, not checked in to index",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49990403/

相关文章:

windows - MSysGit 与 Git for Windows

java - 如何使用 Apache Commons 解压 TAR 文件

Rstudio 找不到开发工具

security - 防止提取有害的 gzip 文件

ios - unzOpen 在 iphone 中解压缩 tz 文件时返回 null

linux - 我如何压缩 proc 文件系统?

c - 了解头 tar 的变量 char size[]

git - 检查两个分支中的哪个文件有较晚的提交

java - 使用 JGit 获取一系列修订的日志

linux - Windows 上区分大小写的问题