зеркало из https://github.com/microsoft/git.git
Merge branch 'rs/commit-m-no-edit' into maint
* rs/commit-m-no-edit: commit: don't start editor if empty message is given with -m
This commit is contained in:
Коммит
ee1a1ddf38
|
@ -107,7 +107,7 @@ static const char *cleanup_arg;
|
|||
|
||||
static enum commit_whence whence;
|
||||
static int use_editor = 1, include_status = 1;
|
||||
static int show_ignored_in_status;
|
||||
static int show_ignored_in_status, have_option_m;
|
||||
static const char *only_include_assumed;
|
||||
static struct strbuf message = STRBUF_INIT;
|
||||
|
||||
|
@ -121,9 +121,11 @@ static enum {
|
|||
static int opt_parse_m(const struct option *opt, const char *arg, int unset)
|
||||
{
|
||||
struct strbuf *buf = opt->value;
|
||||
if (unset)
|
||||
if (unset) {
|
||||
have_option_m = 0;
|
||||
strbuf_setlen(buf, 0);
|
||||
else {
|
||||
} else {
|
||||
have_option_m = 1;
|
||||
if (buf->len)
|
||||
strbuf_addch(buf, '\n');
|
||||
strbuf_addstr(buf, arg);
|
||||
|
@ -975,7 +977,7 @@ static int parse_and_validate_options(int argc, const char *argv[],
|
|||
if (force_author && renew_authorship)
|
||||
die(_("Using both --reset-author and --author does not make sense"));
|
||||
|
||||
if (logfile || message.len || use_message || fixup_message)
|
||||
if (logfile || have_option_m || use_message || fixup_message)
|
||||
use_editor = 0;
|
||||
if (0 <= edit_flag)
|
||||
use_editor = edit_flag;
|
||||
|
|
|
@ -361,6 +361,23 @@ test_expect_success !AUTOIDENT 'do not fire editor when committer is bogus' '
|
|||
test_cmp expect .git/result
|
||||
'
|
||||
|
||||
test_expect_success 'do not fire editor if -m <msg> was given' '
|
||||
echo tick >file &&
|
||||
git add file &&
|
||||
echo "editor not started" >.git/result &&
|
||||
(GIT_EDITOR="\"$(pwd)/.git/FAKE_EDITOR\"" git commit -m tick) &&
|
||||
test "$(cat .git/result)" = "editor not started"
|
||||
'
|
||||
|
||||
test_expect_success 'do not fire editor if -m "" was given' '
|
||||
echo tock >file &&
|
||||
git add file &&
|
||||
echo "editor not started" >.git/result &&
|
||||
(GIT_EDITOR="\"$(pwd)/.git/FAKE_EDITOR\"" \
|
||||
git commit -m "" --allow-empty-message) &&
|
||||
test "$(cat .git/result)" = "editor not started"
|
||||
'
|
||||
|
||||
test_expect_success 'do not fire editor in the presence of conflicts' '
|
||||
|
||||
git clean -f &&
|
||||
|
|
Загрузка…
Ссылка в новой задаче