我对Git感到厌烦,并遇到以下问题:

我的项目源树:

/
|
+--src/
+----refs/
+----...
|
+--vendor/
+----...

我在我的供应商分支中有代码(目前是MEF),我将在那里编译这些代码,然后将这些引用移到/src/refs中,这是项目获取它们的地方。

我的问题是,我的.gitignore设置为忽略*.dll和*.pdb。我可以执行gitadd-f bar.dll来强制添加被忽略的文件,这是正常的,问题是我无法找出存在哪些文件被忽略。

我想列出被忽略的文件,以确保我不会忘记添加它们。

我已经阅读了gitls文件的手册页,无法使其正常工作。在我看来,gitls文件——排除标准——我应该做我想做的事情。我错过了什么?


当前回答

你可以使用fd。

要运行的命令是:

comm -23 <(fd -HI | sort) <(fd -H | sort) 

请注意,如果没有.git目录而只有.gitignore文件(例如裸机),则必须明确指出.gitignorefile文件的位置。

comm -23 <(fd -HI | sort) <(fd -H --ignore-file .gitignore | sort)

更具体地说,使用--no ignore vcs而不是-I

有关详细信息,请查看此处。

其他回答

(扩展其他答案)

注意,git-check-ignore使用committed.gitignore,而不是工作树中的那个!为了在不影响git历史记录的情况下使用它,您可以自由地尝试编辑它,然后使用gitcommit提交--修改。

这个问题主要发生在您需要解决这个问题的方法时,即git不遵循目录。在.gitignore中输入:

dirtokeep/**
!dirtokeep/.keep

.keep应该是dirtokeep中的零长度文件。

其结果是,除了dirtokeep/.keep之外,dirtokeep中的所有内容都将被忽略,这将导致在clone/checkout时构造dirtokeep目录。

假设有几个忽略目录,为什么不使用“gitstatus node/logs/”来告诉您要添加哪些文件?在目录中,我有一个不属于状态输出的文本文件,例如:

在分支主机上您的分支机构已更新“origin/master”。未跟踪的文件:(使用“git add…”将提交的内容包括在内)

    node/logs/.gitignore 

.gitignore是:

*!.忽略

我会的

git status --porcelain --ignored

并且只列出忽略的文件

git status --porcelain --ignored | grep '^[!][!] '

你可以使用fd。

要运行的命令是:

comm -23 <(fd -HI | sort) <(fd -H | sort) 

请注意,如果没有.git目录而只有.gitignore文件(例如裸机),则必须明确指出.gitignorefile文件的位置。

comm -23 <(fd -HI | sort) <(fd -H --ignore-file .gitignore | sort)

更具体地说,使用--no ignore vcs而不是-I

有关详细信息,请查看此处。

以下是如何在工作树中打印与Git的多个gitignore源中任何位置的模式匹配的文件的完整列表(如果您使用GNU find):

$ cd {your project directory}
$ find . -path ./.git -prune -o -print \
| git check-ignore --no-index --stdin --verbose

它将检查存储库当前分支中的所有文件(除非您已在本地删除它们)。

它还标识了特定的gitignore源代码行。

Git继续跟踪一些与gitignore模式匹配的文件的更改,因为这些文件已经添加。有用的是,上面的命令也显示了这些文件。

负gitignore模式也匹配。然而,这些在列表中很容易区分,因为它们以!开头!。

如果您使用的是Windows,GitBash包含GNU find(如find--version所示)。

如果列表很长(并且您有rev),您也可以通过扩展名(多少)显示它们:

$ cd {your project directory}
$ find . -path ./.git -prune -o -print \
| git check-ignore --no-index --stdin --verbose \
| rev | sort | rev

有关详细信息,请参见man find、man git check ignore、man rev和man sort。

整个方法的要点是Git(软件)正在快速变化,而且非常复杂。相比之下,GNU的发现是极其稳定的(至少在这里使用的特性方面)。因此,任何希望通过展示自己对Git的深入了解来提高竞争力的人都会以不同的方式回答这个问题。

最好的答案是什么?这个答案有意减少对Git知识的依赖,通过模块化(信息隔离)实现稳定和简单的目标,并设计为持续很长时间。