1/*
2 * Builtin "git commit"
3 *
4 * Copyright (c) 2007 Kristian Høgsberg <krh@redhat.com>
5 * Based on git-commit.sh by Junio C Hamano and Linus Torvalds
6 */
7
8#include "cache.h"
9#include "lockfile.h"
10#include "cache-tree.h"
11#include "color.h"
12#include "dir.h"
13#include "builtin.h"
14#include "diff.h"
15#include "diffcore.h"
16#include "commit.h"
17#include "revision.h"
18#include "wt-status.h"
19#include "run-command.h"
20#include "refs.h"
21#include "log-tree.h"
22#include "strbuf.h"
23#include "utf8.h"
24#include "parse-options.h"
25#include "string-list.h"
26#include "rerere.h"
27#include "unpack-trees.h"
28#include "quote.h"
29#include "submodule.h"
30#include "gpg-interface.h"
31#include "column.h"
32#include "sequencer.h"
33#include "notes-utils.h"
34#include "mailmap.h"
35#include "sigchain.h"
36
37static const char * const builtin_commit_usage[] = {
38 N_("git commit [<options>] [--] <pathspec>..."),
39 NULL
40};
41
42static const char * const builtin_status_usage[] = {
43 N_("git status [<options>] [--] <pathspec>..."),
44 NULL
45};
46
47static const char implicit_ident_advice_noconfig[] =
48N_("Your name and email address were configured automatically based\n"
49"on your username and hostname. Please check that they are accurate.\n"
50"You can suppress this message by setting them explicitly. Run the\n"
51"following command and follow the instructions in your editor to edit\n"
52"your configuration file:\n"
53"\n"
54" git config --global --edit\n"
55"\n"
56"After doing this, you may fix the identity used for this commit with:\n"
57"\n"
58" git commit --amend --reset-author\n");
59
60static const char implicit_ident_advice_config[] =
61N_("Your name and email address were configured automatically based\n"
62"on your username and hostname. Please check that they are accurate.\n"
63"You can suppress this message by setting them explicitly:\n"
64"\n"
65" git config --global user.name \"Your Name\"\n"
66" git config --global user.email you@example.com\n"
67"\n"
68"After doing this, you may fix the identity used for this commit with:\n"
69"\n"
70" git commit --amend --reset-author\n");
71
72static const char empty_amend_advice[] =
73N_("You asked to amend the most recent commit, but doing so would make\n"
74"it empty. You can repeat your command with --allow-empty, or you can\n"
75"remove the commit entirely with \"git reset HEAD^\".\n");
76
77static const char empty_cherry_pick_advice[] =
78N_("The previous cherry-pick is now empty, possibly due to conflict resolution.\n"
79"If you wish to commit it anyway, use:\n"
80"\n"
81" git commit --allow-empty\n"
82"\n");
83
84static const char empty_cherry_pick_advice_single[] =
85N_("Otherwise, please use 'git reset'\n");
86
87static const char empty_cherry_pick_advice_multi[] =
88N_("If you wish to skip this commit, use:\n"
89"\n"
90" git reset\n"
91"\n"
92"Then \"git cherry-pick --continue\" will resume cherry-picking\n"
93"the remaining commits.\n");
94
95static GIT_PATH_FUNC(git_path_commit_editmsg, "COMMIT_EDITMSG")
96
97static const char *use_message_buffer;
98static struct lock_file index_lock; /* real index */
99static struct lock_file false_lock; /* used only for partial commits */
100static enum {
101 COMMIT_AS_IS = 1,
102 COMMIT_NORMAL,
103 COMMIT_PARTIAL
104} commit_style;
105
106static const char *logfile, *force_author;
107static const char *template_file;
108/*
109 * The _message variables are commit names from which to take
110 * the commit message and/or authorship.
111 */
112static const char *author_message, *author_message_buffer;
113static char *edit_message, *use_message;
114static char *fixup_message, *squash_message;
115static int all, also, interactive, patch_interactive, only, amend, signoff;
116static int edit_flag = -1; /* unspecified */
117static int quiet, verbose, no_verify, allow_empty, dry_run, renew_authorship;
118static int config_commit_verbose = -1; /* unspecified */
119static int no_post_rewrite, allow_empty_message;
120static char *untracked_files_arg, *force_date, *ignore_submodule_arg;
121static char *sign_commit;
122
123/*
124 * The default commit message cleanup mode will remove the lines
125 * beginning with # (shell comments) and leading and trailing
126 * whitespaces (empty lines or containing only whitespaces)
127 * if editor is used, and only the whitespaces if the message
128 * is specified explicitly.
129 */
130static enum {
131 CLEANUP_SPACE,
132 CLEANUP_NONE,
133 CLEANUP_SCISSORS,
134 CLEANUP_ALL
135} cleanup_mode;
136static const char *cleanup_arg;
137
138static enum commit_whence whence;
139static int sequencer_in_use;
140static int use_editor = 1, include_status = 1;
141static int show_ignored_in_status, have_option_m;
142static const char *only_include_assumed;
143static struct strbuf message = STRBUF_INIT;
144
145static enum wt_status_format status_format = STATUS_FORMAT_UNSPECIFIED;
146
147static int opt_parse_porcelain(const struct option *opt, const char *arg, int unset)
148{
149 enum wt_status_format *value = (enum wt_status_format *)opt->value;
150 if (unset)
151 *value = STATUS_FORMAT_NONE;
152 else if (!arg)
153 *value = STATUS_FORMAT_PORCELAIN;
154 else if (!strcmp(arg, "v1") || !strcmp(arg, "1"))
155 *value = STATUS_FORMAT_PORCELAIN;
156 else if (!strcmp(arg, "v2") || !strcmp(arg, "2"))
157 *value = STATUS_FORMAT_PORCELAIN_V2;
158 else
159 die("unsupported porcelain version '%s'", arg);
160
161 return 0;
162}
163
164static int opt_parse_m(const struct option *opt, const char *arg, int unset)
165{
166 struct strbuf *buf = opt->value;
167 if (unset) {
168 have_option_m = 0;
169 strbuf_setlen(buf, 0);
170 } else {
171 have_option_m = 1;
172 if (buf->len)
173 strbuf_addch(buf, '\n');
174 strbuf_addstr(buf, arg);
175 strbuf_complete_line(buf);
176 }
177 return 0;
178}
179
180static void determine_whence(struct wt_status *s)
181{
182 if (file_exists(git_path_merge_head()))
183 whence = FROM_MERGE;
184 else if (file_exists(git_path_cherry_pick_head())) {
185 whence = FROM_CHERRY_PICK;
186 if (file_exists(git_path_seq_dir()))
187 sequencer_in_use = 1;
188 }
189 else
190 whence = FROM_COMMIT;
191 if (s)
192 s->whence = whence;
193}
194
195static void status_init_config(struct wt_status *s, config_fn_t fn)
196{
197 wt_status_prepare(s);
198 gitmodules_config();
199 git_config(fn, s);
200 determine_whence(s);
201 init_diff_ui_defaults();
202 s->hints = advice_status_hints; /* must come after git_config() */
203}
204
205static void rollback_index_files(void)
206{
207 switch (commit_style) {
208 case COMMIT_AS_IS:
209 break; /* nothing to do */
210 case COMMIT_NORMAL:
211 rollback_lock_file(&index_lock);
212 break;
213 case COMMIT_PARTIAL:
214 rollback_lock_file(&index_lock);
215 rollback_lock_file(&false_lock);
216 break;
217 }
218}
219
220static int commit_index_files(void)
221{
222 int err = 0;
223
224 switch (commit_style) {
225 case COMMIT_AS_IS:
226 break; /* nothing to do */
227 case COMMIT_NORMAL:
228 err = commit_lock_file(&index_lock);
229 break;
230 case COMMIT_PARTIAL:
231 err = commit_lock_file(&index_lock);
232 rollback_lock_file(&false_lock);
233 break;
234 }
235
236 return err;
237}
238
239/*
240 * Take a union of paths in the index and the named tree (typically, "HEAD"),
241 * and return the paths that match the given pattern in list.
242 */
243static int list_paths(struct string_list *list, const char *with_tree,
244 const char *prefix, const struct pathspec *pattern)
245{
246 int i, ret;
247 char *m;
248
249 if (!pattern->nr)
250 return 0;
251
252 m = xcalloc(1, pattern->nr);
253
254 if (with_tree) {
255 char *max_prefix = common_prefix(pattern);
256 overlay_tree_on_index(&the_index, with_tree,
257 max_prefix ? max_prefix : prefix);
258 free(max_prefix);
259 }
260
261 for (i = 0; i < active_nr; i++) {
262 const struct cache_entry *ce = active_cache[i];
263 struct string_list_item *item;
264
265 if (ce->ce_flags & CE_UPDATE)
266 continue;
267 if (!ce_path_match(ce, pattern, m))
268 continue;
269 item = string_list_insert(list, ce->name);
270 if (ce_skip_worktree(ce))
271 item->util = item; /* better a valid pointer than a fake one */
272 }
273
274 ret = report_path_error(m, pattern, prefix);
275 free(m);
276 return ret;
277}
278
279static void add_remove_files(struct string_list *list)
280{
281 int i;
282 for (i = 0; i < list->nr; i++) {
283 struct stat st;
284 struct string_list_item *p = &(list->items[i]);
285
286 /* p->util is skip-worktree */
287 if (p->util)
288 continue;
289
290 if (!lstat(p->string, &st)) {
291 if (add_to_cache(p->string, &st, 0))
292 die(_("updating files failed"));
293 } else
294 remove_file_from_cache(p->string);
295 }
296}
297
298static void create_base_index(const struct commit *current_head)
299{
300 struct tree *tree;
301 struct unpack_trees_options opts;
302 struct tree_desc t;
303
304 if (!current_head) {
305 discard_cache();
306 return;
307 }
308
309 memset(&opts, 0, sizeof(opts));
310 opts.head_idx = 1;
311 opts.index_only = 1;
312 opts.merge = 1;
313 opts.src_index = &the_index;
314 opts.dst_index = &the_index;
315
316 opts.fn = oneway_merge;
317 tree = parse_tree_indirect(¤t_head->object.oid);
318 if (!tree)
319 die(_("failed to unpack HEAD tree object"));
320 parse_tree(tree);
321 init_tree_desc(&t, tree->buffer, tree->size);
322 if (unpack_trees(1, &t, &opts))
323 exit(128); /* We've already reported the error, finish dying */
324}
325
326static void refresh_cache_or_die(int refresh_flags)
327{
328 /*
329 * refresh_flags contains REFRESH_QUIET, so the only errors
330 * are for unmerged entries.
331 */
332 if (refresh_cache(refresh_flags | REFRESH_IN_PORCELAIN))
333 die_resolve_conflict("commit");
334}
335
336static const char *prepare_index(int argc, const char **argv, const char *prefix,
337 const struct commit *current_head, int is_status)
338{
339 struct string_list partial;
340 struct pathspec pathspec;
341 int refresh_flags = REFRESH_QUIET;
342 const char *ret;
343
344 if (is_status)
345 refresh_flags |= REFRESH_UNMERGED;
346 parse_pathspec(&pathspec, 0,
347 PATHSPEC_PREFER_FULL,
348 prefix, argv);
349
350 if (read_cache_preload(&pathspec) < 0)
351 die(_("index file corrupt"));
352
353 if (interactive) {
354 char *old_index_env = NULL;
355 hold_locked_index(&index_lock, LOCK_DIE_ON_ERROR);
356
357 refresh_cache_or_die(refresh_flags);
358
359 if (write_locked_index(&the_index, &index_lock, CLOSE_LOCK))
360 die(_("unable to create temporary index"));
361
362 old_index_env = getenv(INDEX_ENVIRONMENT);
363 setenv(INDEX_ENVIRONMENT, get_lock_file_path(&index_lock), 1);
364
365 if (interactive_add(argc, argv, prefix, patch_interactive) != 0)
366 die(_("interactive add failed"));
367
368 if (old_index_env && *old_index_env)
369 setenv(INDEX_ENVIRONMENT, old_index_env, 1);
370 else
371 unsetenv(INDEX_ENVIRONMENT);
372
373 discard_cache();
374 read_cache_from(get_lock_file_path(&index_lock));
375 if (update_main_cache_tree(WRITE_TREE_SILENT) == 0) {
376 if (reopen_lock_file(&index_lock) < 0)
377 die(_("unable to write index file"));
378 if (write_locked_index(&the_index, &index_lock, CLOSE_LOCK))
379 die(_("unable to update temporary index"));
380 } else
381 warning(_("Failed to update main cache tree"));
382
383 commit_style = COMMIT_NORMAL;
384 return get_lock_file_path(&index_lock);
385 }
386
387 /*
388 * Non partial, non as-is commit.
389 *
390 * (1) get the real index;
391 * (2) update the_index as necessary;
392 * (3) write the_index out to the real index (still locked);
393 * (4) return the name of the locked index file.
394 *
395 * The caller should run hooks on the locked real index, and
396 * (A) if all goes well, commit the real index;
397 * (B) on failure, rollback the real index.
398 */
399 if (all || (also && pathspec.nr)) {
400 hold_locked_index(&index_lock, LOCK_DIE_ON_ERROR);
401 add_files_to_cache(also ? prefix : NULL, &pathspec, 0);
402 refresh_cache_or_die(refresh_flags);
403 update_main_cache_tree(WRITE_TREE_SILENT);
404 if (write_locked_index(&the_index, &index_lock, CLOSE_LOCK))
405 die(_("unable to write new_index file"));
406 commit_style = COMMIT_NORMAL;
407 return get_lock_file_path(&index_lock);
408 }
409
410 /*
411 * As-is commit.
412 *
413 * (1) return the name of the real index file.
414 *
415 * The caller should run hooks on the real index,
416 * and create commit from the_index.
417 * We still need to refresh the index here.
418 */
419 if (!only && !pathspec.nr) {
420 hold_locked_index(&index_lock, LOCK_DIE_ON_ERROR);
421 refresh_cache_or_die(refresh_flags);
422 if (active_cache_changed
423 || !cache_tree_fully_valid(active_cache_tree))
424 update_main_cache_tree(WRITE_TREE_SILENT);
425 if (active_cache_changed) {
426 if (write_locked_index(&the_index, &index_lock,
427 COMMIT_LOCK))
428 die(_("unable to write new_index file"));
429 } else {
430 rollback_lock_file(&index_lock);
431 }
432 commit_style = COMMIT_AS_IS;
433 return get_index_file();
434 }
435
436 /*
437 * A partial commit.
438 *
439 * (0) find the set of affected paths;
440 * (1) get lock on the real index file;
441 * (2) update the_index with the given paths;
442 * (3) write the_index out to the real index (still locked);
443 * (4) get lock on the false index file;
444 * (5) reset the_index from HEAD;
445 * (6) update the_index the same way as (2);
446 * (7) write the_index out to the false index file;
447 * (8) return the name of the false index file (still locked);
448 *
449 * The caller should run hooks on the locked false index, and
450 * create commit from it. Then
451 * (A) if all goes well, commit the real index;
452 * (B) on failure, rollback the real index;
453 * In either case, rollback the false index.
454 */
455 commit_style = COMMIT_PARTIAL;
456
457 if (whence != FROM_COMMIT) {
458 if (whence == FROM_MERGE)
459 die(_("cannot do a partial commit during a merge."));
460 else if (whence == FROM_CHERRY_PICK)
461 die(_("cannot do a partial commit during a cherry-pick."));
462 }
463
464 string_list_init(&partial, 1);
465 if (list_paths(&partial, !current_head ? NULL : "HEAD", prefix, &pathspec))
466 exit(1);
467
468 discard_cache();
469 if (read_cache() < 0)
470 die(_("cannot read the index"));
471
472 hold_locked_index(&index_lock, LOCK_DIE_ON_ERROR);
473 add_remove_files(&partial);
474 refresh_cache(REFRESH_QUIET);
475 update_main_cache_tree(WRITE_TREE_SILENT);
476 if (write_locked_index(&the_index, &index_lock, CLOSE_LOCK))
477 die(_("unable to write new_index file"));
478
479 hold_lock_file_for_update(&false_lock,
480 git_path("next-index-%"PRIuMAX,
481 (uintmax_t) getpid()),
482 LOCK_DIE_ON_ERROR);
483
484 create_base_index(current_head);
485 add_remove_files(&partial);
486 refresh_cache(REFRESH_QUIET);
487
488 if (write_locked_index(&the_index, &false_lock, CLOSE_LOCK))
489 die(_("unable to write temporary index file"));
490
491 discard_cache();
492 ret = get_lock_file_path(&false_lock);
493 read_cache_from(ret);
494 return ret;
495}
496
497static int run_status(FILE *fp, const char *index_file, const char *prefix, int nowarn,
498 struct wt_status *s)
499{
500 struct object_id oid;
501
502 if (s->relative_paths)
503 s->prefix = prefix;
504
505 if (amend) {
506 s->amend = 1;
507 s->reference = "HEAD^1";
508 }
509 s->verbose = verbose;
510 s->index_file = index_file;
511 s->fp = fp;
512 s->nowarn = nowarn;
513 s->is_initial = get_sha1(s->reference, oid.hash) ? 1 : 0;
514 if (!s->is_initial)
515 hashcpy(s->sha1_commit, oid.hash);
516 s->status_format = status_format;
517 s->ignore_submodule_arg = ignore_submodule_arg;
518
519 wt_status_collect(s);
520 wt_status_print(s);
521
522 return s->commitable;
523}
524
525static int is_a_merge(const struct commit *current_head)
526{
527 return !!(current_head->parents && current_head->parents->next);
528}
529
530static void assert_split_ident(struct ident_split *id, const struct strbuf *buf)
531{
532 if (split_ident_line(id, buf->buf, buf->len) || !id->date_begin)
533 die("BUG: unable to parse our own ident: %s", buf->buf);
534}
535
536static void export_one(const char *var, const char *s, const char *e, int hack)
537{
538 struct strbuf buf = STRBUF_INIT;
539 if (hack)
540 strbuf_addch(&buf, hack);
541 strbuf_addf(&buf, "%.*s", (int)(e - s), s);
542 setenv(var, buf.buf, 1);
543 strbuf_release(&buf);
544}
545
546static int parse_force_date(const char *in, struct strbuf *out)
547{
548 strbuf_addch(out, '@');
549
550 if (parse_date(in, out) < 0) {
551 int errors = 0;
552 unsigned long t = approxidate_careful(in, &errors);
553 if (errors)
554 return -1;
555 strbuf_addf(out, "%lu", t);
556 }
557
558 return 0;
559}
560
561static void set_ident_var(char **buf, char *val)
562{
563 free(*buf);
564 *buf = val;
565}
566
567static void determine_author_info(struct strbuf *author_ident)
568{
569 char *name, *email, *date;
570 struct ident_split author;
571
572 name = xstrdup_or_null(getenv("GIT_AUTHOR_NAME"));
573 email = xstrdup_or_null(getenv("GIT_AUTHOR_EMAIL"));
574 date = xstrdup_or_null(getenv("GIT_AUTHOR_DATE"));
575
576 if (author_message) {
577 struct ident_split ident;
578 size_t len;
579 const char *a;
580
581 a = find_commit_header(author_message_buffer, "author", &len);
582 if (!a)
583 die(_("commit '%s' lacks author header"), author_message);
584 if (split_ident_line(&ident, a, len) < 0)
585 die(_("commit '%s' has malformed author line"), author_message);
586
587 set_ident_var(&name, xmemdupz(ident.name_begin, ident.name_end - ident.name_begin));
588 set_ident_var(&email, xmemdupz(ident.mail_begin, ident.mail_end - ident.mail_begin));
589
590 if (ident.date_begin) {
591 struct strbuf date_buf = STRBUF_INIT;
592 strbuf_addch(&date_buf, '@');
593 strbuf_add(&date_buf, ident.date_begin, ident.date_end - ident.date_begin);
594 strbuf_addch(&date_buf, ' ');
595 strbuf_add(&date_buf, ident.tz_begin, ident.tz_end - ident.tz_begin);
596 set_ident_var(&date, strbuf_detach(&date_buf, NULL));
597 }
598 }
599
600 if (force_author) {
601 struct ident_split ident;
602
603 if (split_ident_line(&ident, force_author, strlen(force_author)) < 0)
604 die(_("malformed --author parameter"));
605 set_ident_var(&name, xmemdupz(ident.name_begin, ident.name_end - ident.name_begin));
606 set_ident_var(&email, xmemdupz(ident.mail_begin, ident.mail_end - ident.mail_begin));
607 }
608
609 if (force_date) {
610 struct strbuf date_buf = STRBUF_INIT;
611 if (parse_force_date(force_date, &date_buf))
612 die(_("invalid date format: %s"), force_date);
613 set_ident_var(&date, strbuf_detach(&date_buf, NULL));
614 }
615
616 strbuf_addstr(author_ident, fmt_ident(name, email, date, IDENT_STRICT));
617 assert_split_ident(&author, author_ident);
618 export_one("GIT_AUTHOR_NAME", author.name_begin, author.name_end, 0);
619 export_one("GIT_AUTHOR_EMAIL", author.mail_begin, author.mail_end, 0);
620 export_one("GIT_AUTHOR_DATE", author.date_begin, author.tz_end, '@');
621 free(name);
622 free(email);
623 free(date);
624}
625
626static int author_date_is_interesting(void)
627{
628 return author_message || force_date;
629}
630
631static void adjust_comment_line_char(const struct strbuf *sb)
632{
633 char candidates[] = "#;@!$%^&|:";
634 char *candidate;
635 const char *p;
636
637 comment_line_char = candidates[0];
638 if (!memchr(sb->buf, comment_line_char, sb->len))
639 return;
640
641 p = sb->buf;
642 candidate = strchr(candidates, *p);
643 if (candidate)
644 *candidate = ' ';
645 for (p = sb->buf; *p; p++) {
646 if ((p[0] == '\n' || p[0] == '\r') && p[1]) {
647 candidate = strchr(candidates, p[1]);
648 if (candidate)
649 *candidate = ' ';
650 }
651 }
652
653 for (p = candidates; *p == ' '; p++)
654 ;
655 if (!*p)
656 die(_("unable to select a comment character that is not used\n"
657 "in the current commit message"));
658 comment_line_char = *p;
659}
660
661static int prepare_to_commit(const char *index_file, const char *prefix,
662 struct commit *current_head,
663 struct wt_status *s,
664 struct strbuf *author_ident)
665{
666 struct stat statbuf;
667 struct strbuf committer_ident = STRBUF_INIT;
668 int commitable;
669 struct strbuf sb = STRBUF_INIT;
670 const char *hook_arg1 = NULL;
671 const char *hook_arg2 = NULL;
672 int clean_message_contents = (cleanup_mode != CLEANUP_NONE);
673 int old_display_comment_prefix;
674
675 /* This checks and barfs if author is badly specified */
676 determine_author_info(author_ident);
677
678 if (!no_verify && run_commit_hook(use_editor, index_file, "pre-commit", NULL))
679 return 0;
680
681 if (squash_message) {
682 /*
683 * Insert the proper subject line before other commit
684 * message options add their content.
685 */
686 if (use_message && !strcmp(use_message, squash_message))
687 strbuf_addstr(&sb, "squash! ");
688 else {
689 struct pretty_print_context ctx = {0};
690 struct commit *c;
691 c = lookup_commit_reference_by_name(squash_message);
692 if (!c)
693 die(_("could not lookup commit %s"), squash_message);
694 ctx.output_encoding = get_commit_output_encoding();
695 format_commit_message(c, "squash! %s\n\n", &sb,
696 &ctx);
697 }
698 }
699
700 if (have_option_m) {
701 strbuf_addbuf(&sb, &message);
702 hook_arg1 = "message";
703 } else if (logfile && !strcmp(logfile, "-")) {
704 if (isatty(0))
705 fprintf(stderr, _("(reading log message from standard input)\n"));
706 if (strbuf_read(&sb, 0, 0) < 0)
707 die_errno(_("could not read log from standard input"));
708 hook_arg1 = "message";
709 } else if (logfile) {
710 if (strbuf_read_file(&sb, logfile, 0) < 0)
711 die_errno(_("could not read log file '%s'"),
712 logfile);
713 hook_arg1 = "message";
714 } else if (use_message) {
715 char *buffer;
716 buffer = strstr(use_message_buffer, "\n\n");
717 if (buffer)
718 strbuf_addstr(&sb, skip_blank_lines(buffer + 2));
719 hook_arg1 = "commit";
720 hook_arg2 = use_message;
721 } else if (fixup_message) {
722 struct pretty_print_context ctx = {0};
723 struct commit *commit;
724 commit = lookup_commit_reference_by_name(fixup_message);
725 if (!commit)
726 die(_("could not lookup commit %s"), fixup_message);
727 ctx.output_encoding = get_commit_output_encoding();
728 format_commit_message(commit, "fixup! %s\n\n",
729 &sb, &ctx);
730 hook_arg1 = "message";
731 } else if (!stat(git_path_merge_msg(), &statbuf)) {
732 /*
733 * prepend SQUASH_MSG here if it exists and a
734 * "merge --squash" was originally performed
735 */
736 if (!stat(git_path_squash_msg(), &statbuf)) {
737 if (strbuf_read_file(&sb, git_path_squash_msg(), 0) < 0)
738 die_errno(_("could not read SQUASH_MSG"));
739 hook_arg1 = "squash";
740 } else
741 hook_arg1 = "merge";
742 if (strbuf_read_file(&sb, git_path_merge_msg(), 0) < 0)
743 die_errno(_("could not read MERGE_MSG"));
744 } else if (!stat(git_path_squash_msg(), &statbuf)) {
745 if (strbuf_read_file(&sb, git_path_squash_msg(), 0) < 0)
746 die_errno(_("could not read SQUASH_MSG"));
747 hook_arg1 = "squash";
748 } else if (template_file) {
749 if (strbuf_read_file(&sb, template_file, 0) < 0)
750 die_errno(_("could not read '%s'"), template_file);
751 hook_arg1 = "template";
752 clean_message_contents = 0;
753 }
754
755 /*
756 * The remaining cases don't modify the template message, but
757 * just set the argument(s) to the prepare-commit-msg hook.
758 */
759 else if (whence == FROM_MERGE)
760 hook_arg1 = "merge";
761 else if (whence == FROM_CHERRY_PICK) {
762 hook_arg1 = "commit";
763 hook_arg2 = "CHERRY_PICK_HEAD";
764 }
765
766 if (squash_message) {
767 /*
768 * If squash_commit was used for the commit subject,
769 * then we're possibly hijacking other commit log options.
770 * Reset the hook args to tell the real story.
771 */
772 hook_arg1 = "message";
773 hook_arg2 = "";
774 }
775
776 s->fp = fopen_for_writing(git_path_commit_editmsg());
777 if (s->fp == NULL)
778 die_errno(_("could not open '%s'"), git_path_commit_editmsg());
779
780 /* Ignore status.displayCommentPrefix: we do need comments in COMMIT_EDITMSG. */
781 old_display_comment_prefix = s->display_comment_prefix;
782 s->display_comment_prefix = 1;
783
784 /*
785 * Most hints are counter-productive when the commit has
786 * already started.
787 */
788 s->hints = 0;
789
790 if (clean_message_contents)
791 strbuf_stripspace(&sb, 0);
792
793 if (signoff)
794 append_signoff(&sb, ignore_non_trailer(sb.buf, sb.len), 0);
795
796 if (fwrite(sb.buf, 1, sb.len, s->fp) < sb.len)
797 die_errno(_("could not write commit template"));
798
799 if (auto_comment_line_char)
800 adjust_comment_line_char(&sb);
801 strbuf_release(&sb);
802
803 /* This checks if committer ident is explicitly given */
804 strbuf_addstr(&committer_ident, git_committer_info(IDENT_STRICT));
805 if (use_editor && include_status) {
806 int ident_shown = 0;
807 int saved_color_setting;
808 struct ident_split ci, ai;
809
810 if (whence != FROM_COMMIT) {
811 if (cleanup_mode == CLEANUP_SCISSORS)
812 wt_status_add_cut_line(s->fp);
813 status_printf_ln(s, GIT_COLOR_NORMAL,
814 whence == FROM_MERGE
815 ? _("\n"
816 "It looks like you may be committing a merge.\n"
817 "If this is not correct, please remove the file\n"
818 " %s\n"
819 "and try again.\n")
820 : _("\n"
821 "It looks like you may be committing a cherry-pick.\n"
822 "If this is not correct, please remove the file\n"
823 " %s\n"
824 "and try again.\n"),
825 whence == FROM_MERGE ?
826 git_path_merge_head() :
827 git_path_cherry_pick_head());
828 }
829
830 fprintf(s->fp, "\n");
831 if (cleanup_mode == CLEANUP_ALL)
832 status_printf(s, GIT_COLOR_NORMAL,
833 _("Please enter the commit message for your changes."
834 " Lines starting\nwith '%c' will be ignored, and an empty"
835 " message aborts the commit.\n"), comment_line_char);
836 else if (cleanup_mode == CLEANUP_SCISSORS && whence == FROM_COMMIT)
837 wt_status_add_cut_line(s->fp);
838 else /* CLEANUP_SPACE, that is. */
839 status_printf(s, GIT_COLOR_NORMAL,
840 _("Please enter the commit message for your changes."
841 " Lines starting\n"
842 "with '%c' will be kept; you may remove them"
843 " yourself if you want to.\n"
844 "An empty message aborts the commit.\n"), comment_line_char);
845 if (only_include_assumed)
846 status_printf_ln(s, GIT_COLOR_NORMAL,
847 "%s", only_include_assumed);
848
849 /*
850 * These should never fail because they come from our own
851 * fmt_ident. They may fail the sane_ident test, but we know
852 * that the name and mail pointers will at least be valid,
853 * which is enough for our tests and printing here.
854 */
855 assert_split_ident(&ai, author_ident);
856 assert_split_ident(&ci, &committer_ident);
857
858 if (ident_cmp(&ai, &ci))
859 status_printf_ln(s, GIT_COLOR_NORMAL,
860 _("%s"
861 "Author: %.*s <%.*s>"),
862 ident_shown++ ? "" : "\n",
863 (int)(ai.name_end - ai.name_begin), ai.name_begin,
864 (int)(ai.mail_end - ai.mail_begin), ai.mail_begin);
865
866 if (author_date_is_interesting())
867 status_printf_ln(s, GIT_COLOR_NORMAL,
868 _("%s"
869 "Date: %s"),
870 ident_shown++ ? "" : "\n",
871 show_ident_date(&ai, DATE_MODE(NORMAL)));
872
873 if (!committer_ident_sufficiently_given())
874 status_printf_ln(s, GIT_COLOR_NORMAL,
875 _("%s"
876 "Committer: %.*s <%.*s>"),
877 ident_shown++ ? "" : "\n",
878 (int)(ci.name_end - ci.name_begin), ci.name_begin,
879 (int)(ci.mail_end - ci.mail_begin), ci.mail_begin);
880
881 if (ident_shown)
882 status_printf_ln(s, GIT_COLOR_NORMAL, "%s", "");
883
884 saved_color_setting = s->use_color;
885 s->use_color = 0;
886 commitable = run_status(s->fp, index_file, prefix, 1, s);
887 s->use_color = saved_color_setting;
888 } else {
889 struct object_id oid;
890 const char *parent = "HEAD";
891
892 if (!active_nr && read_cache() < 0)
893 die(_("Cannot read index"));
894
895 if (amend)
896 parent = "HEAD^1";
897
898 if (get_sha1(parent, oid.hash)) {
899 int i, ita_nr = 0;
900
901 for (i = 0; i < active_nr; i++)
902 if (ce_intent_to_add(active_cache[i]))
903 ita_nr++;
904 commitable = active_nr - ita_nr > 0;
905 } else {
906 /*
907 * Unless the user did explicitly request a submodule
908 * ignore mode by passing a command line option we do
909 * not ignore any changed submodule SHA-1s when
910 * comparing index and parent, no matter what is
911 * configured. Otherwise we won't commit any
912 * submodules which were manually staged, which would
913 * be really confusing.
914 */
915 int diff_flags = DIFF_OPT_OVERRIDE_SUBMODULE_CONFIG;
916 if (ignore_submodule_arg &&
917 !strcmp(ignore_submodule_arg, "all"))
918 diff_flags |= DIFF_OPT_IGNORE_SUBMODULES;
919 commitable = index_differs_from(parent, diff_flags, 1);
920 }
921 }
922 strbuf_release(&committer_ident);
923
924 fclose(s->fp);
925
926 /*
927 * Reject an attempt to record a non-merge empty commit without
928 * explicit --allow-empty. In the cherry-pick case, it may be
929 * empty due to conflict resolution, which the user should okay.
930 */
931 if (!commitable && whence != FROM_MERGE && !allow_empty &&
932 !(amend && is_a_merge(current_head))) {
933 s->display_comment_prefix = old_display_comment_prefix;
934 run_status(stdout, index_file, prefix, 0, s);
935 if (amend)
936 fputs(_(empty_amend_advice), stderr);
937 else if (whence == FROM_CHERRY_PICK) {
938 fputs(_(empty_cherry_pick_advice), stderr);
939 if (!sequencer_in_use)
940 fputs(_(empty_cherry_pick_advice_single), stderr);
941 else
942 fputs(_(empty_cherry_pick_advice_multi), stderr);
943 }
944 return 0;
945 }
946
947 /*
948 * Re-read the index as pre-commit hook could have updated it,
949 * and write it out as a tree. We must do this before we invoke
950 * the editor and after we invoke run_status above.
951 */
952 discard_cache();
953 read_cache_from(index_file);
954 if (update_main_cache_tree(0)) {
955 error(_("Error building trees"));
956 return 0;
957 }
958
959 if (run_commit_hook(use_editor, index_file, "prepare-commit-msg",
960 git_path_commit_editmsg(), hook_arg1, hook_arg2, NULL))
961 return 0;
962
963 if (use_editor) {
964 struct argv_array env = ARGV_ARRAY_INIT;
965
966 argv_array_pushf(&env, "GIT_INDEX_FILE=%s", index_file);
967 if (launch_editor(git_path_commit_editmsg(), NULL, env.argv)) {
968 fprintf(stderr,
969 _("Please supply the message using either -m or -F option.\n"));
970 exit(1);
971 }
972 argv_array_clear(&env);
973 }
974
975 if (!no_verify &&
976 run_commit_hook(use_editor, index_file, "commit-msg", git_path_commit_editmsg(), NULL)) {
977 return 0;
978 }
979
980 return 1;
981}
982
983static int rest_is_empty(struct strbuf *sb, int start)
984{
985 int i, eol;
986 const char *nl;
987
988 /* Check if the rest is just whitespace and Signed-of-by's. */
989 for (i = start; i < sb->len; i++) {
990 nl = memchr(sb->buf + i, '\n', sb->len - i);
991 if (nl)
992 eol = nl - sb->buf;
993 else
994 eol = sb->len;
995
996 if (strlen(sign_off_header) <= eol - i &&
997 starts_with(sb->buf + i, sign_off_header)) {
998 i = eol;
999 continue;
1000 }
1001 while (i < eol)
1002 if (!isspace(sb->buf[i++]))
1003 return 0;
1004 }
1005
1006 return 1;
1007}
1008
1009/*
1010 * Find out if the message in the strbuf contains only whitespace and
1011 * Signed-off-by lines.
1012 */
1013static int message_is_empty(struct strbuf *sb)
1014{
1015 if (cleanup_mode == CLEANUP_NONE && sb->len)
1016 return 0;
1017 return rest_is_empty(sb, 0);
1018}
1019
1020/*
1021 * See if the user edited the message in the editor or left what
1022 * was in the template intact
1023 */
1024static int template_untouched(struct strbuf *sb)
1025{
1026 struct strbuf tmpl = STRBUF_INIT;
1027 const char *start;
1028
1029 if (cleanup_mode == CLEANUP_NONE && sb->len)
1030 return 0;
1031
1032 if (!template_file || strbuf_read_file(&tmpl, template_file, 0) <= 0)
1033 return 0;
1034
1035 strbuf_stripspace(&tmpl, cleanup_mode == CLEANUP_ALL);
1036 if (!skip_prefix(sb->buf, tmpl.buf, &start))
1037 start = sb->buf;
1038 strbuf_release(&tmpl);
1039 return rest_is_empty(sb, start - sb->buf);
1040}
1041
1042static const char *find_author_by_nickname(const char *name)
1043{
1044 struct rev_info revs;
1045 struct commit *commit;
1046 struct strbuf buf = STRBUF_INIT;
1047 struct string_list mailmap = STRING_LIST_INIT_NODUP;
1048 const char *av[20];
1049 int ac = 0;
1050
1051 init_revisions(&revs, NULL);
1052 strbuf_addf(&buf, "--author=%s", name);
1053 av[++ac] = "--all";
1054 av[++ac] = "-i";
1055 av[++ac] = buf.buf;
1056 av[++ac] = NULL;
1057 setup_revisions(ac, av, &revs, NULL);
1058 revs.mailmap = &mailmap;
1059 read_mailmap(revs.mailmap, NULL);
1060
1061 if (prepare_revision_walk(&revs))
1062 die(_("revision walk setup failed"));
1063 commit = get_revision(&revs);
1064 if (commit) {
1065 struct pretty_print_context ctx = {0};
1066 ctx.date_mode.type = DATE_NORMAL;
1067 strbuf_release(&buf);
1068 format_commit_message(commit, "%aN <%aE>", &buf, &ctx);
1069 clear_mailmap(&mailmap);
1070 return strbuf_detach(&buf, NULL);
1071 }
1072 die(_("--author '%s' is not 'Name <email>' and matches no existing author"), name);
1073}
1074
1075
1076static void handle_untracked_files_arg(struct wt_status *s)
1077{
1078 if (!untracked_files_arg)
1079 ; /* default already initialized */
1080 else if (!strcmp(untracked_files_arg, "no"))
1081 s->show_untracked_files = SHOW_NO_UNTRACKED_FILES;
1082 else if (!strcmp(untracked_files_arg, "normal"))
1083 s->show_untracked_files = SHOW_NORMAL_UNTRACKED_FILES;
1084 else if (!strcmp(untracked_files_arg, "all"))
1085 s->show_untracked_files = SHOW_ALL_UNTRACKED_FILES;
1086 else
1087 die(_("Invalid untracked files mode '%s'"), untracked_files_arg);
1088}
1089
1090static const char *read_commit_message(const char *name)
1091{
1092 const char *out_enc;
1093 struct commit *commit;
1094
1095 commit = lookup_commit_reference_by_name(name);
1096 if (!commit)
1097 die(_("could not lookup commit %s"), name);
1098 out_enc = get_commit_output_encoding();
1099 return logmsg_reencode(commit, NULL, out_enc);
1100}
1101
1102/*
1103 * Enumerate what needs to be propagated when --porcelain
1104 * is not in effect here.
1105 */
1106static struct status_deferred_config {
1107 enum wt_status_format status_format;
1108 int show_branch;
1109} status_deferred_config = {
1110 STATUS_FORMAT_UNSPECIFIED,
1111 -1 /* unspecified */
1112};
1113
1114static void finalize_deferred_config(struct wt_status *s)
1115{
1116 int use_deferred_config = (status_format != STATUS_FORMAT_PORCELAIN &&
1117 status_format != STATUS_FORMAT_PORCELAIN_V2 &&
1118 !s->null_termination);
1119
1120 if (s->null_termination) {
1121 if (status_format == STATUS_FORMAT_NONE ||
1122 status_format == STATUS_FORMAT_UNSPECIFIED)
1123 status_format = STATUS_FORMAT_PORCELAIN;
1124 else if (status_format == STATUS_FORMAT_LONG)
1125 die(_("--long and -z are incompatible"));
1126 }
1127
1128 if (use_deferred_config && status_format == STATUS_FORMAT_UNSPECIFIED)
1129 status_format = status_deferred_config.status_format;
1130 if (status_format == STATUS_FORMAT_UNSPECIFIED)
1131 status_format = STATUS_FORMAT_NONE;
1132
1133 if (use_deferred_config && s->show_branch < 0)
1134 s->show_branch = status_deferred_config.show_branch;
1135 if (s->show_branch < 0)
1136 s->show_branch = 0;
1137}
1138
1139static int parse_and_validate_options(int argc, const char *argv[],
1140 const struct option *options,
1141 const char * const usage[],
1142 const char *prefix,
1143 struct commit *current_head,
1144 struct wt_status *s)
1145{
1146 int f = 0;
1147
1148 argc = parse_options(argc, argv, prefix, options, usage, 0);
1149 finalize_deferred_config(s);
1150
1151 if (force_author && !strchr(force_author, '>'))
1152 force_author = find_author_by_nickname(force_author);
1153
1154 if (force_author && renew_authorship)
1155 die(_("Using both --reset-author and --author does not make sense"));
1156
1157 if (logfile || have_option_m || use_message || fixup_message)
1158 use_editor = 0;
1159 if (0 <= edit_flag)
1160 use_editor = edit_flag;
1161
1162 /* Sanity check options */
1163 if (amend && !current_head)
1164 die(_("You have nothing to amend."));
1165 if (amend && whence != FROM_COMMIT) {
1166 if (whence == FROM_MERGE)
1167 die(_("You are in the middle of a merge -- cannot amend."));
1168 else if (whence == FROM_CHERRY_PICK)
1169 die(_("You are in the middle of a cherry-pick -- cannot amend."));
1170 }
1171 if (fixup_message && squash_message)
1172 die(_("Options --squash and --fixup cannot be used together"));
1173 if (use_message)
1174 f++;
1175 if (edit_message)
1176 f++;
1177 if (fixup_message)
1178 f++;
1179 if (logfile)
1180 f++;
1181 if (f > 1)
1182 die(_("Only one of -c/-C/-F/--fixup can be used."));
1183 if (have_option_m && f > 0)
1184 die((_("Option -m cannot be combined with -c/-C/-F/--fixup.")));
1185 if (f || have_option_m)
1186 template_file = NULL;
1187 if (edit_message)
1188 use_message = edit_message;
1189 if (amend && !use_message && !fixup_message)
1190 use_message = "HEAD";
1191 if (!use_message && whence != FROM_CHERRY_PICK && renew_authorship)
1192 die(_("--reset-author can be used only with -C, -c or --amend."));
1193 if (use_message) {
1194 use_message_buffer = read_commit_message(use_message);
1195 if (!renew_authorship) {
1196 author_message = use_message;
1197 author_message_buffer = use_message_buffer;
1198 }
1199 }
1200 if (whence == FROM_CHERRY_PICK && !renew_authorship) {
1201 author_message = "CHERRY_PICK_HEAD";
1202 author_message_buffer = read_commit_message(author_message);
1203 }
1204
1205 if (patch_interactive)
1206 interactive = 1;
1207
1208 if (also + only + all + interactive > 1)
1209 die(_("Only one of --include/--only/--all/--interactive/--patch can be used."));
1210 if (argc == 0 && (also || (only && !amend && !allow_empty)))
1211 die(_("No paths with --include/--only does not make sense."));
1212 if (argc > 0 && !also && !only)
1213 only_include_assumed = _("Explicit paths specified without -i or -o; assuming --only paths...");
1214 if (!cleanup_arg || !strcmp(cleanup_arg, "default"))
1215 cleanup_mode = use_editor ? CLEANUP_ALL : CLEANUP_SPACE;
1216 else if (!strcmp(cleanup_arg, "verbatim"))
1217 cleanup_mode = CLEANUP_NONE;
1218 else if (!strcmp(cleanup_arg, "whitespace"))
1219 cleanup_mode = CLEANUP_SPACE;
1220 else if (!strcmp(cleanup_arg, "strip"))
1221 cleanup_mode = CLEANUP_ALL;
1222 else if (!strcmp(cleanup_arg, "scissors"))
1223 cleanup_mode = use_editor ? CLEANUP_SCISSORS : CLEANUP_SPACE;
1224 else
1225 die(_("Invalid cleanup mode %s"), cleanup_arg);
1226
1227 handle_untracked_files_arg(s);
1228
1229 if (all && argc > 0)
1230 die(_("Paths with -a does not make sense."));
1231
1232 if (status_format != STATUS_FORMAT_NONE)
1233 dry_run = 1;
1234
1235 return argc;
1236}
1237
1238static int dry_run_commit(int argc, const char **argv, const char *prefix,
1239 const struct commit *current_head, struct wt_status *s)
1240{
1241 int commitable;
1242 const char *index_file;
1243
1244 index_file = prepare_index(argc, argv, prefix, current_head, 1);
1245 commitable = run_status(stdout, index_file, prefix, 0, s);
1246 rollback_index_files();
1247
1248 return commitable ? 0 : 1;
1249}
1250
1251static int parse_status_slot(const char *slot)
1252{
1253 if (!strcasecmp(slot, "header"))
1254 return WT_STATUS_HEADER;
1255 if (!strcasecmp(slot, "branch"))
1256 return WT_STATUS_ONBRANCH;
1257 if (!strcasecmp(slot, "updated") || !strcasecmp(slot, "added"))
1258 return WT_STATUS_UPDATED;
1259 if (!strcasecmp(slot, "changed"))
1260 return WT_STATUS_CHANGED;
1261 if (!strcasecmp(slot, "untracked"))
1262 return WT_STATUS_UNTRACKED;
1263 if (!strcasecmp(slot, "nobranch"))
1264 return WT_STATUS_NOBRANCH;
1265 if (!strcasecmp(slot, "unmerged"))
1266 return WT_STATUS_UNMERGED;
1267 if (!strcasecmp(slot, "localBranch"))
1268 return WT_STATUS_LOCAL_BRANCH;
1269 if (!strcasecmp(slot, "remoteBranch"))
1270 return WT_STATUS_REMOTE_BRANCH;
1271 return -1;
1272}
1273
1274static int git_status_config(const char *k, const char *v, void *cb)
1275{
1276 struct wt_status *s = cb;
1277 const char *slot_name;
1278
1279 if (starts_with(k, "column."))
1280 return git_column_config(k, v, "status", &s->colopts);
1281 if (!strcmp(k, "status.submodulesummary")) {
1282 int is_bool;
1283 s->submodule_summary = git_config_bool_or_int(k, v, &is_bool);
1284 if (is_bool && s->submodule_summary)
1285 s->submodule_summary = -1;
1286 return 0;
1287 }
1288 if (!strcmp(k, "status.short")) {
1289 if (git_config_bool(k, v))
1290 status_deferred_config.status_format = STATUS_FORMAT_SHORT;
1291 else
1292 status_deferred_config.status_format = STATUS_FORMAT_NONE;
1293 return 0;
1294 }
1295 if (!strcmp(k, "status.branch")) {
1296 status_deferred_config.show_branch = git_config_bool(k, v);
1297 return 0;
1298 }
1299 if (!strcmp(k, "status.color") || !strcmp(k, "color.status")) {
1300 s->use_color = git_config_colorbool(k, v);
1301 return 0;
1302 }
1303 if (!strcmp(k, "status.displaycommentprefix")) {
1304 s->display_comment_prefix = git_config_bool(k, v);
1305 return 0;
1306 }
1307 if (skip_prefix(k, "status.color.", &slot_name) ||
1308 skip_prefix(k, "color.status.", &slot_name)) {
1309 int slot = parse_status_slot(slot_name);
1310 if (slot < 0)
1311 return 0;
1312 if (!v)
1313 return config_error_nonbool(k);
1314 return color_parse(v, s->color_palette[slot]);
1315 }
1316 if (!strcmp(k, "status.relativepaths")) {
1317 s->relative_paths = git_config_bool(k, v);
1318 return 0;
1319 }
1320 if (!strcmp(k, "status.showuntrackedfiles")) {
1321 if (!v)
1322 return config_error_nonbool(k);
1323 else if (!strcmp(v, "no"))
1324 s->show_untracked_files = SHOW_NO_UNTRACKED_FILES;
1325 else if (!strcmp(v, "normal"))
1326 s->show_untracked_files = SHOW_NORMAL_UNTRACKED_FILES;
1327 else if (!strcmp(v, "all"))
1328 s->show_untracked_files = SHOW_ALL_UNTRACKED_FILES;
1329 else
1330 return error(_("Invalid untracked files mode '%s'"), v);
1331 return 0;
1332 }
1333 return git_diff_ui_config(k, v, NULL);
1334}
1335
1336int cmd_status(int argc, const char **argv, const char *prefix)
1337{
1338 static struct wt_status s;
1339 int fd;
1340 struct object_id oid;
1341 static struct option builtin_status_options[] = {
1342 OPT__VERBOSE(&verbose, N_("be verbose")),
1343 OPT_SET_INT('s', "short", &status_format,
1344 N_("show status concisely"), STATUS_FORMAT_SHORT),
1345 OPT_BOOL('b', "branch", &s.show_branch,
1346 N_("show branch information")),
1347 { OPTION_CALLBACK, 0, "porcelain", &status_format,
1348 N_("version"), N_("machine-readable output"),
1349 PARSE_OPT_OPTARG, opt_parse_porcelain },
1350 OPT_SET_INT(0, "long", &status_format,
1351 N_("show status in long format (default)"),
1352 STATUS_FORMAT_LONG),
1353 OPT_BOOL('z', "null", &s.null_termination,
1354 N_("terminate entries with NUL")),
1355 { OPTION_STRING, 'u', "untracked-files", &untracked_files_arg,
1356 N_("mode"),
1357 N_("show untracked files, optional modes: all, normal, no. (Default: all)"),
1358 PARSE_OPT_OPTARG, NULL, (intptr_t)"all" },
1359 OPT_BOOL(0, "ignored", &show_ignored_in_status,
1360 N_("show ignored files")),
1361 { OPTION_STRING, 0, "ignore-submodules", &ignore_submodule_arg, N_("when"),
1362 N_("ignore changes to submodules, optional when: all, dirty, untracked. (Default: all)"),
1363 PARSE_OPT_OPTARG, NULL, (intptr_t)"all" },
1364 OPT_COLUMN(0, "column", &s.colopts, N_("list untracked files in columns")),
1365 OPT_END(),
1366 };
1367
1368 if (argc == 2 && !strcmp(argv[1], "-h"))
1369 usage_with_options(builtin_status_usage, builtin_status_options);
1370
1371 status_init_config(&s, git_status_config);
1372 argc = parse_options(argc, argv, prefix,
1373 builtin_status_options,
1374 builtin_status_usage, 0);
1375 finalize_colopts(&s.colopts, -1);
1376 finalize_deferred_config(&s);
1377
1378 handle_untracked_files_arg(&s);
1379 if (show_ignored_in_status)
1380 s.show_ignored_files = 1;
1381 parse_pathspec(&s.pathspec, 0,
1382 PATHSPEC_PREFER_FULL,
1383 prefix, argv);
1384
1385 read_cache_preload(&s.pathspec);
1386 refresh_index(&the_index, REFRESH_QUIET|REFRESH_UNMERGED, &s.pathspec, NULL, NULL);
1387
1388 fd = hold_locked_index(&index_lock, 0);
1389
1390 s.is_initial = get_sha1(s.reference, oid.hash) ? 1 : 0;
1391 if (!s.is_initial)
1392 hashcpy(s.sha1_commit, oid.hash);
1393
1394 s.ignore_submodule_arg = ignore_submodule_arg;
1395 s.status_format = status_format;
1396 s.verbose = verbose;
1397
1398 wt_status_collect(&s);
1399
1400 if (0 <= fd)
1401 update_index_if_able(&the_index, &index_lock);
1402
1403 if (s.relative_paths)
1404 s.prefix = prefix;
1405
1406 wt_status_print(&s);
1407 return 0;
1408}
1409
1410static const char *implicit_ident_advice(void)
1411{
1412 char *user_config = expand_user_path("~/.gitconfig", 0);
1413 char *xdg_config = xdg_config_home("config");
1414 int config_exists = file_exists(user_config) || file_exists(xdg_config);
1415
1416 free(user_config);
1417 free(xdg_config);
1418
1419 if (config_exists)
1420 return _(implicit_ident_advice_config);
1421 else
1422 return _(implicit_ident_advice_noconfig);
1423
1424}
1425
1426static void print_summary(const char *prefix, const struct object_id *oid,
1427 int initial_commit)
1428{
1429 struct rev_info rev;
1430 struct commit *commit;
1431 struct strbuf format = STRBUF_INIT;
1432 struct object_id junk_oid;
1433 const char *head;
1434 struct pretty_print_context pctx = {0};
1435 struct strbuf author_ident = STRBUF_INIT;
1436 struct strbuf committer_ident = STRBUF_INIT;
1437
1438 commit = lookup_commit(oid);
1439 if (!commit)
1440 die(_("couldn't look up newly created commit"));
1441 if (parse_commit(commit))
1442 die(_("could not parse newly created commit"));
1443
1444 strbuf_addstr(&format, "format:%h] %s");
1445
1446 format_commit_message(commit, "%an <%ae>", &author_ident, &pctx);
1447 format_commit_message(commit, "%cn <%ce>", &committer_ident, &pctx);
1448 if (strbuf_cmp(&author_ident, &committer_ident)) {
1449 strbuf_addstr(&format, "\n Author: ");
1450 strbuf_addbuf_percentquote(&format, &author_ident);
1451 }
1452 if (author_date_is_interesting()) {
1453 struct strbuf date = STRBUF_INIT;
1454 format_commit_message(commit, "%ad", &date, &pctx);
1455 strbuf_addstr(&format, "\n Date: ");
1456 strbuf_addbuf_percentquote(&format, &date);
1457 strbuf_release(&date);
1458 }
1459 if (!committer_ident_sufficiently_given()) {
1460 strbuf_addstr(&format, "\n Committer: ");
1461 strbuf_addbuf_percentquote(&format, &committer_ident);
1462 if (advice_implicit_identity) {
1463 strbuf_addch(&format, '\n');
1464 strbuf_addstr(&format, implicit_ident_advice());
1465 }
1466 }
1467 strbuf_release(&author_ident);
1468 strbuf_release(&committer_ident);
1469
1470 init_revisions(&rev, prefix);
1471 setup_revisions(0, NULL, &rev, NULL);
1472
1473 rev.diff = 1;
1474 rev.diffopt.output_format =
1475 DIFF_FORMAT_SHORTSTAT | DIFF_FORMAT_SUMMARY;
1476
1477 rev.verbose_header = 1;
1478 rev.show_root_diff = 1;
1479 get_commit_format(format.buf, &rev);
1480 rev.always_show_header = 0;
1481 rev.diffopt.detect_rename = 1;
1482 rev.diffopt.break_opt = 0;
1483 diff_setup_done(&rev.diffopt);
1484
1485 head = resolve_ref_unsafe("HEAD", 0, junk_oid.hash, NULL);
1486 if (!strcmp(head, "HEAD"))
1487 head = _("detached HEAD");
1488 else
1489 skip_prefix(head, "refs/heads/", &head);
1490 printf("[%s%s ", head, initial_commit ? _(" (root-commit)") : "");
1491
1492 if (!log_tree_commit(&rev, commit)) {
1493 rev.always_show_header = 1;
1494 rev.use_terminator = 1;
1495 log_tree_commit(&rev, commit);
1496 }
1497
1498 strbuf_release(&format);
1499}
1500
1501static int git_commit_config(const char *k, const char *v, void *cb)
1502{
1503 struct wt_status *s = cb;
1504 int status;
1505
1506 if (!strcmp(k, "commit.template"))
1507 return git_config_pathname(&template_file, k, v);
1508 if (!strcmp(k, "commit.status")) {
1509 include_status = git_config_bool(k, v);
1510 return 0;
1511 }
1512 if (!strcmp(k, "commit.cleanup"))
1513 return git_config_string(&cleanup_arg, k, v);
1514 if (!strcmp(k, "commit.gpgsign")) {
1515 sign_commit = git_config_bool(k, v) ? "" : NULL;
1516 return 0;
1517 }
1518 if (!strcmp(k, "commit.verbose")) {
1519 int is_bool;
1520 config_commit_verbose = git_config_bool_or_int(k, v, &is_bool);
1521 return 0;
1522 }
1523
1524 status = git_gpg_config(k, v, NULL);
1525 if (status)
1526 return status;
1527 return git_status_config(k, v, s);
1528}
1529
1530static int run_rewrite_hook(const struct object_id *oldoid,
1531 const struct object_id *newoid)
1532{
1533 struct child_process proc = CHILD_PROCESS_INIT;
1534 const char *argv[3];
1535 int code;
1536 struct strbuf sb = STRBUF_INIT;
1537
1538 argv[0] = find_hook("post-rewrite");
1539 if (!argv[0])
1540 return 0;
1541
1542 argv[1] = "amend";
1543 argv[2] = NULL;
1544
1545 proc.argv = argv;
1546 proc.in = -1;
1547 proc.stdout_to_stderr = 1;
1548
1549 code = start_command(&proc);
1550 if (code)
1551 return code;
1552 strbuf_addf(&sb, "%s %s\n", oid_to_hex(oldoid), oid_to_hex(newoid));
1553 sigchain_push(SIGPIPE, SIG_IGN);
1554 write_in_full(proc.in, sb.buf, sb.len);
1555 close(proc.in);
1556 strbuf_release(&sb);
1557 sigchain_pop(SIGPIPE);
1558 return finish_command(&proc);
1559}
1560
1561int run_commit_hook(int editor_is_used, const char *index_file, const char *name, ...)
1562{
1563 struct argv_array hook_env = ARGV_ARRAY_INIT;
1564 va_list args;
1565 int ret;
1566
1567 argv_array_pushf(&hook_env, "GIT_INDEX_FILE=%s", index_file);
1568
1569 /*
1570 * Let the hook know that no editor will be launched.
1571 */
1572 if (!editor_is_used)
1573 argv_array_push(&hook_env, "GIT_EDITOR=:");
1574
1575 va_start(args, name);
1576 ret = run_hook_ve(hook_env.argv,name, args);
1577 va_end(args);
1578 argv_array_clear(&hook_env);
1579
1580 return ret;
1581}
1582
1583int cmd_commit(int argc, const char **argv, const char *prefix)
1584{
1585 static struct wt_status s;
1586 static struct option builtin_commit_options[] = {
1587 OPT__QUIET(&quiet, N_("suppress summary after successful commit")),
1588 OPT__VERBOSE(&verbose, N_("show diff in commit message template")),
1589
1590 OPT_GROUP(N_("Commit message options")),
1591 OPT_FILENAME('F', "file", &logfile, N_("read message from file")),
1592 OPT_STRING(0, "author", &force_author, N_("author"), N_("override author for commit")),
1593 OPT_STRING(0, "date", &force_date, N_("date"), N_("override date for commit")),
1594 OPT_CALLBACK('m', "message", &message, N_("message"), N_("commit message"), opt_parse_m),
1595 OPT_STRING('c', "reedit-message", &edit_message, N_("commit"), N_("reuse and edit message from specified commit")),
1596 OPT_STRING('C', "reuse-message", &use_message, N_("commit"), N_("reuse message from specified commit")),
1597 OPT_STRING(0, "fixup", &fixup_message, N_("commit"), N_("use autosquash formatted message to fixup specified commit")),
1598 OPT_STRING(0, "squash", &squash_message, N_("commit"), N_("use autosquash formatted message to squash specified commit")),
1599 OPT_BOOL(0, "reset-author", &renew_authorship, N_("the commit is authored by me now (used with -C/-c/--amend)")),
1600 OPT_BOOL('s', "signoff", &signoff, N_("add Signed-off-by:")),
1601 OPT_FILENAME('t', "template", &template_file, N_("use specified template file")),
1602 OPT_BOOL('e', "edit", &edit_flag, N_("force edit of commit")),
1603 OPT_STRING(0, "cleanup", &cleanup_arg, N_("default"), N_("how to strip spaces and #comments from message")),
1604 OPT_BOOL(0, "status", &include_status, N_("include status in commit message template")),
1605 { OPTION_STRING, 'S', "gpg-sign", &sign_commit, N_("key-id"),
1606 N_("GPG sign commit"), PARSE_OPT_OPTARG, NULL, (intptr_t) "" },
1607 /* end commit message options */
1608
1609 OPT_GROUP(N_("Commit contents options")),
1610 OPT_BOOL('a', "all", &all, N_("commit all changed files")),
1611 OPT_BOOL('i', "include", &also, N_("add specified files to index for commit")),
1612 OPT_BOOL(0, "interactive", &interactive, N_("interactively add files")),
1613 OPT_BOOL('p', "patch", &patch_interactive, N_("interactively add changes")),
1614 OPT_BOOL('o', "only", &only, N_("commit only specified files")),
1615 OPT_BOOL('n', "no-verify", &no_verify, N_("bypass pre-commit and commit-msg hooks")),
1616 OPT_BOOL(0, "dry-run", &dry_run, N_("show what would be committed")),
1617 OPT_SET_INT(0, "short", &status_format, N_("show status concisely"),
1618 STATUS_FORMAT_SHORT),
1619 OPT_BOOL(0, "branch", &s.show_branch, N_("show branch information")),
1620 OPT_SET_INT(0, "porcelain", &status_format,
1621 N_("machine-readable output"), STATUS_FORMAT_PORCELAIN),
1622 OPT_SET_INT(0, "long", &status_format,
1623 N_("show status in long format (default)"),
1624 STATUS_FORMAT_LONG),
1625 OPT_BOOL('z', "null", &s.null_termination,
1626 N_("terminate entries with NUL")),
1627 OPT_BOOL(0, "amend", &amend, N_("amend previous commit")),
1628 OPT_BOOL(0, "no-post-rewrite", &no_post_rewrite, N_("bypass post-rewrite hook")),
1629 { OPTION_STRING, 'u', "untracked-files", &untracked_files_arg, N_("mode"), N_("show untracked files, optional modes: all, normal, no. (Default: all)"), PARSE_OPT_OPTARG, NULL, (intptr_t)"all" },
1630 /* end commit contents options */
1631
1632 OPT_HIDDEN_BOOL(0, "allow-empty", &allow_empty,
1633 N_("ok to record an empty change")),
1634 OPT_HIDDEN_BOOL(0, "allow-empty-message", &allow_empty_message,
1635 N_("ok to record a change with an empty message")),
1636
1637 OPT_END()
1638 };
1639
1640 struct strbuf sb = STRBUF_INIT;
1641 struct strbuf author_ident = STRBUF_INIT;
1642 const char *index_file, *reflog_msg;
1643 char *nl;
1644 struct object_id oid;
1645 struct commit_list *parents = NULL;
1646 struct stat statbuf;
1647 struct commit *current_head = NULL;
1648 struct commit_extra_header *extra = NULL;
1649 struct ref_transaction *transaction;
1650 struct strbuf err = STRBUF_INIT;
1651
1652 if (argc == 2 && !strcmp(argv[1], "-h"))
1653 usage_with_options(builtin_commit_usage, builtin_commit_options);
1654
1655 status_init_config(&s, git_commit_config);
1656 status_format = STATUS_FORMAT_NONE; /* Ignore status.short */
1657 s.colopts = 0;
1658
1659 if (get_sha1("HEAD", oid.hash))
1660 current_head = NULL;
1661 else {
1662 current_head = lookup_commit_or_die(&oid, "HEAD");
1663 if (parse_commit(current_head))
1664 die(_("could not parse HEAD commit"));
1665 }
1666 verbose = -1; /* unspecified */
1667 argc = parse_and_validate_options(argc, argv, builtin_commit_options,
1668 builtin_commit_usage,
1669 prefix, current_head, &s);
1670 if (verbose == -1)
1671 verbose = (config_commit_verbose < 0) ? 0 : config_commit_verbose;
1672
1673 if (dry_run)
1674 return dry_run_commit(argc, argv, prefix, current_head, &s);
1675 index_file = prepare_index(argc, argv, prefix, current_head, 0);
1676
1677 /* Set up everything for writing the commit object. This includes
1678 running hooks, writing the trees, and interacting with the user. */
1679 if (!prepare_to_commit(index_file, prefix,
1680 current_head, &s, &author_ident)) {
1681 rollback_index_files();
1682 return 1;
1683 }
1684
1685 /* Determine parents */
1686 reflog_msg = getenv("GIT_REFLOG_ACTION");
1687 if (!current_head) {
1688 if (!reflog_msg)
1689 reflog_msg = "commit (initial)";
1690 } else if (amend) {
1691 if (!reflog_msg)
1692 reflog_msg = "commit (amend)";
1693 parents = copy_commit_list(current_head->parents);
1694 } else if (whence == FROM_MERGE) {
1695 struct strbuf m = STRBUF_INIT;
1696 FILE *fp;
1697 int allow_fast_forward = 1;
1698 struct commit_list **pptr = &parents;
1699
1700 if (!reflog_msg)
1701 reflog_msg = "commit (merge)";
1702 pptr = commit_list_append(current_head, pptr);
1703 fp = xfopen(git_path_merge_head(), "r");
1704 while (strbuf_getline_lf(&m, fp) != EOF) {
1705 struct commit *parent;
1706
1707 parent = get_merge_parent(m.buf);
1708 if (!parent)
1709 die(_("Corrupt MERGE_HEAD file (%s)"), m.buf);
1710 pptr = commit_list_append(parent, pptr);
1711 }
1712 fclose(fp);
1713 strbuf_release(&m);
1714 if (!stat(git_path_merge_mode(), &statbuf)) {
1715 if (strbuf_read_file(&sb, git_path_merge_mode(), 0) < 0)
1716 die_errno(_("could not read MERGE_MODE"));
1717 if (!strcmp(sb.buf, "no-ff"))
1718 allow_fast_forward = 0;
1719 }
1720 if (allow_fast_forward)
1721 parents = reduce_heads(parents);
1722 } else {
1723 if (!reflog_msg)
1724 reflog_msg = (whence == FROM_CHERRY_PICK)
1725 ? "commit (cherry-pick)"
1726 : "commit";
1727 commit_list_insert(current_head, &parents);
1728 }
1729
1730 /* Finally, get the commit message */
1731 strbuf_reset(&sb);
1732 if (strbuf_read_file(&sb, git_path_commit_editmsg(), 0) < 0) {
1733 int saved_errno = errno;
1734 rollback_index_files();
1735 die(_("could not read commit message: %s"), strerror(saved_errno));
1736 }
1737
1738 if (verbose || /* Truncate the message just before the diff, if any. */
1739 cleanup_mode == CLEANUP_SCISSORS)
1740 strbuf_setlen(&sb, wt_status_locate_end(sb.buf, sb.len));
1741
1742 if (cleanup_mode != CLEANUP_NONE)
1743 strbuf_stripspace(&sb, cleanup_mode == CLEANUP_ALL);
1744 if (template_untouched(&sb) && !allow_empty_message) {
1745 rollback_index_files();
1746 fprintf(stderr, _("Aborting commit; you did not edit the message.\n"));
1747 exit(1);
1748 }
1749 if (message_is_empty(&sb) && !allow_empty_message) {
1750 rollback_index_files();
1751 fprintf(stderr, _("Aborting commit due to empty commit message.\n"));
1752 exit(1);
1753 }
1754
1755 if (amend) {
1756 const char *exclude_gpgsig[2] = { "gpgsig", NULL };
1757 extra = read_commit_extra_headers(current_head, exclude_gpgsig);
1758 } else {
1759 struct commit_extra_header **tail = &extra;
1760 append_merge_tag_headers(parents, &tail);
1761 }
1762
1763 if (commit_tree_extended(sb.buf, sb.len, active_cache_tree->oid.hash,
1764 parents, oid.hash, author_ident.buf, sign_commit, extra)) {
1765 rollback_index_files();
1766 die(_("failed to write commit object"));
1767 }
1768 strbuf_release(&author_ident);
1769 free_commit_extra_headers(extra);
1770
1771 nl = strchr(sb.buf, '\n');
1772 if (nl)
1773 strbuf_setlen(&sb, nl + 1 - sb.buf);
1774 else
1775 strbuf_addch(&sb, '\n');
1776 strbuf_insert(&sb, 0, reflog_msg, strlen(reflog_msg));
1777 strbuf_insert(&sb, strlen(reflog_msg), ": ", 2);
1778
1779 transaction = ref_transaction_begin(&err);
1780 if (!transaction ||
1781 ref_transaction_update(transaction, "HEAD", oid.hash,
1782 current_head
1783 ? current_head->object.oid.hash : null_sha1,
1784 0, sb.buf, &err) ||
1785 ref_transaction_commit(transaction, &err)) {
1786 rollback_index_files();
1787 die("%s", err.buf);
1788 }
1789 ref_transaction_free(transaction);
1790
1791 unlink(git_path_cherry_pick_head());
1792 unlink(git_path_revert_head());
1793 unlink(git_path_merge_head());
1794 unlink(git_path_merge_msg());
1795 unlink(git_path_merge_mode());
1796 unlink(git_path_squash_msg());
1797
1798 if (commit_index_files())
1799 die (_("Repository has been updated, but unable to write\n"
1800 "new_index file. Check that disk is not full and quota is\n"
1801 "not exceeded, and then \"git reset HEAD\" to recover."));
1802
1803 rerere(0);
1804 run_commit_hook(use_editor, get_index_file(), "post-commit", NULL);
1805 if (amend && !no_post_rewrite) {
1806 struct notes_rewrite_cfg *cfg;
1807 cfg = init_copy_notes_for_rewrite("amend");
1808 if (cfg) {
1809 /* we are amending, so current_head is not NULL */
1810 copy_note_for_rewrite(cfg, ¤t_head->object.oid, &oid);
1811 finish_copy_notes_for_rewrite(cfg, "Notes added by 'git commit --amend'");
1812 }
1813 run_rewrite_hook(¤t_head->object.oid, &oid);
1814 }
1815 if (!quiet)
1816 print_summary(prefix, &oid, !current_head);
1817
1818 strbuf_release(&err);
1819 return 0;
1820}