Ping Yin <pkufranky@xxxxxxxxx> writes: > status.color shouldn't be honored when committing since the run-status > output is fed to the editor. > --- > builtin-commit.c | 2 ++ > 1 files changed, 2 insertions(+), 0 deletions(-) > > diff --git a/builtin-commit.c b/builtin-commit.c > index 8db74ed..4396e7d 100644 > --- a/builtin-commit.c > +++ b/builtin-commit.c > @@ -45,6 +45,7 @@ static int quiet, verbose, untracked_files, no_verify; > static int no_edit, initial_commit, in_merge; > const char *only_include_assumed; > struct strbuf message; > +extern int wt_status_use_color; > > static int opt_parse_m(const struct option *opt, const char *arg, int unset) > { > @@ -325,6 +326,7 @@ static int prepare_log_message(const char *index_file, const char *prefix) > if (only_include_assumed) > fprintf(fp, "# %s\n", only_include_assumed); > > + wt_status_use_color = 0; > commitable = run_status(fp, index_file, prefix); > > fclose(fp); Although I admit I do not care much about the "status color", I suspect this patch is not quite right. When prepare_log_message() returns "no committable changes" and we are not in merge, the calling cmd_commit() does another run_status() to show the status of the index and the work tree to the stdout, and at that point, we _do_ want to honor the configuration setting you are discarding with this assignment. --- builtin-commit.c | 5 ++++- wt-status.h | 1 + 2 files changed, 5 insertions(+), 1 deletions(-) diff --git a/builtin-commit.c b/builtin-commit.c index 4e2f4aa..058cd32 100644 --- a/builtin-commit.c +++ b/builtin-commit.c @@ -300,7 +300,7 @@ static const char sign_off_header[] = "Signed-off-by: "; static int prepare_log_message(const char *index_file, const char *prefix) { struct stat statbuf; - int commitable; + int commitable, saved_color_setting; struct strbuf sb; char *buffer; FILE *fp; @@ -383,7 +383,10 @@ static int prepare_log_message(const char *index_file, const char *prefix) if (only_include_assumed) fprintf(fp, "# %s\n", only_include_assumed); + saved_color_setting = wt_status_use_color; + wt_status_use_color = 0; commitable = run_status(fp, index_file, prefix); + wt_status_use_color = saved_color_setting; fclose(fp); diff --git a/wt-status.h b/wt-status.h index f58ebcb..225fb4d 100644 --- a/wt-status.h +++ b/wt-status.h @@ -27,6 +27,7 @@ struct wt_status { }; int git_status_config(const char *var, const char *value); +int wt_status_use_color; void wt_status_prepare(struct wt_status *s); void wt_status_print(struct wt_status *s); - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html