- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我目前正在尝试对 (github) 存储库的 PR 进行代码样式检查,我想向提交者提供补丁,以便他们可以轻松修复代码样式。为此,我正在 pull 下他们的 PR,在其上运行我们的 uncrustify 脚本以修复任何样式错误,并希望创建一个他们可以轻松应用的 .patch 文件。但是,它总是会在某些文件上中断。
我这样做(git 版本 1.7.10.4,带有 core.autocrlf=input
,core.filemode=false
):
$ git checkout pr-branch
$ git log -1 (shows: commit dbb8d3f)
$ git status (nothing to commit, working directory clean)
$ <run the code styler script, which modifies some files>
$ git diff > ../style.patch (so the patch file lands outside the repo)
$ git reset --hard HEAD (to simulate the situation at the submitter's end)
$ git log -1 (shows: commit dbb8d3f)
$ git status (nothing to commit, working directory clean, so we are where we started)
$ git apply ../style.patch
error: patch failed: somefile.cpp:195
error: somefile.cpp: patch does not apply (same output using the --check option)
这仅适用于部分文件,并非全部。我不知道如何解决这个问题,即如何让 git 准确地告诉我哪里出了问题——它只在我挖掘时告诉我一个 hunk#,但这仍然相当大。
到目前为止我尝试过的(没有成功):
应用 --reverse
,应用 --whitespace=nowarn
diff HEAD
而不是单独的 diff
format-patch
,删除虚拟提交,使用 git-am
应用补丁,有或没有 -3
,或者用git-apply
patch
命令打补丁我不知道 diff 有什么问题。空白的东西应该只是警告,对吧?无论如何,我不想忽略它们,因为它是一种明显涉及空白的样式修复。
我该如何解决/诊断这个问题,甚至找出它究竟在哪里?如果我发布其中一个罪魁祸首文件的差异会有帮助吗?令我感到困惑的是提交没有问题,但是从提交创建的补丁却没有??
在与此搏斗了几个小时之后,我的知识已经走到尽头了......
最佳答案
更新:
您可以使用 git apply -v
来查看有关正在发生的事情的更多详细信息,git apply --check
来验证操作,或者 git应用 --index
重建本地索引文件。
根据您的评论,您的本地索引似乎已损坏,因此 index
解决了它。
我将保留我最初的答案和评论,主要是为了让人们了解正在发生的事情,因为我怀疑其他人会根据问题描述得出与我相同的初步结论。
------
差异很可能没有问题。而是查看目标 git 存储库。当您执行 git reset --hard HEAD
时,没有任何东西可以保证您在其他存储库上的 HEAD
与您的 HEAD
相同.
在目标仓库上执行 git log
并查看顶部的提交。它与您产生差异的那个相同吗?很可能不是。查看历史记录并检查是否存在您需要的提交。如果是,那么目标存储库在你之前,你必须返回,执行 git pull
(或 git rebase
)并生成一个新的 diff。如果不是,则目标存储库落后于您的存储库,您需要对目标存储库执行 git pull
(或 git rebase
)以加快速度.
请记住,如果您有其他人提交您的“主”存储库(您的机器人和目标存储库从中 pull 的存储库),您可能必须 git pull
两个存储库,让他们进行合理的近期共同提交。
关于git-apply 神秘地失败了,我该如何排除故障/修复?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14649605/
有人可以解释一下为什么这个脚本不起作用吗? function destroy(ID) { if (confirm("Deleting is a very bad thing! Sure?")
我正在尝试使 WCF Silverlight 故障按此方式工作: MSDN aricle 将 SL 故障添加到我的 Web.config 文件后,我收到以下警告: The element 'behav
这是我要删除的 Haskell 函数 2::Int和 5::Int从列表中: remPrimesFactors25 :: [Int] -> [Int] remPrimesFactors25 [] =
当我想用 ffmpeg 连接和录制两个 mp4 视频时,我遇到了这个问题。我得到的输出是: [concat @ 0x2566e80] DTS 4079 #0:0 (h264 (native) ->
我想在delphi中编写一个程序来模拟以特定速度移动的鼠标指针(类似于AutoIT MouseMove函数)。要么是我的代码错误,要么是 SetCursorPos 在被调用太多次后出现故障。这是我的功
我将“wa、or 和 id”(来自这些州的访问者)设置为重定向到 website1.com - 当我访问该网站时,它会将我重定向到 website1.com(因此它知道我在 WA) 。但如果我将 wa
我们目前正在争论通过 WCF channel 抛出错误与传递指示状态或服务响应的消息是否更好。 故障带有 WCF 的内置支持,您可以使用内置的错误处理程序并做出相应的 react 。然而,这会带来开销
不确定我在这里做错了什么,如果有任何帮助,我们将不胜感激。 尝试创建一个名为“control”的新变量,并在行变量等于这些数字时将其编码为 1,否则编码为 0。 data$control= ifels
我想在应用洞察中记录成功调用的百分比。我看到这篇文章https://learn.microsoft.com/en-us/azure/azure-monitor/app/sampling我认为固定速率采
我正在尝试使用 SVD 和特征分解来使用动态模式分解进行一些数据分析。我遇到了一个简单的问题,即从 Matlab 和 Python 获得不同的结果。我很困惑,不知道为什么 Python 给我错误的结果
This question already has an answer here: mysqli_fetch_assoc() expects parameter / Call to a member
我刚刚开始我的一个实验室,在那里我计算类(class)的 GPA,其信息存储在结构的链接列表中。截至目前,我正在尝试打印所有类(class)信息,以确保它们已正确初始化并添加到链接列表中。 我遇到了一
我正在尝试学习如何使用 visual studio 为 C++ 制作 GUI。但是我在使用 GetWindowText() 函数时遇到了一些问题。它不会将 LPTSTR 标题更改为文本框中的文本,并且
我有一个奇怪的问题。它似乎只出现在测试者的 iPhone 5s 上。它可以在运行最新 iOS (8.3) 的 iPhone 5、6 和 6 plus 上正常运行。 这是代码 -(NSString *)
我正在尝试更新 Core Data 中的一些记录。我正在采取以下步骤来完成它 带谓词的获取函数从核心数据中检索记录 将结果集存储在对象数组中 遍历数组并更新每条记录 调用保存上下文 我遇到了两个问题
我通过 Storyboard设计了 tableView,在一个单元格中我有一个按钮和一个标签。按钮在 Storyboard上有标签 1 和标签在 Storyboard上有标签 2。在 cellForR
我实现了这个方法,当在文本字段中输入了未经授权的字符或已使用的用户名时,向用户发送多个警报 View : func textFieldShouldEndEditing(textField: UITex
伙计们,我在运行程序时遇到了这个非常奇怪的错误。这是重要的代码: 变量(编辑): const short int maxX = 100; const short int maxZ = 100; con
我有这个修改过的 Matrix Javascript 代码,我想摆脱第一次运行的所有与自身重叠的字符串。有人知道我该如何管理吗?另外,我想在我的网页上多次使用此代码,我需要声明新变量,不是吗?但是当我
有谁知道是否有网站(甚至非 Microsoft)有关于 COMExceptions/HRESULTS 的详细信息。 当我尝试在使用 Copy() 函数后保存我的 Excel 工作簿时,我收到此错误:
我是一名优秀的程序员,十分优秀!