提交时如何抑制"未提交的更改"输出?注意:
- 我知道我可以做
> /dev/null
,但我希望不要压制其他事情 - 我说的不是提交消息——我说的是打印到终端的内容
在git.git代码库中进行了一些挖掘之后,恐怕您应该设计一种方法来忽略脚本中的这些行。
在提交过程中,如果不使用--allow-empty
,git将通过该代码:
if (!commitable && whence != FROM_MERGE && !allow_empty &&
!(amend && is_a_merge(current_head))) {
s->display_comment_prefix = old_display_comment_prefix;
run_status(stdout, index_file, prefix, 0, s);
...
return 0;
}
run_status
做以下事情:
switch (status_format) {
case STATUS_FORMAT_SHORT:
wt_shortstatus_print(s);
break;
case STATUS_FORMAT_PORCELAIN:
wt_porcelain_print(s);
break;
case STATUS_FORMAT_UNSPECIFIED:
die("BUG: finalize_deferred_config() should have been called");
break;
case STATUS_FORMAT_NONE:
case STATUS_FORMAT_LONG:
wt_status_print(s);
break;
}
}
STATUS_FORMAT_PORCELAIN
(使用--porcelain
)和STATUS_FORMAT_SHORT
(git config status.short true
)将产生相同的缩小输出:
M bla.txt
和STATUS_FORMAT_LONG
(and STATUS_FORMAT_NONE
,不确定为什么?),将产生通常的输出:
Changes not staged for commit:
modified: bla.txt
也就是说,我们不要绝望,这就是我们正在谈论的软件,总有办法解决这个问题(不过我仍然需要完全测试这个;)
您可以使用--allow-empty
来传递该代码分支并创建一个空提交。然后,你用一个post-commit
钩子来检查最近的提交是否为空,如果是,钩子运行git reset --hard HEAD~1
,你可以继续吗?