- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在 rebase 期间,我经常想查看当前正在应用的提交消息,以帮助理解 merge 冲突。
我曾经跑过:
$ cat .git/rebase-apply/message
这会很好地给我。但是,在我运行 git v2.20.1 的新机器上,该文件在 rebase 期间不再存在。
我在哪里可以获得当前正在应用的提交的消息(当 rebase 因 merge 冲突而暂停时)?
最佳答案
TL;DR:检查 git rev-parse --git-path rebase-merge/message
和 git rev-parse --git-path rebase-apply/msg
如果您在添加的工作树中。
不幸的是,获取这些信息的接口(interface)并不稳定。但是,您要查找的文件确实仍然存在于现代 Git 中。
随着git worktree
的出现,大多数状态信息已经(至少可能)移动了。现在存在相同类型的文件,但位于不同的位置。要查找 git 相对路径名为 P 的文件的位置,请使用 git rev-parse --git-path <em>P</em>
:
$ git rev-parse --git-path HEAD
.git/HEAD
$ git worktree add ../git2 --detach
Preparing worktree (detached HEAD 5d826e9729)
HEAD is now at 5d826e9729 Git 2.20
$ (cd ../git2; git rev-parse --git-path HEAD)
[redacted]/git/.git/worktrees/git2/HEAD
从 Git 2.13 开始,可以在其中找到 rebase 信息的两个目录是:
rebase-apply
rebase-merge
(一如既往,使用 git-path 技巧来定位实际目录或其中的单个文件)。其中的文件最初是对称的,因为代码只是设置一个状态目录,然后根据需要将文件放入其中。这组文件可能会在未来的任何 Git 版本中发生变化;然而,由于 contrib/completion/git-prompt.sh
,至少有一些一致性的希望.这看起来在里面 rebase-merge
首先,如果它存在,对于:
head-name the branch you were on when you started the rebase
msgnum how many commits are already done (how far along are you)
end the total number of commits to do
interactive if exists, means this is git rebase -i (vs git rebase -m)
如果rebase-merge
不存在,它在里面查找rebase-apply
(如果存在)用于:
next how many commits are already done (how far along are you)
last the total number of commits to do
rebasing if exists, means this is an ordinary git rebase, in which case:
head-name the branch you were on when you started rebasing
applying if exists, means this is a git am without rebase
如果 rebase 和应用文件都不存在,提示代码假定“git-am 或 git-rebase”而不尝试进一步猜测。
如果两个目录都不存在,提示设置代码将继续检查:
MERGE_HEAD a merge is in progress
CHERRY_PICK_HEAD a cherry-pick is in progress
REVERT_HEAD a revert is in progress
BISECT_LOG a bisect is in progress
序列器代码(现在用于除遗留 rebase 之外的所有 rebase ,虽然我不确定它在 2.13 中使用了多少)比其中任何一个都不稳定 - 参见所有 GIT_PATH_FUNC
the source code 中的行.其中之一是您的 rebase-merge/message
文件。无论您是在进行交互式 rebase ,git rebase -m
, 或 git rebase -s <em>strategy</em>
,此文件应该存在于适当的工作树相关路径中。对于非交互式 git rebase
我认为该文件应该在 rebase-apply/msg
中相反。
关于git - 在 git rebase 期间查看当前提交的消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53982206/
我有一个用 Swift 编写的自定义转换,当呈现的 View 从侧面进入时,被关闭的 View 消失。 现在我想要同样的效果,但我希望呈现的 View 从顶部进入,而被取消的 View 从底部出来。
该方法的预期目的是什么 findBinding(View view) ? 我一直在使用数据绑定(bind)库测试版。 目前还没有针对各个类的官方引用文档,所以我一直在查看源代码以了解我们可以访问哪些方
我试图在遍历 &str 时查看当前位置前面的字符。 let myStr = "12345"; let mut iter = myStr.chars().peekable(); for c in ite
每当我在 Azure 中创建新的 Azure 函数应用时,我都会选择一个存储帐户供其使用。 创建应用后,如何查看/更改存储帐户? 我尝试在门户中浏览,但无法看到可以在哪里配置它。 最佳答案 创建后,您
我想查看读取 QFile 的 QTextStream 的下一个字符,以创建一个高效的标记器。 但是,我没有找到任何令人满意的解决方案。 QFile f("test.txt"); f.open(QIOD
当我旋转手机时, ListView 中选定的项目将被取消选择。这是我的适配器。我只想更改所选项目的颜色(仅是单个选择),当我旋转手机时,我想查看我选择的内容。现在,当我旋转手机时,我看不到所选项目。
我开始编写代码来检查函数的返回值,但我不确定在捕获到一些错误后如何继续。 例如,在 fgets 中: while( fgets( rta, 3, stdin ) == NULL ) {
是否可以获取或创建一个 optional 轮,它以假想的圆圈滚动而不是直接向下(垂直)滚动? 直线链接但想要弯曲 例如就像控件 here ,但车轮是弯曲的? 最佳答案 有没有可能你想要的是一个轮播?
当我尝试为其创建 View 时出现错误:“ View 的 SELECT 在 FROM 子句中包含一个子查询”,但它在普通查询中工作正常。我认为它与我的 WHERE 子句有关,但我不明白为什么或如何修复
在一个类中,我有以下代码: /// [System.Xml.Serialization.XmlElementAttribute("Errors", typeof(ErrorsType))] [Sys
我想显示来自 catch block 的错误(日志)消息。如何在单个屏幕上显示所有消息(堆栈),以便用户了解? 谢谢... 最佳答案 使用 Toast 怎么样? 示例: Toast.makeText(
我有以下屏幕(图像),当按下按钮时显示一个侧面菜单,菜单出现,另外我有一个 uitableview 来显示其他东西 我的问题是,当侧边菜单出现时,uitableview 被调整了大小。 如何保持 ui
invariant violation element type is invalid: expected a string (for built-in components) or a class/
我是新手,正在尝试学习 fork() 和系统调用的功能,现在我正在使用 execvp() 来尝试制作 bash,但我遇到的问题是,当我编写正确的命令时,程序结束,我想循环使用我的 bash,直到有人在
我正在尝试使用 Laravel request validation method 创建一个登录页面 和凭据验证 -> 如果用户未通过身份验证,它将返回错误“密码错误....” 我在两种不同的情况下看
我有一个 .jar 文件,我需要查看 jar 文件的内容。 是否有任何解码器可用于解码 jar 文件。 我也有 solaris 环境,我需要知道什么是 最佳答案 使用jar命令行,即 jar tf j
Git 提供了几种方式可以帮你快速查看提交中哪些文件被改变。 如果你每天使用 Git,应该会提交不少改动。如果你每天和其他人在一个项目中使用 Git,假设 每个人 每天的提
问题 tensor详细数值 不能直接print打印: ? 1
一,uptime 可以查看系统的运行时间 show global status like 'uptime'; 二,利用linux命令查看 Linux 下有个 uptime 可以查看系统的运行时
在所有主流的浏览器中,均能够查看原始的 XML 文件 不要指望 XML 文件会直接显示为 HTML 页面 查看 XML 文件 <?xml version="1.0" e
我是一名优秀的程序员,十分优秀!