如何抑制"Changes not staged for commit"?



提交时如何抑制"未提交的更改"输出?注意:

  • 我知道我可以做> /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_SHORTgit 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,你可以继续吗?

相关内容

  • 没有找到相关文章

最新更新