我不明白gitrm--cached之间的区别和gitupdate-index--assume-unchanged.我知道gitrm--cached将从暂存区中删除一个文件。而且,我知道gitupdate-index--assume-unchanged也这样做。我还在SO上看到这两个命令都作为对类似问题的建议提供。这两个命令是否有其他影响使它们不同? 最佳答案 命令gitrm--cached用于取消跟踪Git分支中的文件。此命令将从暂存区中删除文件,并且还将在您下次提交时从存储库中删除该文件。命令gitupdate-index--as
gitupdate-index--assume-unchanged返回fatal:Unabletomarkfile.我需要做什么来解决这个问题?它在提示什么,为什么? 最佳答案 它是否被添加到存储库中,而不是在.git/info/exclude中而不是在.gitignore中?如果其中任何一个的答案是肯定的,那么该文件不在存储库中,这就是错误的原因。尝试gitls-files-o并查看文件是否存在。不应该。 关于gitupdate-index--assume-unchanged返回错误,
在下面这张来自Github(c)桌面应用程序的图片中,有这个按钮“从主服务器更新”(在本例中)。我想知道是否有人了解它触发的确切git函数。如果使用merge或rebase,我主要感兴趣。(我找不到任何类型的日志控制台)。 最佳答案 GitHubDesktop中按钮下的git命令没有详细记录,所以我前一段时间调查了一下。我得出的结论是“更新自...”按钮已发送gitmerge--no-ff-m"Merge"或与设置为的“比较”分支几乎相同的东西在GitHubDesktopGUI中。我是这样得出结论的:首先,我将我控制的存储库fork
有些情况下我不能使用.gitignore文件,否则,在gitpush,从远程清除关键文件。在这些情况下,我申请gitupdate-index--assume-unchanged到我想忽略的文件。在应用假设不变的规则并调用gitpush之后,这些规则是否会附加到远程分支,以便所有后续pull(来自其他客户端)都将继承它们?或者,这些客户端是否也必须运行gitupdate-index--assume-unchanged在他们的机器上单独命令?如果命令不是继承的——以前有没有人为此编写过服务器钩子(Hook)?而不是强制所有当前和future的客户防范它? 最佳答
这个问题在这里已经有了答案:Writingagitpost-receivehooktodealwithaspecificbranch(7个答案)关闭6年前。我正在执行一个程序,以便在每次向我们的远程存储库发送更新时提醒CruiseControl。为此,我正在使用Git更新后Hook。如果我能找出哪个分支已被提交就太好了,这样我就可以用它来通知CruiseControl要构建哪个分支。有什么方法可以在更新后Hook中访问分支名称吗?
场景如下:在我的工作目录中,我有许多我编辑过的文件(我们称它们为A、B、C)。然后,我对这些文件运行了gitupdate-index--assume-unchanged。现在gitstatus返回空白。好。现在,如果我执行gitreset--hard,文件A、B和C的内容将恢复到我编辑它们之前的内容,并且“假设未更改”“他们。有没有办法阻止git实际恢复文件A、B和C,并简单地忽略它们?谢谢,肯 最佳答案 你可以这样做:gitupdate-index--skip-worktreeA 关于
我是最近的gitconvert。能够使用git-svn在不干扰svn服务器的情况下将我的分支保留在本地真是太棒了。最新版本的代码中存在一个错误。我想确定它工作的时间,以便我可以使用gitbisect。我找不到及时返回的正确命令。谢谢。 最佳答案 gitcheckoutHEAD~1这会将您当前的HEAD移动到更早的一个版本。gitcheckout这会将您当前的HEAD移动到给定的修订版。使用gitlog或gitk查找您要查找的修订版。 关于git-"svnupdate-r"的git等价物是
git1.7.12我想将给定目录下的所有文件标记为假设未更改。gitupdate-index--assume-unchangeddir/给出“忽略路径”。gitupdate-index--assume-unchangeddir/*很快就会失败,因为它会遇到未被跟踪的文件,因此它给出“致命:无法标记文件”和退出。尝试生成要标记的文件列表。cd进入所需的目录,然后运行gitls-files|tr'\n'''|gitupdate-index--assume-unchanged.这不会产生错误消息,但不会成功标记文件。命令的第一部分,gitls-files|tr'\n''',正确生成我要标
回应aquestionaboutpullingonecommitatatimefromagitrepository,我被推荐使用gitremoteupdate而不是gitfetch。我已经阅读了两个手册页,但不能说我完全理解其中任何一个。谁能给我解释一下gitfetchorigin和getremoteupdateorigin的行为有何不同? 最佳答案 这样使用没有区别。remoteupdate是一个非常高级的命令——它支持分组Remote(remotes.=),并更新所有Remote(除了设置了remote..skipDefault
我遇到了与this上的OP相同的问题|帖子,但我不明白标记为正确的答案(我没有看到它解释了如何解决这个问题)我这样做并得到这个错误:$gitupdate-index--assume-unchangedweb.configfatal:Unabletomarkfileweb.config文件已添加到存储库它不在.git/info/exclude它不在.gitignore中(它是,但我把它拿出来,然后强制使用gitadd-fweb.config添加web.config,提交,和将这些更改推送到存储库)当我执行Gitls-files-o时,它不存在那么我能做些什么来修复呢?