5 #include "object-store.h"
 
  10 #include "run-command.h"
 
  13 #include "cache-tree.h"
 
  17 #include "merge-recursive.h"
 
  23 #include "wt-status.h"
 
  25 #include "notes-utils.h"
 
  27 #include "unpack-trees.h"
 
  31 #include "commit-slab.h"
 
  33 #include "commit-reach.h"
 
  34 #include "rebase-interactive.h"
 
  37 #define GIT_REFLOG_ACTION "GIT_REFLOG_ACTION"
 
  39 static const char sign_off_header[] = "Signed-off-by: ";
 
  40 static const char cherry_picked_prefix[] = "(cherry picked from commit ";
 
  42 GIT_PATH_FUNC(git_path_commit_editmsg, "COMMIT_EDITMSG")
 
  44 static GIT_PATH_FUNC(git_path_seq_dir, "sequencer")
 
  46 static GIT_PATH_FUNC(git_path_todo_file, "sequencer/todo")
 
  47 static GIT_PATH_FUNC(git_path_opts_file, "sequencer/opts")
 
  48 static GIT_PATH_FUNC(git_path_head_file, "sequencer/head")
 
  49 static GIT_PATH_FUNC(git_path_abort_safety_file, "sequencer/abort-safety")
 
  51 static GIT_PATH_FUNC(rebase_path, "rebase-merge")
 
  53  * The file containing rebase commands, comments, and empty lines.
 
  54  * This file is created by "git rebase -i" then edited by the user. As
 
  55  * the lines are processed, they are removed from the front of this
 
  56  * file and written to the tail of 'done'.
 
  58 GIT_PATH_FUNC(rebase_path_todo, "rebase-merge/git-rebase-todo")
 
  59 GIT_PATH_FUNC(rebase_path_todo_backup, "rebase-merge/git-rebase-todo.backup")
 
  61 GIT_PATH_FUNC(rebase_path_dropped, "rebase-merge/dropped")
 
  64  * The rebase command lines that have already been processed. A line
 
  65  * is moved here when it is first handled, before any associated user
 
  68 static GIT_PATH_FUNC(rebase_path_done, "rebase-merge/done")
 
  70  * The file to keep track of how many commands were already processed (e.g.
 
  73 static GIT_PATH_FUNC(rebase_path_msgnum, "rebase-merge/msgnum")
 
  75  * The file to keep track of how many commands are to be processed in total
 
  76  * (e.g. for the prompt).
 
  78 static GIT_PATH_FUNC(rebase_path_msgtotal, "rebase-merge/end")
 
  80  * The commit message that is planned to be used for any changes that
 
  81  * need to be committed following a user interaction.
 
  83 static GIT_PATH_FUNC(rebase_path_message, "rebase-merge/message")
 
  85  * The file into which is accumulated the suggested commit message for
 
  86  * squash/fixup commands. When the first of a series of squash/fixups
 
  87  * is seen, the file is created and the commit message from the
 
  88  * previous commit and from the first squash/fixup commit are written
 
  89  * to it. The commit message for each subsequent squash/fixup commit
 
  90  * is appended to the file as it is processed.
 
  92 static GIT_PATH_FUNC(rebase_path_squash_msg, "rebase-merge/message-squash")
 
  94  * If the current series of squash/fixups has not yet included a squash
 
  95  * command, then this file exists and holds the commit message of the
 
  96  * original "pick" commit.  (If the series ends without a "squash"
 
  97  * command, then this can be used as the commit message of the combined
 
  98  * commit without opening the editor.)
 
 100 static GIT_PATH_FUNC(rebase_path_fixup_msg, "rebase-merge/message-fixup")
 
 102  * This file contains the list fixup/squash commands that have been
 
 103  * accumulated into message-fixup or message-squash so far.
 
 105 static GIT_PATH_FUNC(rebase_path_current_fixups, "rebase-merge/current-fixups")
 
 107  * A script to set the GIT_AUTHOR_NAME, GIT_AUTHOR_EMAIL, and
 
 108  * GIT_AUTHOR_DATE that will be used for the commit that is currently
 
 111 static GIT_PATH_FUNC(rebase_path_author_script, "rebase-merge/author-script")
 
 113  * When an "edit" rebase command is being processed, the SHA1 of the
 
 114  * commit to be edited is recorded in this file.  When "git rebase
 
 115  * --continue" is executed, if there are any staged changes then they
 
 116  * will be amended to the HEAD commit, but only provided the HEAD
 
 117  * commit is still the commit to be edited.  When any other rebase
 
 118  * command is processed, this file is deleted.
 
 120 static GIT_PATH_FUNC(rebase_path_amend, "rebase-merge/amend")
 
 122  * When we stop at a given patch via the "edit" command, this file contains
 
 123  * the abbreviated commit name of the corresponding patch.
 
 125 static GIT_PATH_FUNC(rebase_path_stopped_sha, "rebase-merge/stopped-sha")
 
 127  * For the post-rewrite hook, we make a list of rewritten commits and
 
 128  * their new sha1s.  The rewritten-pending list keeps the sha1s of
 
 129  * commits that have been processed, but not committed yet,
 
 130  * e.g. because they are waiting for a 'squash' command.
 
 132 static GIT_PATH_FUNC(rebase_path_rewritten_list, "rebase-merge/rewritten-list")
 
 133 static GIT_PATH_FUNC(rebase_path_rewritten_pending,
 
 134         "rebase-merge/rewritten-pending")
 
 137  * The path of the file containing the OID of the "squash onto" commit, i.e.
 
 138  * the dummy commit used for `reset [new root]`.
 
 140 static GIT_PATH_FUNC(rebase_path_squash_onto, "rebase-merge/squash-onto")
 
 143  * The path of the file listing refs that need to be deleted after the rebase
 
 144  * finishes. This is used by the `label` command to record the need for cleanup.
 
 146 static GIT_PATH_FUNC(rebase_path_refs_to_delete, "rebase-merge/refs-to-delete")
 
 149  * The following files are written by git-rebase just after parsing the
 
 152 static GIT_PATH_FUNC(rebase_path_gpg_sign_opt, "rebase-merge/gpg_sign_opt")
 
 153 static GIT_PATH_FUNC(rebase_path_orig_head, "rebase-merge/orig-head")
 
 154 static GIT_PATH_FUNC(rebase_path_verbose, "rebase-merge/verbose")
 
 155 static GIT_PATH_FUNC(rebase_path_quiet, "rebase-merge/quiet")
 
 156 static GIT_PATH_FUNC(rebase_path_signoff, "rebase-merge/signoff")
 
 157 static GIT_PATH_FUNC(rebase_path_head_name, "rebase-merge/head-name")
 
 158 static GIT_PATH_FUNC(rebase_path_onto, "rebase-merge/onto")
 
 159 static GIT_PATH_FUNC(rebase_path_autostash, "rebase-merge/autostash")
 
 160 static GIT_PATH_FUNC(rebase_path_strategy, "rebase-merge/strategy")
 
 161 static GIT_PATH_FUNC(rebase_path_strategy_opts, "rebase-merge/strategy_opts")
 
 162 static GIT_PATH_FUNC(rebase_path_allow_rerere_autoupdate, "rebase-merge/allow_rerere_autoupdate")
 
 163 static GIT_PATH_FUNC(rebase_path_reschedule_failed_exec, "rebase-merge/reschedule-failed-exec")
 
 164 static GIT_PATH_FUNC(rebase_path_drop_redundant_commits, "rebase-merge/drop_redundant_commits")
 
 165 static GIT_PATH_FUNC(rebase_path_keep_redundant_commits, "rebase-merge/keep_redundant_commits")
 
 167 static int git_sequencer_config(const char *k, const char *v, void *cb)
 
 169         struct replay_opts *opts = cb;
 
 172         if (!strcmp(k, "commit.cleanup")) {
 
 175                 status = git_config_string(&s, k, v);
 
 179                 if (!strcmp(s, "verbatim")) {
 
 180                         opts->default_msg_cleanup = COMMIT_MSG_CLEANUP_NONE;
 
 181                         opts->explicit_cleanup = 1;
 
 182                 } else if (!strcmp(s, "whitespace")) {
 
 183                         opts->default_msg_cleanup = COMMIT_MSG_CLEANUP_SPACE;
 
 184                         opts->explicit_cleanup = 1;
 
 185                 } else if (!strcmp(s, "strip")) {
 
 186                         opts->default_msg_cleanup = COMMIT_MSG_CLEANUP_ALL;
 
 187                         opts->explicit_cleanup = 1;
 
 188                 } else if (!strcmp(s, "scissors")) {
 
 189                         opts->default_msg_cleanup = COMMIT_MSG_CLEANUP_SCISSORS;
 
 190                         opts->explicit_cleanup = 1;
 
 192                         warning(_("invalid commit message cleanup mode '%s'"),
 
 200         if (!strcmp(k, "commit.gpgsign")) {
 
 201                 opts->gpg_sign = git_config_bool(k, v) ? xstrdup("") : NULL;
 
 205         status = git_gpg_config(k, v, NULL);
 
 209         return git_diff_basic_config(k, v, NULL);
 
 212 void sequencer_init_config(struct replay_opts *opts)
 
 214         opts->default_msg_cleanup = COMMIT_MSG_CLEANUP_NONE;
 
 215         git_config(git_sequencer_config, opts);
 
 218 static inline int is_rebase_i(const struct replay_opts *opts)
 
 220         return opts->action == REPLAY_INTERACTIVE_REBASE;
 
 223 static const char *get_dir(const struct replay_opts *opts)
 
 225         if (is_rebase_i(opts))
 
 226                 return rebase_path();
 
 227         return git_path_seq_dir();
 
 230 static const char *get_todo_path(const struct replay_opts *opts)
 
 232         if (is_rebase_i(opts))
 
 233                 return rebase_path_todo();
 
 234         return git_path_todo_file();
 
 238  * Returns 0 for non-conforming footer
 
 239  * Returns 1 for conforming footer
 
 240  * Returns 2 when sob exists within conforming footer
 
 241  * Returns 3 when sob exists within conforming footer as last entry
 
 243 static int has_conforming_footer(struct strbuf *sb, struct strbuf *sob,
 
 244         size_t ignore_footer)
 
 246         struct process_trailer_options opts = PROCESS_TRAILER_OPTIONS_INIT;
 
 247         struct trailer_info info;
 
 249         int found_sob = 0, found_sob_last = 0;
 
 253         trailer_info_get(&info, sb->buf, &opts);
 
 255         if (info.trailer_start == info.trailer_end)
 
 258         for (i = 0; i < info.trailer_nr; i++)
 
 259                 if (sob && !strncmp(info.trailers[i], sob->buf, sob->len)) {
 
 261                         if (i == info.trailer_nr - 1)
 
 265         trailer_info_release(&info);
 
 274 static const char *gpg_sign_opt_quoted(struct replay_opts *opts)
 
 276         static struct strbuf buf = STRBUF_INIT;
 
 280                 sq_quotef(&buf, "-S%s", opts->gpg_sign);
 
 284 int sequencer_remove_state(struct replay_opts *opts)
 
 286         struct strbuf buf = STRBUF_INIT;
 
 289         if (is_rebase_i(opts) &&
 
 290             strbuf_read_file(&buf, rebase_path_refs_to_delete(), 0) > 0) {
 
 293                         char *eol = strchr(p, '\n');
 
 296                         if (delete_ref("(rebase) cleanup", p, NULL, 0) < 0) {
 
 297                                 warning(_("could not delete '%s'"), p);
 
 306         free(opts->gpg_sign);
 
 307         free(opts->strategy);
 
 308         for (i = 0; i < opts->xopts_nr; i++)
 
 309                 free(opts->xopts[i]);
 
 311         strbuf_release(&opts->current_fixups);
 
 314         strbuf_addstr(&buf, get_dir(opts));
 
 315         if (remove_dir_recursively(&buf, 0))
 
 316                 ret = error(_("could not remove '%s'"), buf.buf);
 
 317         strbuf_release(&buf);
 
 322 static const char *action_name(const struct replay_opts *opts)
 
 324         switch (opts->action) {
 
 328                 return N_("cherry-pick");
 
 329         case REPLAY_INTERACTIVE_REBASE:
 
 332         die(_("unknown action: %d"), opts->action);
 
 335 struct commit_message {
 
 342 static const char *short_commit_name(struct commit *commit)
 
 344         return find_unique_abbrev(&commit->object.oid, DEFAULT_ABBREV);
 
 347 static int get_message(struct commit *commit, struct commit_message *out)
 
 349         const char *abbrev, *subject;
 
 352         out->message = logmsg_reencode(commit, NULL, get_commit_output_encoding());
 
 353         abbrev = short_commit_name(commit);
 
 355         subject_len = find_commit_subject(out->message, &subject);
 
 357         out->subject = xmemdupz(subject, subject_len);
 
 358         out->label = xstrfmt("%s... %s", abbrev, out->subject);
 
 359         out->parent_label = xstrfmt("parent of %s", out->label);
 
 364 static void free_message(struct commit *commit, struct commit_message *msg)
 
 366         free(msg->parent_label);
 
 369         unuse_commit_buffer(commit, msg->message);
 
 372 static void print_advice(struct repository *r, int show_hint,
 
 373                          struct replay_opts *opts)
 
 375         char *msg = getenv("GIT_CHERRY_PICK_HELP");
 
 378                 fprintf(stderr, "%s\n", msg);
 
 380                  * A conflict has occurred but the porcelain
 
 381                  * (typically rebase --interactive) wants to take care
 
 382                  * of the commit itself so remove CHERRY_PICK_HEAD
 
 384                 refs_delete_ref(get_main_ref_store(r), "", "CHERRY_PICK_HEAD",
 
 391                         advise(_("after resolving the conflicts, mark the corrected paths\n"
 
 392                                  "with 'git add <paths>' or 'git rm <paths>'"));
 
 394                         advise(_("after resolving the conflicts, mark the corrected paths\n"
 
 395                                  "with 'git add <paths>' or 'git rm <paths>'\n"
 
 396                                  "and commit the result with 'git commit'"));
 
 400 static int write_message(const void *buf, size_t len, const char *filename,
 
 403         struct lock_file msg_file = LOCK_INIT;
 
 405         int msg_fd = hold_lock_file_for_update(&msg_file, filename, 0);
 
 407                 return error_errno(_("could not lock '%s'"), filename);
 
 408         if (write_in_full(msg_fd, buf, len) < 0) {
 
 409                 error_errno(_("could not write to '%s'"), filename);
 
 410                 rollback_lock_file(&msg_file);
 
 413         if (append_eol && write(msg_fd, "\n", 1) < 0) {
 
 414                 error_errno(_("could not write eol to '%s'"), filename);
 
 415                 rollback_lock_file(&msg_file);
 
 418         if (commit_lock_file(&msg_file) < 0)
 
 419                 return error(_("failed to finalize '%s'"), filename);
 
 424 int read_oneliner(struct strbuf *buf,
 
 425         const char *path, unsigned flags)
 
 427         int orig_len = buf->len;
 
 429         if (strbuf_read_file(buf, path, 0) < 0) {
 
 430                 if ((flags & READ_ONELINER_WARN_MISSING) ||
 
 431                     (errno != ENOENT && errno != ENOTDIR))
 
 432                         warning_errno(_("could not read '%s'"), path);
 
 436         if (buf->len > orig_len && buf->buf[buf->len - 1] == '\n') {
 
 437                 if (--buf->len > orig_len && buf->buf[buf->len - 1] == '\r')
 
 439                 buf->buf[buf->len] = '\0';
 
 442         if ((flags & READ_ONELINER_SKIP_IF_EMPTY) && buf->len == orig_len)
 
 448 static struct tree *empty_tree(struct repository *r)
 
 450         return lookup_tree(r, the_hash_algo->empty_tree);
 
 453 static int error_dirty_index(struct repository *repo, struct replay_opts *opts)
 
 455         if (repo_read_index_unmerged(repo))
 
 456                 return error_resolve_conflict(_(action_name(opts)));
 
 458         error(_("your local changes would be overwritten by %s."),
 
 459                 _(action_name(opts)));
 
 461         if (advice_commit_before_merge)
 
 462                 advise(_("commit your changes or stash them to proceed."));
 
 466 static void update_abort_safety_file(void)
 
 468         struct object_id head;
 
 470         /* Do nothing on a single-pick */
 
 471         if (!file_exists(git_path_seq_dir()))
 
 474         if (!get_oid("HEAD", &head))
 
 475                 write_file(git_path_abort_safety_file(), "%s", oid_to_hex(&head));
 
 477                 write_file(git_path_abort_safety_file(), "%s", "");
 
 480 static int fast_forward_to(struct repository *r,
 
 481                            const struct object_id *to,
 
 482                            const struct object_id *from,
 
 484                            struct replay_opts *opts)
 
 486         struct ref_transaction *transaction;
 
 487         struct strbuf sb = STRBUF_INIT;
 
 488         struct strbuf err = STRBUF_INIT;
 
 491         if (checkout_fast_forward(r, from, to, 1))
 
 492                 return -1; /* the callee should have complained already */
 
 494         strbuf_addf(&sb, _("%s: fast-forward"), _(action_name(opts)));
 
 496         transaction = ref_transaction_begin(&err);
 
 498             ref_transaction_update(transaction, "HEAD",
 
 499                                    to, unborn && !is_rebase_i(opts) ?
 
 502             ref_transaction_commit(transaction, &err)) {
 
 503                 ref_transaction_free(transaction);
 
 504                 error("%s", err.buf);
 
 506                 strbuf_release(&err);
 
 511         strbuf_release(&err);
 
 512         ref_transaction_free(transaction);
 
 513         update_abort_safety_file();
 
 517 enum commit_msg_cleanup_mode get_cleanup_mode(const char *cleanup_arg,
 
 520         if (!cleanup_arg || !strcmp(cleanup_arg, "default"))
 
 521                 return use_editor ? COMMIT_MSG_CLEANUP_ALL :
 
 522                                     COMMIT_MSG_CLEANUP_SPACE;
 
 523         else if (!strcmp(cleanup_arg, "verbatim"))
 
 524                 return COMMIT_MSG_CLEANUP_NONE;
 
 525         else if (!strcmp(cleanup_arg, "whitespace"))
 
 526                 return COMMIT_MSG_CLEANUP_SPACE;
 
 527         else if (!strcmp(cleanup_arg, "strip"))
 
 528                 return COMMIT_MSG_CLEANUP_ALL;
 
 529         else if (!strcmp(cleanup_arg, "scissors"))
 
 530                 return use_editor ? COMMIT_MSG_CLEANUP_SCISSORS :
 
 531                                     COMMIT_MSG_CLEANUP_SPACE;
 
 533                 die(_("Invalid cleanup mode %s"), cleanup_arg);
 
 537  * NB using int rather than enum cleanup_mode to stop clang's
 
 538  * -Wtautological-constant-out-of-range-compare complaining that the comparison
 
 541 static const char *describe_cleanup_mode(int cleanup_mode)
 
 543         static const char *modes[] = { "whitespace",
 
 548         if (cleanup_mode < ARRAY_SIZE(modes))
 
 549                 return modes[cleanup_mode];
 
 551         BUG("invalid cleanup_mode provided (%d)", cleanup_mode);
 
 554 void append_conflicts_hint(struct index_state *istate,
 
 555         struct strbuf *msgbuf, enum commit_msg_cleanup_mode cleanup_mode)
 
 559         if (cleanup_mode == COMMIT_MSG_CLEANUP_SCISSORS) {
 
 560                 strbuf_addch(msgbuf, '\n');
 
 561                 wt_status_append_cut_line(msgbuf);
 
 562                 strbuf_addch(msgbuf, comment_line_char);
 
 565         strbuf_addch(msgbuf, '\n');
 
 566         strbuf_commented_addf(msgbuf, "Conflicts:\n");
 
 567         for (i = 0; i < istate->cache_nr;) {
 
 568                 const struct cache_entry *ce = istate->cache[i++];
 
 570                         strbuf_commented_addf(msgbuf, "\t%s\n", ce->name);
 
 571                         while (i < istate->cache_nr &&
 
 572                                !strcmp(ce->name, istate->cache[i]->name))
 
 578 static int do_recursive_merge(struct repository *r,
 
 579                               struct commit *base, struct commit *next,
 
 580                               const char *base_label, const char *next_label,
 
 581                               struct object_id *head, struct strbuf *msgbuf,
 
 582                               struct replay_opts *opts)
 
 584         struct merge_options o;
 
 585         struct tree *next_tree, *base_tree, *head_tree;
 
 588         struct lock_file index_lock = LOCK_INIT;
 
 590         if (repo_hold_locked_index(r, &index_lock, LOCK_REPORT_ON_ERROR) < 0)
 
 595         init_merge_options(&o, r);
 
 596         o.ancestor = base ? base_label : "(empty tree)";
 
 598         o.branch2 = next ? next_label : "(empty tree)";
 
 599         if (is_rebase_i(opts))
 
 601         o.show_rename_progress = 1;
 
 603         head_tree = parse_tree_indirect(head);
 
 604         next_tree = next ? get_commit_tree(next) : empty_tree(r);
 
 605         base_tree = base ? get_commit_tree(base) : empty_tree(r);
 
 607         for (i = 0; i < opts->xopts_nr; i++)
 
 608                 parse_merge_opt(&o, opts->xopts[i]);
 
 610         clean = merge_trees(&o,
 
 612                             next_tree, base_tree);
 
 613         if (is_rebase_i(opts) && clean <= 0)
 
 614                 fputs(o.obuf.buf, stdout);
 
 615         strbuf_release(&o.obuf);
 
 617                 rollback_lock_file(&index_lock);
 
 621         if (write_locked_index(r->index, &index_lock,
 
 622                                COMMIT_LOCK | SKIP_IF_UNCHANGED))
 
 624                  * TRANSLATORS: %s will be "revert", "cherry-pick" or
 
 627                 return error(_("%s: Unable to write new index file"),
 
 628                         _(action_name(opts)));
 
 631                 append_conflicts_hint(r->index, msgbuf,
 
 632                                       opts->default_msg_cleanup);
 
 637 static struct object_id *get_cache_tree_oid(struct index_state *istate)
 
 639         if (!istate->cache_tree)
 
 640                 istate->cache_tree = cache_tree();
 
 642         if (!cache_tree_fully_valid(istate->cache_tree))
 
 643                 if (cache_tree_update(istate, 0)) {
 
 644                         error(_("unable to update cache tree"));
 
 648         return &istate->cache_tree->oid;
 
 651 static int is_index_unchanged(struct repository *r)
 
 653         struct object_id head_oid, *cache_tree_oid;
 
 654         struct commit *head_commit;
 
 655         struct index_state *istate = r->index;
 
 657         if (!resolve_ref_unsafe("HEAD", RESOLVE_REF_READING, &head_oid, NULL))
 
 658                 return error(_("could not resolve HEAD commit"));
 
 660         head_commit = lookup_commit(r, &head_oid);
 
 663          * If head_commit is NULL, check_commit, called from
 
 664          * lookup_commit, would have indicated that head_commit is not
 
 665          * a commit object already.  parse_commit() will return failure
 
 666          * without further complaints in such a case.  Otherwise, if
 
 667          * the commit is invalid, parse_commit() will complain.  So
 
 668          * there is nothing for us to say here.  Just return failure.
 
 670         if (parse_commit(head_commit))
 
 673         if (!(cache_tree_oid = get_cache_tree_oid(istate)))
 
 676         return oideq(cache_tree_oid, get_commit_tree_oid(head_commit));
 
 679 static int write_author_script(const char *message)
 
 681         struct strbuf buf = STRBUF_INIT;
 
 686                 if (!*message || starts_with(message, "\n")) {
 
 688                         /* Missing 'author' line? */
 
 689                         unlink(rebase_path_author_script());
 
 691                 } else if (skip_prefix(message, "author ", &message))
 
 693                 else if ((eol = strchr(message, '\n')))
 
 698         strbuf_addstr(&buf, "GIT_AUTHOR_NAME='");
 
 699         while (*message && *message != '\n' && *message != '\r')
 
 700                 if (skip_prefix(message, " <", &message))
 
 702                 else if (*message != '\'')
 
 703                         strbuf_addch(&buf, *(message++));
 
 705                         strbuf_addf(&buf, "'\\%c'", *(message++));
 
 706         strbuf_addstr(&buf, "'\nGIT_AUTHOR_EMAIL='");
 
 707         while (*message && *message != '\n' && *message != '\r')
 
 708                 if (skip_prefix(message, "> ", &message))
 
 710                 else if (*message != '\'')
 
 711                         strbuf_addch(&buf, *(message++));
 
 713                         strbuf_addf(&buf, "'\\%c'", *(message++));
 
 714         strbuf_addstr(&buf, "'\nGIT_AUTHOR_DATE='@");
 
 715         while (*message && *message != '\n' && *message != '\r')
 
 716                 if (*message != '\'')
 
 717                         strbuf_addch(&buf, *(message++));
 
 719                         strbuf_addf(&buf, "'\\%c'", *(message++));
 
 720         strbuf_addch(&buf, '\'');
 
 721         res = write_message(buf.buf, buf.len, rebase_path_author_script(), 1);
 
 722         strbuf_release(&buf);
 
 727  * Take a series of KEY='VALUE' lines where VALUE part is
 
 728  * sq-quoted, and append <KEY, VALUE> at the end of the string list
 
 730 static int parse_key_value_squoted(char *buf, struct string_list *list)
 
 733                 struct string_list_item *item;
 
 735                 char *cp = strchr(buf, '=');
 
 737                         np = strchrnul(buf, '\n');
 
 738                         return error(_("no key present in '%.*s'"),
 
 739                                      (int) (np - buf), buf);
 
 741                 np = strchrnul(cp, '\n');
 
 743                 item = string_list_append(list, buf);
 
 745                 buf = np + (*np == '\n');
 
 749                         return error(_("unable to dequote value of '%s'"),
 
 751                 item->util = xstrdup(cp);
 
 757  * Reads and parses the state directory's "author-script" file, and sets name,
 
 758  * email and date accordingly.
 
 759  * Returns 0 on success, -1 if the file could not be parsed.
 
 761  * The author script is of the format:
 
 763  *      GIT_AUTHOR_NAME='$author_name'
 
 764  *      GIT_AUTHOR_EMAIL='$author_email'
 
 765  *      GIT_AUTHOR_DATE='$author_date'
 
 767  * where $author_name, $author_email and $author_date are quoted. We are strict
 
 768  * with our parsing, as the file was meant to be eval'd in the now-removed
 
 769  * git-am.sh/git-rebase--interactive.sh scripts, and thus if the file differs
 
 770  * from what this function expects, it is better to bail out than to do
 
 771  * something that the user does not expect.
 
 773 int read_author_script(const char *path, char **name, char **email, char **date,
 
 776         struct strbuf buf = STRBUF_INIT;
 
 777         struct string_list kv = STRING_LIST_INIT_DUP;
 
 778         int retval = -1; /* assume failure */
 
 779         int i, name_i = -2, email_i = -2, date_i = -2, err = 0;
 
 781         if (strbuf_read_file(&buf, path, 256) <= 0) {
 
 782                 strbuf_release(&buf);
 
 783                 if (errno == ENOENT && allow_missing)
 
 786                         return error_errno(_("could not open '%s' for reading"),
 
 790         if (parse_key_value_squoted(buf.buf, &kv))
 
 793         for (i = 0; i < kv.nr; i++) {
 
 794                 if (!strcmp(kv.items[i].string, "GIT_AUTHOR_NAME")) {
 
 796                                 name_i = error(_("'GIT_AUTHOR_NAME' already given"));
 
 799                 } else if (!strcmp(kv.items[i].string, "GIT_AUTHOR_EMAIL")) {
 
 801                                 email_i = error(_("'GIT_AUTHOR_EMAIL' already given"));
 
 804                 } else if (!strcmp(kv.items[i].string, "GIT_AUTHOR_DATE")) {
 
 806                                 date_i = error(_("'GIT_AUTHOR_DATE' already given"));
 
 810                         err = error(_("unknown variable '%s'"),
 
 815                 error(_("missing 'GIT_AUTHOR_NAME'"));
 
 817                 error(_("missing 'GIT_AUTHOR_EMAIL'"));
 
 819                 error(_("missing 'GIT_AUTHOR_DATE'"));
 
 820         if (date_i < 0 || email_i < 0 || date_i < 0 || err)
 
 822         *name = kv.items[name_i].util;
 
 823         *email = kv.items[email_i].util;
 
 824         *date = kv.items[date_i].util;
 
 827         string_list_clear(&kv, !!retval);
 
 828         strbuf_release(&buf);
 
 833  * Read a GIT_AUTHOR_NAME, GIT_AUTHOR_EMAIL AND GIT_AUTHOR_DATE from a
 
 834  * file with shell quoting into struct strvec. Returns -1 on
 
 835  * error, 0 otherwise.
 
 837 static int read_env_script(struct strvec *env)
 
 839         char *name, *email, *date;
 
 841         if (read_author_script(rebase_path_author_script(),
 
 842                                &name, &email, &date, 0))
 
 845         strvec_pushf(env, "GIT_AUTHOR_NAME=%s", name);
 
 846         strvec_pushf(env, "GIT_AUTHOR_EMAIL=%s", email);
 
 847         strvec_pushf(env, "GIT_AUTHOR_DATE=%s", date);
 
 855 static char *get_author(const char *message)
 
 860         a = find_commit_header(message, "author", &len);
 
 862                 return xmemdupz(a, len);
 
 867 static const char staged_changes_advice[] =
 
 868 N_("you have staged changes in your working tree\n"
 
 869 "If these changes are meant to be squashed into the previous commit, run:\n"
 
 871 "  git commit --amend %s\n"
 
 873 "If they are meant to go into a new commit, run:\n"
 
 877 "In both cases, once you're done, continue with:\n"
 
 879 "  git rebase --continue\n");
 
 881 #define ALLOW_EMPTY (1<<0)
 
 882 #define EDIT_MSG    (1<<1)
 
 883 #define AMEND_MSG   (1<<2)
 
 884 #define CLEANUP_MSG (1<<3)
 
 885 #define VERIFY_MSG  (1<<4)
 
 886 #define CREATE_ROOT_COMMIT (1<<5)
 
 888 static int run_command_silent_on_success(struct child_process *cmd)
 
 890         struct strbuf buf = STRBUF_INIT;
 
 893         cmd->stdout_to_stderr = 1;
 
 894         rc = pipe_command(cmd,
 
 900                 fputs(buf.buf, stderr);
 
 901         strbuf_release(&buf);
 
 906  * If we are cherry-pick, and if the merge did not result in
 
 907  * hand-editing, we will hit this commit and inherit the original
 
 908  * author date and name.
 
 910  * If we are revert, or if our cherry-pick results in a hand merge,
 
 911  * we had better say that the current user is responsible for that.
 
 913  * An exception is when run_git_commit() is called during an
 
 914  * interactive rebase: in that case, we will want to retain the
 
 917 static int run_git_commit(struct repository *r,
 
 919                           struct replay_opts *opts,
 
 922         struct child_process cmd = CHILD_PROCESS_INIT;
 
 926         if (is_rebase_i(opts) && read_env_script(&cmd.env_array)) {
 
 927                 const char *gpg_opt = gpg_sign_opt_quoted(opts);
 
 929                 return error(_(staged_changes_advice),
 
 933         strvec_push(&cmd.args, "commit");
 
 935         if (!(flags & VERIFY_MSG))
 
 936                 strvec_push(&cmd.args, "-n");
 
 937         if ((flags & AMEND_MSG))
 
 938                 strvec_push(&cmd.args, "--amend");
 
 940                 strvec_pushf(&cmd.args, "-S%s", opts->gpg_sign);
 
 942                 strvec_push(&cmd.args, "--no-gpg-sign");
 
 944                 strvec_pushl(&cmd.args, "-F", defmsg, NULL);
 
 945         else if (!(flags & EDIT_MSG))
 
 946                 strvec_pushl(&cmd.args, "-C", "HEAD", NULL);
 
 947         if ((flags & CLEANUP_MSG))
 
 948                 strvec_push(&cmd.args, "--cleanup=strip");
 
 949         if ((flags & EDIT_MSG))
 
 950                 strvec_push(&cmd.args, "-e");
 
 951         else if (!(flags & CLEANUP_MSG) &&
 
 952                  !opts->signoff && !opts->record_origin &&
 
 953                  !opts->explicit_cleanup)
 
 954                 strvec_push(&cmd.args, "--cleanup=verbatim");
 
 956         if ((flags & ALLOW_EMPTY))
 
 957                 strvec_push(&cmd.args, "--allow-empty");
 
 959         if (!(flags & EDIT_MSG))
 
 960                 strvec_push(&cmd.args, "--allow-empty-message");
 
 962         if (is_rebase_i(opts) && !(flags & EDIT_MSG))
 
 963                 return run_command_silent_on_success(&cmd);
 
 965                 return run_command(&cmd);
 
 968 static int rest_is_empty(const struct strbuf *sb, int start)
 
 973         /* Check if the rest is just whitespace and Signed-off-by's. */
 
 974         for (i = start; i < sb->len; i++) {
 
 975                 nl = memchr(sb->buf + i, '\n', sb->len - i);
 
 981                 if (strlen(sign_off_header) <= eol - i &&
 
 982                     starts_with(sb->buf + i, sign_off_header)) {
 
 987                         if (!isspace(sb->buf[i++]))
 
 994 void cleanup_message(struct strbuf *msgbuf,
 
 995         enum commit_msg_cleanup_mode cleanup_mode, int verbose)
 
 997         if (verbose || /* Truncate the message just before the diff, if any. */
 
 998             cleanup_mode == COMMIT_MSG_CLEANUP_SCISSORS)
 
 999                 strbuf_setlen(msgbuf, wt_status_locate_end(msgbuf->buf, msgbuf->len));
 
1000         if (cleanup_mode != COMMIT_MSG_CLEANUP_NONE)
 
1001                 strbuf_stripspace(msgbuf, cleanup_mode == COMMIT_MSG_CLEANUP_ALL);
 
1005  * Find out if the message in the strbuf contains only whitespace and
 
1006  * Signed-off-by lines.
 
1008 int message_is_empty(const struct strbuf *sb,
 
1009                      enum commit_msg_cleanup_mode cleanup_mode)
 
1011         if (cleanup_mode == COMMIT_MSG_CLEANUP_NONE && sb->len)
 
1013         return rest_is_empty(sb, 0);
 
1017  * See if the user edited the message in the editor or left what
 
1018  * was in the template intact
 
1020 int template_untouched(const struct strbuf *sb, const char *template_file,
 
1021                        enum commit_msg_cleanup_mode cleanup_mode)
 
1023         struct strbuf tmpl = STRBUF_INIT;
 
1026         if (cleanup_mode == COMMIT_MSG_CLEANUP_NONE && sb->len)
 
1029         if (!template_file || strbuf_read_file(&tmpl, template_file, 0) <= 0)
 
1032         strbuf_stripspace(&tmpl, cleanup_mode == COMMIT_MSG_CLEANUP_ALL);
 
1033         if (!skip_prefix(sb->buf, tmpl.buf, &start))
 
1035         strbuf_release(&tmpl);
 
1036         return rest_is_empty(sb, start - sb->buf);
 
1039 int update_head_with_reflog(const struct commit *old_head,
 
1040                             const struct object_id *new_head,
 
1041                             const char *action, const struct strbuf *msg,
 
1044         struct ref_transaction *transaction;
 
1045         struct strbuf sb = STRBUF_INIT;
 
1050                 strbuf_addstr(&sb, action);
 
1051                 strbuf_addstr(&sb, ": ");
 
1054         nl = strchr(msg->buf, '\n');
 
1056                 strbuf_add(&sb, msg->buf, nl + 1 - msg->buf);
 
1058                 strbuf_addbuf(&sb, msg);
 
1059                 strbuf_addch(&sb, '\n');
 
1062         transaction = ref_transaction_begin(err);
 
1064             ref_transaction_update(transaction, "HEAD", new_head,
 
1065                                    old_head ? &old_head->object.oid : &null_oid,
 
1067             ref_transaction_commit(transaction, err)) {
 
1070         ref_transaction_free(transaction);
 
1071         strbuf_release(&sb);
 
1076 static int run_rewrite_hook(const struct object_id *oldoid,
 
1077                             const struct object_id *newoid)
 
1079         struct child_process proc = CHILD_PROCESS_INIT;
 
1080         const char *argv[3];
 
1082         struct strbuf sb = STRBUF_INIT;
 
1084         argv[0] = find_hook("post-rewrite");
 
1093         proc.stdout_to_stderr = 1;
 
1094         proc.trace2_hook_name = "post-rewrite";
 
1096         code = start_command(&proc);
 
1099         strbuf_addf(&sb, "%s %s\n", oid_to_hex(oldoid), oid_to_hex(newoid));
 
1100         sigchain_push(SIGPIPE, SIG_IGN);
 
1101         write_in_full(proc.in, sb.buf, sb.len);
 
1103         strbuf_release(&sb);
 
1104         sigchain_pop(SIGPIPE);
 
1105         return finish_command(&proc);
 
1108 void commit_post_rewrite(struct repository *r,
 
1109                          const struct commit *old_head,
 
1110                          const struct object_id *new_head)
 
1112         struct notes_rewrite_cfg *cfg;
 
1114         cfg = init_copy_notes_for_rewrite("amend");
 
1116                 /* we are amending, so old_head is not NULL */
 
1117                 copy_note_for_rewrite(cfg, &old_head->object.oid, new_head);
 
1118                 finish_copy_notes_for_rewrite(r, cfg, "Notes added by 'git commit --amend'");
 
1120         run_rewrite_hook(&old_head->object.oid, new_head);
 
1123 static int run_prepare_commit_msg_hook(struct repository *r,
 
1128         const char *name, *arg1 = NULL, *arg2 = NULL;
 
1130         name = git_path_commit_editmsg();
 
1131         if (write_message(msg->buf, msg->len, name, 0))
 
1140         if (run_commit_hook(0, r->index_file, "prepare-commit-msg", name,
 
1142                 ret = error(_("'prepare-commit-msg' hook failed"));
 
1147 static const char implicit_ident_advice_noconfig[] =
 
1148 N_("Your name and email address were configured automatically based\n"
 
1149 "on your username and hostname. Please check that they are accurate.\n"
 
1150 "You can suppress this message by setting them explicitly. Run the\n"
 
1151 "following command and follow the instructions in your editor to edit\n"
 
1152 "your configuration file:\n"
 
1154 "    git config --global --edit\n"
 
1156 "After doing this, you may fix the identity used for this commit with:\n"
 
1158 "    git commit --amend --reset-author\n");
 
1160 static const char implicit_ident_advice_config[] =
 
1161 N_("Your name and email address were configured automatically based\n"
 
1162 "on your username and hostname. Please check that they are accurate.\n"
 
1163 "You can suppress this message by setting them explicitly:\n"
 
1165 "    git config --global user.name \"Your Name\"\n"
 
1166 "    git config --global user.email you@example.com\n"
 
1168 "After doing this, you may fix the identity used for this commit with:\n"
 
1170 "    git commit --amend --reset-author\n");
 
1172 static const char *implicit_ident_advice(void)
 
1174         char *user_config = expand_user_path("~/.gitconfig", 0);
 
1175         char *xdg_config = xdg_config_home("config");
 
1176         int config_exists = file_exists(user_config) || file_exists(xdg_config);
 
1182                 return _(implicit_ident_advice_config);
 
1184                 return _(implicit_ident_advice_noconfig);
 
1188 void print_commit_summary(struct repository *r,
 
1190                           const struct object_id *oid,
 
1193         struct rev_info rev;
 
1194         struct commit *commit;
 
1195         struct strbuf format = STRBUF_INIT;
 
1197         struct pretty_print_context pctx = {0};
 
1198         struct strbuf author_ident = STRBUF_INIT;
 
1199         struct strbuf committer_ident = STRBUF_INIT;
 
1201         commit = lookup_commit(r, oid);
 
1203                 die(_("couldn't look up newly created commit"));
 
1204         if (parse_commit(commit))
 
1205                 die(_("could not parse newly created commit"));
 
1207         strbuf_addstr(&format, "format:%h] %s");
 
1209         format_commit_message(commit, "%an <%ae>", &author_ident, &pctx);
 
1210         format_commit_message(commit, "%cn <%ce>", &committer_ident, &pctx);
 
1211         if (strbuf_cmp(&author_ident, &committer_ident)) {
 
1212                 strbuf_addstr(&format, "\n Author: ");
 
1213                 strbuf_addbuf_percentquote(&format, &author_ident);
 
1215         if (flags & SUMMARY_SHOW_AUTHOR_DATE) {
 
1216                 struct strbuf date = STRBUF_INIT;
 
1218                 format_commit_message(commit, "%ad", &date, &pctx);
 
1219                 strbuf_addstr(&format, "\n Date: ");
 
1220                 strbuf_addbuf_percentquote(&format, &date);
 
1221                 strbuf_release(&date);
 
1223         if (!committer_ident_sufficiently_given()) {
 
1224                 strbuf_addstr(&format, "\n Committer: ");
 
1225                 strbuf_addbuf_percentquote(&format, &committer_ident);
 
1226                 if (advice_implicit_identity) {
 
1227                         strbuf_addch(&format, '\n');
 
1228                         strbuf_addstr(&format, implicit_ident_advice());
 
1231         strbuf_release(&author_ident);
 
1232         strbuf_release(&committer_ident);
 
1234         repo_init_revisions(r, &rev, prefix);
 
1235         setup_revisions(0, NULL, &rev, NULL);
 
1238         rev.diffopt.output_format =
 
1239                 DIFF_FORMAT_SHORTSTAT | DIFF_FORMAT_SUMMARY;
 
1241         rev.verbose_header = 1;
 
1242         rev.show_root_diff = 1;
 
1243         get_commit_format(format.buf, &rev);
 
1244         rev.always_show_header = 0;
 
1245         rev.diffopt.detect_rename = DIFF_DETECT_RENAME;
 
1246         rev.diffopt.break_opt = 0;
 
1247         diff_setup_done(&rev.diffopt);
 
1249         head = resolve_ref_unsafe("HEAD", 0, NULL, NULL);
 
1251                 die_errno(_("unable to resolve HEAD after creating commit"));
 
1252         if (!strcmp(head, "HEAD"))
 
1253                 head = _("detached HEAD");
 
1255                 skip_prefix(head, "refs/heads/", &head);
 
1256         printf("[%s%s ", head, (flags & SUMMARY_INITIAL_COMMIT) ?
 
1257                                                 _(" (root-commit)") : "");
 
1259         if (!log_tree_commit(&rev, commit)) {
 
1260                 rev.always_show_header = 1;
 
1261                 rev.use_terminator = 1;
 
1262                 log_tree_commit(&rev, commit);
 
1265         strbuf_release(&format);
 
1268 static int parse_head(struct repository *r, struct commit **head)
 
1270         struct commit *current_head;
 
1271         struct object_id oid;
 
1273         if (get_oid("HEAD", &oid)) {
 
1274                 current_head = NULL;
 
1276                 current_head = lookup_commit_reference(r, &oid);
 
1278                         return error(_("could not parse HEAD"));
 
1279                 if (!oideq(&oid, ¤t_head->object.oid)) {
 
1280                         warning(_("HEAD %s is not a commit!"),
 
1283                 if (parse_commit(current_head))
 
1284                         return error(_("could not parse HEAD commit"));
 
1286         *head = current_head;
 
1292  * Try to commit without forking 'git commit'. In some cases we need
 
1293  * to run 'git commit' to display an error message
 
1296  *  -1 - error unable to commit
 
1298  *   1 - run 'git commit'
 
1300 static int try_to_commit(struct repository *r,
 
1301                          struct strbuf *msg, const char *author,
 
1302                          struct replay_opts *opts, unsigned int flags,
 
1303                          struct object_id *oid)
 
1305         struct object_id tree;
 
1306         struct commit *current_head = NULL;
 
1307         struct commit_list *parents = NULL;
 
1308         struct commit_extra_header *extra = NULL;
 
1309         struct strbuf err = STRBUF_INIT;
 
1310         struct strbuf commit_msg = STRBUF_INIT;
 
1311         char *amend_author = NULL;
 
1312         const char *hook_commit = NULL;
 
1313         enum commit_msg_cleanup_mode cleanup;
 
1316         if (parse_head(r, ¤t_head))
 
1319         if (flags & AMEND_MSG) {
 
1320                 const char *exclude_gpgsig[] = { "gpgsig", "gpgsig-sha256", NULL };
 
1321                 const char *out_enc = get_commit_output_encoding();
 
1322                 const char *message = logmsg_reencode(current_head, NULL,
 
1326                         const char *orig_message = NULL;
 
1328                         find_commit_subject(message, &orig_message);
 
1330                         strbuf_addstr(msg, orig_message);
 
1331                         hook_commit = "HEAD";
 
1333                 author = amend_author = get_author(message);
 
1334                 unuse_commit_buffer(current_head, message);
 
1336                         res = error(_("unable to parse commit author"));
 
1339                 parents = copy_commit_list(current_head->parents);
 
1340                 extra = read_commit_extra_headers(current_head, exclude_gpgsig);
 
1341         } else if (current_head &&
 
1342                    (!(flags & CREATE_ROOT_COMMIT) || (flags & AMEND_MSG))) {
 
1343                 commit_list_insert(current_head, &parents);
 
1346         if (write_index_as_tree(&tree, r->index, r->index_file, 0, NULL)) {
 
1347                 res = error(_("git write-tree failed to write a tree"));
 
1351         if (!(flags & ALLOW_EMPTY)) {
 
1352                 struct commit *first_parent = current_head;
 
1354                 if (flags & AMEND_MSG) {
 
1355                         if (current_head->parents) {
 
1356                                 first_parent = current_head->parents->item;
 
1357                                 if (repo_parse_commit(r, first_parent)) {
 
1358                                         res = error(_("could not parse HEAD commit"));
 
1362                                 first_parent = NULL;
 
1365                 if (oideq(first_parent
 
1366                           ? get_commit_tree_oid(first_parent)
 
1367                           : the_hash_algo->empty_tree,
 
1369                         res = 1; /* run 'git commit' to display error message */
 
1374         if (find_hook("prepare-commit-msg")) {
 
1375                 res = run_prepare_commit_msg_hook(r, msg, hook_commit);
 
1378                 if (strbuf_read_file(&commit_msg, git_path_commit_editmsg(),
 
1380                         res = error_errno(_("unable to read commit message "
 
1382                                             git_path_commit_editmsg());
 
1388         if (flags & CLEANUP_MSG)
 
1389                 cleanup = COMMIT_MSG_CLEANUP_ALL;
 
1390         else if ((opts->signoff || opts->record_origin) &&
 
1391                  !opts->explicit_cleanup)
 
1392                 cleanup = COMMIT_MSG_CLEANUP_SPACE;
 
1394                 cleanup = opts->default_msg_cleanup;
 
1396         if (cleanup != COMMIT_MSG_CLEANUP_NONE)
 
1397                 strbuf_stripspace(msg, cleanup == COMMIT_MSG_CLEANUP_ALL);
 
1398         if ((flags & EDIT_MSG) && message_is_empty(msg, cleanup)) {
 
1399                 res = 1; /* run 'git commit' to display error message */
 
1405         if (commit_tree_extended(msg->buf, msg->len, &tree, parents,
 
1406                                  oid, author, opts->gpg_sign, extra)) {
 
1407                 res = error(_("failed to write commit object"));
 
1411         if (update_head_with_reflog(current_head, oid,
 
1412                                     getenv("GIT_REFLOG_ACTION"), msg, &err)) {
 
1413                 res = error("%s", err.buf);
 
1417         run_commit_hook(0, r->index_file, "post-commit", NULL);
 
1418         if (flags & AMEND_MSG)
 
1419                 commit_post_rewrite(r, current_head, oid);
 
1422         free_commit_extra_headers(extra);
 
1423         strbuf_release(&err);
 
1424         strbuf_release(&commit_msg);
 
1430 static int write_rebase_head(struct object_id *oid)
 
1432         if (update_ref("rebase", "REBASE_HEAD", oid,
 
1433                        NULL, REF_NO_DEREF, UPDATE_REFS_MSG_ON_ERR))
 
1434                 return error(_("could not update %s"), "REBASE_HEAD");
 
1439 static int do_commit(struct repository *r,
 
1440                      const char *msg_file, const char *author,
 
1441                      struct replay_opts *opts, unsigned int flags,
 
1442                      struct object_id *oid)
 
1446         if (!(flags & EDIT_MSG) && !(flags & VERIFY_MSG)) {
 
1447                 struct object_id oid;
 
1448                 struct strbuf sb = STRBUF_INIT;
 
1450                 if (msg_file && strbuf_read_file(&sb, msg_file, 2048) < 0)
 
1451                         return error_errno(_("unable to read commit message "
 
1455                 res = try_to_commit(r, msg_file ? &sb : NULL,
 
1456                                     author, opts, flags, &oid);
 
1457                 strbuf_release(&sb);
 
1459                         refs_delete_ref(get_main_ref_store(r), "",
 
1460                                         "CHERRY_PICK_HEAD", NULL, 0);
 
1461                         unlink(git_path_merge_msg(r));
 
1462                         if (!is_rebase_i(opts))
 
1463                                 print_commit_summary(r, NULL, &oid,
 
1464                                                 SUMMARY_SHOW_AUTHOR_DATE);
 
1469                 if (is_rebase_i(opts) && oid)
 
1470                         if (write_rebase_head(oid))
 
1472                 return run_git_commit(r, msg_file, opts, flags);
 
1478 static int is_original_commit_empty(struct commit *commit)
 
1480         const struct object_id *ptree_oid;
 
1482         if (parse_commit(commit))
 
1483                 return error(_("could not parse commit %s"),
 
1484                              oid_to_hex(&commit->object.oid));
 
1485         if (commit->parents) {
 
1486                 struct commit *parent = commit->parents->item;
 
1487                 if (parse_commit(parent))
 
1488                         return error(_("could not parse parent commit %s"),
 
1489                                 oid_to_hex(&parent->object.oid));
 
1490                 ptree_oid = get_commit_tree_oid(parent);
 
1492                 ptree_oid = the_hash_algo->empty_tree; /* commit is root */
 
1495         return oideq(ptree_oid, get_commit_tree_oid(commit));
 
1499  * Should empty commits be allowed?  Return status:
 
1500  *    <0: Error in is_index_unchanged(r) or is_original_commit_empty(commit)
 
1501  *     0: Halt on empty commit
 
1502  *     1: Allow empty commit
 
1503  *     2: Drop empty commit
 
1505 static int allow_empty(struct repository *r,
 
1506                        struct replay_opts *opts,
 
1507                        struct commit *commit)
 
1509         int index_unchanged, originally_empty;
 
1514          * (1) we do not allow empty at all and error out.
 
1516          * (2) we allow ones that were initially empty, and
 
1517          *     just drop the ones that become empty
 
1519          * (3) we allow ones that were initially empty, but
 
1520          *     halt for the ones that become empty;
 
1522          * (4) we allow both.
 
1524         if (!opts->allow_empty)
 
1525                 return 0; /* let "git commit" barf as necessary */
 
1527         index_unchanged = is_index_unchanged(r);
 
1528         if (index_unchanged < 0)
 
1529                 return index_unchanged;
 
1530         if (!index_unchanged)
 
1531                 return 0; /* we do not have to say --allow-empty */
 
1533         if (opts->keep_redundant_commits)
 
1536         originally_empty = is_original_commit_empty(commit);
 
1537         if (originally_empty < 0)
 
1538                 return originally_empty;
 
1539         if (originally_empty)
 
1541         else if (opts->drop_redundant_commits)
 
1550 } todo_command_info[] = {
 
1567 static const char *command_to_string(const enum todo_command command)
 
1569         if (command < TODO_COMMENT)
 
1570                 return todo_command_info[command].str;
 
1571         die(_("unknown command: %d"), command);
 
1574 static char command_to_char(const enum todo_command command)
 
1576         if (command < TODO_COMMENT)
 
1577                 return todo_command_info[command].c;
 
1578         return comment_line_char;
 
1581 static int is_noop(const enum todo_command command)
 
1583         return TODO_NOOP <= command;
 
1586 static int is_fixup(enum todo_command command)
 
1588         return command == TODO_FIXUP || command == TODO_SQUASH;
 
1591 /* Does this command create a (non-merge) commit? */
 
1592 static int is_pick_or_similar(enum todo_command command)
 
1607 static int update_squash_messages(struct repository *r,
 
1608                                   enum todo_command command,
 
1609                                   struct commit *commit,
 
1610                                   struct replay_opts *opts)
 
1612         struct strbuf buf = STRBUF_INIT;
 
1614         const char *message, *body;
 
1615         const char *encoding = get_commit_output_encoding();
 
1617         if (opts->current_fixup_count > 0) {
 
1618                 struct strbuf header = STRBUF_INIT;
 
1621                 if (strbuf_read_file(&buf, rebase_path_squash_msg(), 9) <= 0)
 
1622                         return error(_("could not read '%s'"),
 
1623                                 rebase_path_squash_msg());
 
1625                 eol = buf.buf[0] != comment_line_char ?
 
1626                         buf.buf : strchrnul(buf.buf, '\n');
 
1628                 strbuf_addf(&header, "%c ", comment_line_char);
 
1629                 strbuf_addf(&header, _("This is a combination of %d commits."),
 
1630                             opts->current_fixup_count + 2);
 
1631                 strbuf_splice(&buf, 0, eol - buf.buf, header.buf, header.len);
 
1632                 strbuf_release(&header);
 
1634                 struct object_id head;
 
1635                 struct commit *head_commit;
 
1636                 const char *head_message, *body;
 
1638                 if (get_oid("HEAD", &head))
 
1639                         return error(_("need a HEAD to fixup"));
 
1640                 if (!(head_commit = lookup_commit_reference(r, &head)))
 
1641                         return error(_("could not read HEAD"));
 
1642                 if (!(head_message = logmsg_reencode(head_commit, NULL, encoding)))
 
1643                         return error(_("could not read HEAD's commit message"));
 
1645                 find_commit_subject(head_message, &body);
 
1646                 if (write_message(body, strlen(body),
 
1647                                   rebase_path_fixup_msg(), 0)) {
 
1648                         unuse_commit_buffer(head_commit, head_message);
 
1649                         return error(_("cannot write '%s'"),
 
1650                                      rebase_path_fixup_msg());
 
1653                 strbuf_addf(&buf, "%c ", comment_line_char);
 
1654                 strbuf_addf(&buf, _("This is a combination of %d commits."), 2);
 
1655                 strbuf_addf(&buf, "\n%c ", comment_line_char);
 
1656                 strbuf_addstr(&buf, _("This is the 1st commit message:"));
 
1657                 strbuf_addstr(&buf, "\n\n");
 
1658                 strbuf_addstr(&buf, body);
 
1660                 unuse_commit_buffer(head_commit, head_message);
 
1663         if (!(message = logmsg_reencode(commit, NULL, encoding)))
 
1664                 return error(_("could not read commit message of %s"),
 
1665                              oid_to_hex(&commit->object.oid));
 
1666         find_commit_subject(message, &body);
 
1668         if (command == TODO_SQUASH) {
 
1669                 unlink(rebase_path_fixup_msg());
 
1670                 strbuf_addf(&buf, "\n%c ", comment_line_char);
 
1671                 strbuf_addf(&buf, _("This is the commit message #%d:"),
 
1672                             ++opts->current_fixup_count + 1);
 
1673                 strbuf_addstr(&buf, "\n\n");
 
1674                 strbuf_addstr(&buf, body);
 
1675         } else if (command == TODO_FIXUP) {
 
1676                 strbuf_addf(&buf, "\n%c ", comment_line_char);
 
1677                 strbuf_addf(&buf, _("The commit message #%d will be skipped:"),
 
1678                             ++opts->current_fixup_count + 1);
 
1679                 strbuf_addstr(&buf, "\n\n");
 
1680                 strbuf_add_commented_lines(&buf, body, strlen(body));
 
1682                 return error(_("unknown command: %d"), command);
 
1683         unuse_commit_buffer(commit, message);
 
1685         res = write_message(buf.buf, buf.len, rebase_path_squash_msg(), 0);
 
1686         strbuf_release(&buf);
 
1689                 strbuf_addf(&opts->current_fixups, "%s%s %s",
 
1690                             opts->current_fixups.len ? "\n" : "",
 
1691                             command_to_string(command),
 
1692                             oid_to_hex(&commit->object.oid));
 
1693                 res = write_message(opts->current_fixups.buf,
 
1694                                     opts->current_fixups.len,
 
1695                                     rebase_path_current_fixups(), 0);
 
1701 static void flush_rewritten_pending(void)
 
1703         struct strbuf buf = STRBUF_INIT;
 
1704         struct object_id newoid;
 
1707         if (strbuf_read_file(&buf, rebase_path_rewritten_pending(), (GIT_MAX_HEXSZ + 1) * 2) > 0 &&
 
1708             !get_oid("HEAD", &newoid) &&
 
1709             (out = fopen_or_warn(rebase_path_rewritten_list(), "a"))) {
 
1710                 char *bol = buf.buf, *eol;
 
1713                         eol = strchrnul(bol, '\n');
 
1714                         fprintf(out, "%.*s %s\n", (int)(eol - bol),
 
1715                                         bol, oid_to_hex(&newoid));
 
1721                 unlink(rebase_path_rewritten_pending());
 
1723         strbuf_release(&buf);
 
1726 static void record_in_rewritten(struct object_id *oid,
 
1727                 enum todo_command next_command)
 
1729         FILE *out = fopen_or_warn(rebase_path_rewritten_pending(), "a");
 
1734         fprintf(out, "%s\n", oid_to_hex(oid));
 
1737         if (!is_fixup(next_command))
 
1738                 flush_rewritten_pending();
 
1741 static int do_pick_commit(struct repository *r,
 
1742                           enum todo_command command,
 
1743                           struct commit *commit,
 
1744                           struct replay_opts *opts,
 
1745                           int final_fixup, int *check_todo)
 
1747         unsigned int flags = opts->edit ? EDIT_MSG : 0;
 
1748         const char *msg_file = opts->edit ? NULL : git_path_merge_msg(r);
 
1749         struct object_id head;
 
1750         struct commit *base, *next, *parent;
 
1751         const char *base_label, *next_label;
 
1752         char *author = NULL;
 
1753         struct commit_message msg = { NULL, NULL, NULL, NULL };
 
1754         struct strbuf msgbuf = STRBUF_INIT;
 
1755         int res, unborn = 0, reword = 0, allow, drop_commit;
 
1757         if (opts->no_commit) {
 
1759                  * We do not intend to commit immediately.  We just want to
 
1760                  * merge the differences in, so let's compute the tree
 
1761                  * that represents the "current" state for merge-recursive
 
1764                 if (write_index_as_tree(&head, r->index, r->index_file, 0, NULL))
 
1765                         return error(_("your index file is unmerged."));
 
1767                 unborn = get_oid("HEAD", &head);
 
1768                 /* Do we want to generate a root commit? */
 
1769                 if (is_pick_or_similar(command) && opts->have_squash_onto &&
 
1770                     oideq(&head, &opts->squash_onto)) {
 
1771                         if (is_fixup(command))
 
1772                                 return error(_("cannot fixup root commit"));
 
1773                         flags |= CREATE_ROOT_COMMIT;
 
1776                         oidcpy(&head, the_hash_algo->empty_tree);
 
1777                 if (index_differs_from(r, unborn ? empty_tree_oid_hex() : "HEAD",
 
1779                         return error_dirty_index(r, opts);
 
1781         discard_index(r->index);
 
1783         if (!commit->parents)
 
1785         else if (commit->parents->next) {
 
1786                 /* Reverting or cherry-picking a merge commit */
 
1788                 struct commit_list *p;
 
1790                 if (!opts->mainline)
 
1791                         return error(_("commit %s is a merge but no -m option was given."),
 
1792                                 oid_to_hex(&commit->object.oid));
 
1794                 for (cnt = 1, p = commit->parents;
 
1795                      cnt != opts->mainline && p;
 
1798                 if (cnt != opts->mainline || !p)
 
1799                         return error(_("commit %s does not have parent %d"),
 
1800                                 oid_to_hex(&commit->object.oid), opts->mainline);
 
1802         } else if (1 < opts->mainline)
 
1804                  *  Non-first parent explicitly specified as mainline for
 
1807                 return error(_("commit %s does not have parent %d"),
 
1808                              oid_to_hex(&commit->object.oid), opts->mainline);
 
1810                 parent = commit->parents->item;
 
1812         if (get_message(commit, &msg) != 0)
 
1813                 return error(_("cannot get commit message for %s"),
 
1814                         oid_to_hex(&commit->object.oid));
 
1816         if (opts->allow_ff && !is_fixup(command) &&
 
1817             ((parent && oideq(&parent->object.oid, &head)) ||
 
1818              (!parent && unborn))) {
 
1819                 if (is_rebase_i(opts))
 
1820                         write_author_script(msg.message);
 
1821                 res = fast_forward_to(r, &commit->object.oid, &head, unborn,
 
1823                 if (res || command != TODO_REWORD)
 
1827                 goto fast_forward_edit;
 
1829         if (parent && parse_commit(parent) < 0)
 
1830                 /* TRANSLATORS: The first %s will be a "todo" command like
 
1831                    "revert" or "pick", the second %s a SHA1. */
 
1832                 return error(_("%s: cannot parse parent commit %s"),
 
1833                         command_to_string(command),
 
1834                         oid_to_hex(&parent->object.oid));
 
1837          * "commit" is an existing commit.  We would want to apply
 
1838          * the difference it introduces since its first parent "prev"
 
1839          * on top of the current HEAD if we are cherry-pick.  Or the
 
1840          * reverse of it if we are revert.
 
1843         if (command == TODO_REVERT) {
 
1845                 base_label = msg.label;
 
1847                 next_label = msg.parent_label;
 
1848                 strbuf_addstr(&msgbuf, "Revert \"");
 
1849                 strbuf_addstr(&msgbuf, msg.subject);
 
1850                 strbuf_addstr(&msgbuf, "\"\n\nThis reverts commit ");
 
1851                 strbuf_addstr(&msgbuf, oid_to_hex(&commit->object.oid));
 
1853                 if (commit->parents && commit->parents->next) {
 
1854                         strbuf_addstr(&msgbuf, ", reversing\nchanges made to ");
 
1855                         strbuf_addstr(&msgbuf, oid_to_hex(&parent->object.oid));
 
1857                 strbuf_addstr(&msgbuf, ".\n");
 
1862                 base_label = msg.parent_label;
 
1864                 next_label = msg.label;
 
1866                 /* Append the commit log message to msgbuf. */
 
1867                 if (find_commit_subject(msg.message, &p))
 
1868                         strbuf_addstr(&msgbuf, p);
 
1870                 if (opts->record_origin) {
 
1871                         strbuf_complete_line(&msgbuf);
 
1872                         if (!has_conforming_footer(&msgbuf, NULL, 0))
 
1873                                 strbuf_addch(&msgbuf, '\n');
 
1874                         strbuf_addstr(&msgbuf, cherry_picked_prefix);
 
1875                         strbuf_addstr(&msgbuf, oid_to_hex(&commit->object.oid));
 
1876                         strbuf_addstr(&msgbuf, ")\n");
 
1878                 if (!is_fixup(command))
 
1879                         author = get_author(msg.message);
 
1882         if (command == TODO_REWORD)
 
1884         else if (is_fixup(command)) {
 
1885                 if (update_squash_messages(r, command, commit, opts))
 
1889                         msg_file = rebase_path_squash_msg();
 
1890                 else if (file_exists(rebase_path_fixup_msg())) {
 
1891                         flags |= CLEANUP_MSG;
 
1892                         msg_file = rebase_path_fixup_msg();
 
1894                         const char *dest = git_path_squash_msg(r);
 
1896                         if (copy_file(dest, rebase_path_squash_msg(), 0666))
 
1897                                 return error(_("could not rename '%s' to '%s'"),
 
1898                                              rebase_path_squash_msg(), dest);
 
1899                         unlink(git_path_merge_msg(r));
 
1905         if (opts->signoff && !is_fixup(command))
 
1906                 append_signoff(&msgbuf, 0, 0);
 
1908         if (is_rebase_i(opts) && write_author_script(msg.message) < 0)
 
1910         else if (!opts->strategy || !strcmp(opts->strategy, "recursive") || command == TODO_REVERT) {
 
1911                 res = do_recursive_merge(r, base, next, base_label, next_label,
 
1912                                          &head, &msgbuf, opts);
 
1916                 res |= write_message(msgbuf.buf, msgbuf.len,
 
1917                                      git_path_merge_msg(r), 0);
 
1919                 struct commit_list *common = NULL;
 
1920                 struct commit_list *remotes = NULL;
 
1922                 res = write_message(msgbuf.buf, msgbuf.len,
 
1923                                     git_path_merge_msg(r), 0);
 
1925                 commit_list_insert(base, &common);
 
1926                 commit_list_insert(next, &remotes);
 
1927                 res |= try_merge_command(r, opts->strategy,
 
1928                                          opts->xopts_nr, (const char **)opts->xopts,
 
1929                                         common, oid_to_hex(&head), remotes);
 
1930                 free_commit_list(common);
 
1931                 free_commit_list(remotes);
 
1933         strbuf_release(&msgbuf);
 
1936          * If the merge was clean or if it failed due to conflict, we write
 
1937          * CHERRY_PICK_HEAD for the subsequent invocation of commit to use.
 
1938          * However, if the merge did not even start, then we don't want to
 
1941         if ((command == TODO_PICK || command == TODO_REWORD ||
 
1942              command == TODO_EDIT) && !opts->no_commit &&
 
1943             (res == 0 || res == 1) &&
 
1944             update_ref(NULL, "CHERRY_PICK_HEAD", &commit->object.oid, NULL,
 
1945                        REF_NO_DEREF, UPDATE_REFS_MSG_ON_ERR))
 
1947         if (command == TODO_REVERT && ((opts->no_commit && res == 0) || res == 1) &&
 
1948             update_ref(NULL, "REVERT_HEAD", &commit->object.oid, NULL,
 
1949                        REF_NO_DEREF, UPDATE_REFS_MSG_ON_ERR))
 
1953                 error(command == TODO_REVERT
 
1954                       ? _("could not revert %s... %s")
 
1955                       : _("could not apply %s... %s"),
 
1956                       short_commit_name(commit), msg.subject);
 
1957                 print_advice(r, res == 1, opts);
 
1958                 repo_rerere(r, opts->allow_rerere_auto);
 
1963         allow = allow_empty(r, opts, commit);
 
1967         } else if (allow == 1) {
 
1968                 flags |= ALLOW_EMPTY;
 
1969         } else if (allow == 2) {
 
1971                 refs_delete_ref(get_main_ref_store(r), "", "CHERRY_PICK_HEAD",
 
1973                 unlink(git_path_merge_msg(r));
 
1975                         _("dropping %s %s -- patch contents already upstream\n"),
 
1976                         oid_to_hex(&commit->object.oid), msg.subject);
 
1977         } /* else allow == 0 and there's nothing special to do */
 
1978         if (!opts->no_commit && !drop_commit) {
 
1979                 if (author || command == TODO_REVERT || (flags & AMEND_MSG))
 
1980                         res = do_commit(r, msg_file, author, opts, flags,
 
1981                                         commit? &commit->object.oid : NULL);
 
1983                         res = error(_("unable to parse commit author"));
 
1984                 *check_todo = !!(flags & EDIT_MSG);
 
1985                 if (!res && reword) {
 
1987                         res = run_git_commit(r, NULL, opts, EDIT_MSG |
 
1988                                              VERIFY_MSG | AMEND_MSG |
 
1989                                              (flags & ALLOW_EMPTY));
 
1995         if (!res && final_fixup) {
 
1996                 unlink(rebase_path_fixup_msg());
 
1997                 unlink(rebase_path_squash_msg());
 
1998                 unlink(rebase_path_current_fixups());
 
1999                 strbuf_reset(&opts->current_fixups);
 
2000                 opts->current_fixup_count = 0;
 
2004         free_message(commit, &msg);
 
2006         update_abort_safety_file();
 
2011 static int prepare_revs(struct replay_opts *opts)
 
2014          * picking (but not reverting) ranges (but not individual revisions)
 
2015          * should be done in reverse
 
2017         if (opts->action == REPLAY_PICK && !opts->revs->no_walk)
 
2018                 opts->revs->reverse ^= 1;
 
2020         if (prepare_revision_walk(opts->revs))
 
2021                 return error(_("revision walk setup failed"));
 
2026 static int read_and_refresh_cache(struct repository *r,
 
2027                                   struct replay_opts *opts)
 
2029         struct lock_file index_lock = LOCK_INIT;
 
2030         int index_fd = repo_hold_locked_index(r, &index_lock, 0);
 
2031         if (repo_read_index(r) < 0) {
 
2032                 rollback_lock_file(&index_lock);
 
2033                 return error(_("git %s: failed to read the index"),
 
2034                         _(action_name(opts)));
 
2036         refresh_index(r->index, REFRESH_QUIET|REFRESH_UNMERGED, NULL, NULL, NULL);
 
2037         if (index_fd >= 0) {
 
2038                 if (write_locked_index(r->index, &index_lock,
 
2039                                        COMMIT_LOCK | SKIP_IF_UNCHANGED)) {
 
2040                         return error(_("git %s: failed to refresh the index"),
 
2041                                 _(action_name(opts)));
 
2047 enum todo_item_flags {
 
2048         TODO_EDIT_MERGE_MSG = 1
 
2051 void todo_list_release(struct todo_list *todo_list)
 
2053         strbuf_release(&todo_list->buf);
 
2054         FREE_AND_NULL(todo_list->items);
 
2055         todo_list->nr = todo_list->alloc = 0;
 
2058 static struct todo_item *append_new_todo(struct todo_list *todo_list)
 
2060         ALLOC_GROW(todo_list->items, todo_list->nr + 1, todo_list->alloc);
 
2061         todo_list->total_nr++;
 
2062         return todo_list->items + todo_list->nr++;
 
2065 const char *todo_item_get_arg(struct todo_list *todo_list,
 
2066                               struct todo_item *item)
 
2068         return todo_list->buf.buf + item->arg_offset;
 
2071 static int is_command(enum todo_command command, const char **bol)
 
2073         const char *str = todo_command_info[command].str;
 
2074         const char nick = todo_command_info[command].c;
 
2075         const char *p = *bol + 1;
 
2077         return skip_prefix(*bol, str, bol) ||
 
2078                 ((nick && **bol == nick) &&
 
2079                  (*p == ' ' || *p == '\t' || *p == '\n' || *p == '\r' || !*p) &&
 
2083 static int parse_insn_line(struct repository *r, struct todo_item *item,
 
2084                            const char *buf, const char *bol, char *eol)
 
2086         struct object_id commit_oid;
 
2087         char *end_of_object_name;
 
2088         int i, saved, status, padding;
 
2093         bol += strspn(bol, " \t");
 
2095         if (bol == eol || *bol == '\r' || *bol == comment_line_char) {
 
2096                 item->command = TODO_COMMENT;
 
2097                 item->commit = NULL;
 
2098                 item->arg_offset = bol - buf;
 
2099                 item->arg_len = eol - bol;
 
2103         for (i = 0; i < TODO_COMMENT; i++)
 
2104                 if (is_command(i, &bol)) {
 
2108         if (i >= TODO_COMMENT)
 
2111         /* Eat up extra spaces/ tabs before object name */
 
2112         padding = strspn(bol, " \t");
 
2115         if (item->command == TODO_NOOP || item->command == TODO_BREAK) {
 
2117                         return error(_("%s does not accept arguments: '%s'"),
 
2118                                      command_to_string(item->command), bol);
 
2119                 item->commit = NULL;
 
2120                 item->arg_offset = bol - buf;
 
2121                 item->arg_len = eol - bol;
 
2126                 return error(_("missing arguments for %s"),
 
2127                              command_to_string(item->command));
 
2129         if (item->command == TODO_EXEC || item->command == TODO_LABEL ||
 
2130             item->command == TODO_RESET) {
 
2131                 item->commit = NULL;
 
2132                 item->arg_offset = bol - buf;
 
2133                 item->arg_len = (int)(eol - bol);
 
2137         if (item->command == TODO_MERGE) {
 
2138                 if (skip_prefix(bol, "-C", &bol))
 
2139                         bol += strspn(bol, " \t");
 
2140                 else if (skip_prefix(bol, "-c", &bol)) {
 
2141                         bol += strspn(bol, " \t");
 
2142                         item->flags |= TODO_EDIT_MERGE_MSG;
 
2144                         item->flags |= TODO_EDIT_MERGE_MSG;
 
2145                         item->commit = NULL;
 
2146                         item->arg_offset = bol - buf;
 
2147                         item->arg_len = (int)(eol - bol);
 
2152         end_of_object_name = (char *) bol + strcspn(bol, " \t\n");
 
2153         saved = *end_of_object_name;
 
2154         *end_of_object_name = '\0';
 
2155         status = get_oid(bol, &commit_oid);
 
2157                 error(_("could not parse '%s'"), bol); /* return later */
 
2158         *end_of_object_name = saved;
 
2160         bol = end_of_object_name + strspn(end_of_object_name, " \t");
 
2161         item->arg_offset = bol - buf;
 
2162         item->arg_len = (int)(eol - bol);
 
2167         item->commit = lookup_commit_reference(r, &commit_oid);
 
2168         return item->commit ? 0 : -1;
 
2171 int sequencer_get_last_command(struct repository *r, enum replay_action *action)
 
2173         const char *todo_file, *bol;
 
2174         struct strbuf buf = STRBUF_INIT;
 
2177         todo_file = git_path_todo_file();
 
2178         if (strbuf_read_file(&buf, todo_file, 0) < 0) {
 
2179                 if (errno == ENOENT || errno == ENOTDIR)
 
2182                         return error_errno("unable to open '%s'", todo_file);
 
2184         bol = buf.buf + strspn(buf.buf, " \t\r\n");
 
2185         if (is_command(TODO_PICK, &bol) && (*bol == ' ' || *bol == '\t'))
 
2186                 *action = REPLAY_PICK;
 
2187         else if (is_command(TODO_REVERT, &bol) &&
 
2188                  (*bol == ' ' || *bol == '\t'))
 
2189                 *action = REPLAY_REVERT;
 
2193         strbuf_release(&buf);
 
2198 int todo_list_parse_insn_buffer(struct repository *r, char *buf,
 
2199                                 struct todo_list *todo_list)
 
2201         struct todo_item *item;
 
2202         char *p = buf, *next_p;
 
2203         int i, res = 0, fixup_okay = file_exists(rebase_path_done());
 
2205         todo_list->current = todo_list->nr = 0;
 
2207         for (i = 1; *p; i++, p = next_p) {
 
2208                 char *eol = strchrnul(p, '\n');
 
2210                 next_p = *eol ? eol + 1 /* skip LF */ : eol;
 
2212                 if (p != eol && eol[-1] == '\r')
 
2213                         eol--; /* strip Carriage Return */
 
2215                 item = append_new_todo(todo_list);
 
2216                 item->offset_in_buf = p - todo_list->buf.buf;
 
2217                 if (parse_insn_line(r, item, buf, p, eol)) {
 
2218                         res = error(_("invalid line %d: %.*s"),
 
2219                                 i, (int)(eol - p), p);
 
2220                         item->command = TODO_COMMENT + 1;
 
2221                         item->arg_offset = p - buf;
 
2222                         item->arg_len = (int)(eol - p);
 
2223                         item->commit = NULL;
 
2228                 else if (is_fixup(item->command))
 
2229                         return error(_("cannot '%s' without a previous commit"),
 
2230                                 command_to_string(item->command));
 
2231                 else if (!is_noop(item->command))
 
2238 static int count_commands(struct todo_list *todo_list)
 
2242         for (i = 0; i < todo_list->nr; i++)
 
2243                 if (todo_list->items[i].command != TODO_COMMENT)
 
2249 static int get_item_line_offset(struct todo_list *todo_list, int index)
 
2251         return index < todo_list->nr ?
 
2252                 todo_list->items[index].offset_in_buf : todo_list->buf.len;
 
2255 static const char *get_item_line(struct todo_list *todo_list, int index)
 
2257         return todo_list->buf.buf + get_item_line_offset(todo_list, index);
 
2260 static int get_item_line_length(struct todo_list *todo_list, int index)
 
2262         return get_item_line_offset(todo_list, index + 1)
 
2263                 -  get_item_line_offset(todo_list, index);
 
2266 static ssize_t strbuf_read_file_or_whine(struct strbuf *sb, const char *path)
 
2271         fd = open(path, O_RDONLY);
 
2273                 return error_errno(_("could not open '%s'"), path);
 
2274         len = strbuf_read(sb, fd, 0);
 
2277                 return error(_("could not read '%s'."), path);
 
2281 static int have_finished_the_last_pick(void)
 
2283         struct strbuf buf = STRBUF_INIT;
 
2285         const char *todo_path = git_path_todo_file();
 
2288         if (strbuf_read_file(&buf, todo_path, 0) < 0) {
 
2289                 if (errno == ENOENT) {
 
2292                         error_errno("unable to open '%s'", todo_path);
 
2296         /* If there is only one line then we are done */
 
2297         eol = strchr(buf.buf, '\n');
 
2298         if (!eol || !eol[1])
 
2301         strbuf_release(&buf);
 
2306 void sequencer_post_commit_cleanup(struct repository *r, int verbose)
 
2308         struct replay_opts opts = REPLAY_OPTS_INIT;
 
2309         int need_cleanup = 0;
 
2311         if (refs_ref_exists(get_main_ref_store(r), "CHERRY_PICK_HEAD")) {
 
2312                 if (!refs_delete_ref(get_main_ref_store(r), "",
 
2313                                      "CHERRY_PICK_HEAD", NULL, 0) &&
 
2315                         warning(_("cancelling a cherry picking in progress"));
 
2316                 opts.action = REPLAY_PICK;
 
2320         if (refs_ref_exists(get_main_ref_store(r), "REVERT_HEAD")) {
 
2321                 if (!refs_delete_ref(get_main_ref_store(r), "", "REVERT_HEAD",
 
2324                         warning(_("cancelling a revert in progress"));
 
2325                 opts.action = REPLAY_REVERT;
 
2332         if (!have_finished_the_last_pick())
 
2335         sequencer_remove_state(&opts);
 
2338 static void todo_list_write_total_nr(struct todo_list *todo_list)
 
2340         FILE *f = fopen_or_warn(rebase_path_msgtotal(), "w");
 
2343                 fprintf(f, "%d\n", todo_list->total_nr);
 
2348 static int read_populate_todo(struct repository *r,
 
2349                               struct todo_list *todo_list,
 
2350                               struct replay_opts *opts)
 
2353         const char *todo_file = get_todo_path(opts);
 
2356         strbuf_reset(&todo_list->buf);
 
2357         if (strbuf_read_file_or_whine(&todo_list->buf, todo_file) < 0)
 
2360         res = stat(todo_file, &st);
 
2362                 return error(_("could not stat '%s'"), todo_file);
 
2363         fill_stat_data(&todo_list->stat, &st);
 
2365         res = todo_list_parse_insn_buffer(r, todo_list->buf.buf, todo_list);
 
2367                 if (is_rebase_i(opts))
 
2368                         return error(_("please fix this using "
 
2369                                        "'git rebase --edit-todo'."));
 
2370                 return error(_("unusable instruction sheet: '%s'"), todo_file);
 
2373         if (!todo_list->nr &&
 
2374             (!is_rebase_i(opts) || !file_exists(rebase_path_done())))
 
2375                 return error(_("no commits parsed."));
 
2377         if (!is_rebase_i(opts)) {
 
2378                 enum todo_command valid =
 
2379                         opts->action == REPLAY_PICK ? TODO_PICK : TODO_REVERT;
 
2382                 for (i = 0; i < todo_list->nr; i++)
 
2383                         if (valid == todo_list->items[i].command)
 
2385                         else if (valid == TODO_PICK)
 
2386                                 return error(_("cannot cherry-pick during a revert."));
 
2388                                 return error(_("cannot revert during a cherry-pick."));
 
2391         if (is_rebase_i(opts)) {
 
2392                 struct todo_list done = TODO_LIST_INIT;
 
2394                 if (strbuf_read_file(&done.buf, rebase_path_done(), 0) > 0 &&
 
2395                     !todo_list_parse_insn_buffer(r, done.buf.buf, &done))
 
2396                         todo_list->done_nr = count_commands(&done);
 
2398                         todo_list->done_nr = 0;
 
2400                 todo_list->total_nr = todo_list->done_nr
 
2401                         + count_commands(todo_list);
 
2402                 todo_list_release(&done);
 
2404                 todo_list_write_total_nr(todo_list);
 
2410 static int git_config_string_dup(char **dest,
 
2411                                  const char *var, const char *value)
 
2414                 return config_error_nonbool(var);
 
2416         *dest = xstrdup(value);
 
2420 static int populate_opts_cb(const char *key, const char *value, void *data)
 
2422         struct replay_opts *opts = data;
 
2427         else if (!strcmp(key, "options.no-commit"))
 
2428                 opts->no_commit = git_config_bool_or_int(key, value, &error_flag);
 
2429         else if (!strcmp(key, "options.edit"))
 
2430                 opts->edit = git_config_bool_or_int(key, value, &error_flag);
 
2431         else if (!strcmp(key, "options.allow-empty"))
 
2433                         git_config_bool_or_int(key, value, &error_flag);
 
2434         else if (!strcmp(key, "options.allow-empty-message"))
 
2435                 opts->allow_empty_message =
 
2436                         git_config_bool_or_int(key, value, &error_flag);
 
2437         else if (!strcmp(key, "options.keep-redundant-commits"))
 
2438                 opts->keep_redundant_commits =
 
2439                         git_config_bool_or_int(key, value, &error_flag);
 
2440         else if (!strcmp(key, "options.signoff"))
 
2441                 opts->signoff = git_config_bool_or_int(key, value, &error_flag);
 
2442         else if (!strcmp(key, "options.record-origin"))
 
2443                 opts->record_origin = git_config_bool_or_int(key, value, &error_flag);
 
2444         else if (!strcmp(key, "options.allow-ff"))
 
2445                 opts->allow_ff = git_config_bool_or_int(key, value, &error_flag);
 
2446         else if (!strcmp(key, "options.mainline"))
 
2447                 opts->mainline = git_config_int(key, value);
 
2448         else if (!strcmp(key, "options.strategy"))
 
2449                 git_config_string_dup(&opts->strategy, key, value);
 
2450         else if (!strcmp(key, "options.gpg-sign"))
 
2451                 git_config_string_dup(&opts->gpg_sign, key, value);
 
2452         else if (!strcmp(key, "options.strategy-option")) {
 
2453                 ALLOC_GROW(opts->xopts, opts->xopts_nr + 1, opts->xopts_alloc);
 
2454                 opts->xopts[opts->xopts_nr++] = xstrdup(value);
 
2455         } else if (!strcmp(key, "options.allow-rerere-auto"))
 
2456                 opts->allow_rerere_auto =
 
2457                         git_config_bool_or_int(key, value, &error_flag) ?
 
2458                                 RERERE_AUTOUPDATE : RERERE_NOAUTOUPDATE;
 
2459         else if (!strcmp(key, "options.default-msg-cleanup")) {
 
2460                 opts->explicit_cleanup = 1;
 
2461                 opts->default_msg_cleanup = get_cleanup_mode(value, 1);
 
2463                 return error(_("invalid key: %s"), key);
 
2466                 return error(_("invalid value for %s: %s"), key, value);
 
2471 void parse_strategy_opts(struct replay_opts *opts, char *raw_opts)
 
2474         char *strategy_opts_string = raw_opts;
 
2476         if (*strategy_opts_string == ' ')
 
2477                 strategy_opts_string++;
 
2479         opts->xopts_nr = split_cmdline(strategy_opts_string,
 
2480                                        (const char ***)&opts->xopts);
 
2481         for (i = 0; i < opts->xopts_nr; i++) {
 
2482                 const char *arg = opts->xopts[i];
 
2484                 skip_prefix(arg, "--", &arg);
 
2485                 opts->xopts[i] = xstrdup(arg);
 
2489 static void read_strategy_opts(struct replay_opts *opts, struct strbuf *buf)
 
2492         if (!read_oneliner(buf, rebase_path_strategy(), 0))
 
2494         opts->strategy = strbuf_detach(buf, NULL);
 
2495         if (!read_oneliner(buf, rebase_path_strategy_opts(), 0))
 
2498         parse_strategy_opts(opts, buf->buf);
 
2501 static int read_populate_opts(struct replay_opts *opts)
 
2503         if (is_rebase_i(opts)) {
 
2504                 struct strbuf buf = STRBUF_INIT;
 
2507                 if (read_oneliner(&buf, rebase_path_gpg_sign_opt(),
 
2508                                   READ_ONELINER_SKIP_IF_EMPTY)) {
 
2509                         if (!starts_with(buf.buf, "-S"))
 
2512                                 free(opts->gpg_sign);
 
2513                                 opts->gpg_sign = xstrdup(buf.buf + 2);
 
2518                 if (read_oneliner(&buf, rebase_path_allow_rerere_autoupdate(),
 
2519                                   READ_ONELINER_SKIP_IF_EMPTY)) {
 
2520                         if (!strcmp(buf.buf, "--rerere-autoupdate"))
 
2521                                 opts->allow_rerere_auto = RERERE_AUTOUPDATE;
 
2522                         else if (!strcmp(buf.buf, "--no-rerere-autoupdate"))
 
2523                                 opts->allow_rerere_auto = RERERE_NOAUTOUPDATE;
 
2527                 if (file_exists(rebase_path_verbose()))
 
2530                 if (file_exists(rebase_path_quiet()))
 
2533                 if (file_exists(rebase_path_signoff())) {
 
2538                 if (file_exists(rebase_path_reschedule_failed_exec()))
 
2539                         opts->reschedule_failed_exec = 1;
 
2541                 if (file_exists(rebase_path_drop_redundant_commits()))
 
2542                         opts->drop_redundant_commits = 1;
 
2544                 if (file_exists(rebase_path_keep_redundant_commits()))
 
2545                         opts->keep_redundant_commits = 1;
 
2547                 read_strategy_opts(opts, &buf);
 
2550                 if (read_oneliner(&opts->current_fixups,
 
2551                                   rebase_path_current_fixups(),
 
2552                                   READ_ONELINER_SKIP_IF_EMPTY)) {
 
2553                         const char *p = opts->current_fixups.buf;
 
2554                         opts->current_fixup_count = 1;
 
2555                         while ((p = strchr(p, '\n'))) {
 
2556                                 opts->current_fixup_count++;
 
2561                 if (read_oneliner(&buf, rebase_path_squash_onto(), 0)) {
 
2562                         if (get_oid_hex(buf.buf, &opts->squash_onto) < 0) {
 
2563                                 ret = error(_("unusable squash-onto"));
 
2566                         opts->have_squash_onto = 1;
 
2570                 strbuf_release(&buf);
 
2574         if (!file_exists(git_path_opts_file()))
 
2577          * The function git_parse_source(), called from git_config_from_file(),
 
2578          * may die() in case of a syntactically incorrect file. We do not care
 
2579          * about this case, though, because we wrote that file ourselves, so we
 
2580          * are pretty certain that it is syntactically correct.
 
2582         if (git_config_from_file(populate_opts_cb, git_path_opts_file(), opts) < 0)
 
2583                 return error(_("malformed options sheet: '%s'"),
 
2584                         git_path_opts_file());
 
2588 static void write_strategy_opts(struct replay_opts *opts)
 
2591         struct strbuf buf = STRBUF_INIT;
 
2593         for (i = 0; i < opts->xopts_nr; ++i)
 
2594                 strbuf_addf(&buf, " --%s", opts->xopts[i]);
 
2596         write_file(rebase_path_strategy_opts(), "%s\n", buf.buf);
 
2597         strbuf_release(&buf);
 
2600 int write_basic_state(struct replay_opts *opts, const char *head_name,
 
2601                       struct commit *onto, const char *orig_head)
 
2604                 write_file(rebase_path_head_name(), "%s\n", head_name);
 
2606                 write_file(rebase_path_onto(), "%s\n",
 
2607                            oid_to_hex(&onto->object.oid));
 
2609                 write_file(rebase_path_orig_head(), "%s\n", orig_head);
 
2612                 write_file(rebase_path_quiet(), "%s", "");
 
2614                 write_file(rebase_path_verbose(), "%s", "");
 
2616                 write_file(rebase_path_strategy(), "%s\n", opts->strategy);
 
2617         if (opts->xopts_nr > 0)
 
2618                 write_strategy_opts(opts);
 
2620         if (opts->allow_rerere_auto == RERERE_AUTOUPDATE)
 
2621                 write_file(rebase_path_allow_rerere_autoupdate(), "--rerere-autoupdate\n");
 
2622         else if (opts->allow_rerere_auto == RERERE_NOAUTOUPDATE)
 
2623                 write_file(rebase_path_allow_rerere_autoupdate(), "--no-rerere-autoupdate\n");
 
2626                 write_file(rebase_path_gpg_sign_opt(), "-S%s\n", opts->gpg_sign);
 
2628                 write_file(rebase_path_signoff(), "--signoff\n");
 
2629         if (opts->drop_redundant_commits)
 
2630                 write_file(rebase_path_drop_redundant_commits(), "%s", "");
 
2631         if (opts->keep_redundant_commits)
 
2632                 write_file(rebase_path_keep_redundant_commits(), "%s", "");
 
2633         if (opts->reschedule_failed_exec)
 
2634                 write_file(rebase_path_reschedule_failed_exec(), "%s", "");
 
2639 static int walk_revs_populate_todo(struct todo_list *todo_list,
 
2640                                 struct replay_opts *opts)
 
2642         enum todo_command command = opts->action == REPLAY_PICK ?
 
2643                 TODO_PICK : TODO_REVERT;
 
2644         const char *command_string = todo_command_info[command].str;
 
2645         const char *encoding;
 
2646         struct commit *commit;
 
2648         if (prepare_revs(opts))
 
2651         encoding = get_log_output_encoding();
 
2653         while ((commit = get_revision(opts->revs))) {
 
2654                 struct todo_item *item = append_new_todo(todo_list);
 
2655                 const char *commit_buffer = logmsg_reencode(commit, NULL, encoding);
 
2656                 const char *subject;
 
2659                 item->command = command;
 
2660                 item->commit = commit;
 
2661                 item->arg_offset = 0;
 
2663                 item->offset_in_buf = todo_list->buf.len;
 
2664                 subject_len = find_commit_subject(commit_buffer, &subject);
 
2665                 strbuf_addf(&todo_list->buf, "%s %s %.*s\n", command_string,
 
2666                         short_commit_name(commit), subject_len, subject);
 
2667                 unuse_commit_buffer(commit, commit_buffer);
 
2671                 return error(_("empty commit set passed"));
 
2676 static int create_seq_dir(struct repository *r)
 
2678         enum replay_action action;
 
2679         const char *in_progress_error = NULL;
 
2680         const char *in_progress_advice = NULL;
 
2681         unsigned int advise_skip =
 
2682                 refs_ref_exists(get_main_ref_store(r), "REVERT_HEAD") ||
 
2683                 refs_ref_exists(get_main_ref_store(r), "CHERRY_PICK_HEAD");
 
2685         if (!sequencer_get_last_command(r, &action)) {
 
2688                         in_progress_error = _("revert is already in progress");
 
2689                         in_progress_advice =
 
2690                         _("try \"git revert (--continue | %s--abort | --quit)\"");
 
2693                         in_progress_error = _("cherry-pick is already in progress");
 
2694                         in_progress_advice =
 
2695                         _("try \"git cherry-pick (--continue | %s--abort | --quit)\"");
 
2698                         BUG("unexpected action in create_seq_dir");
 
2701         if (in_progress_error) {
 
2702                 error("%s", in_progress_error);
 
2703                 if (advice_sequencer_in_use)
 
2704                         advise(in_progress_advice,
 
2705                                 advise_skip ? "--skip | " : "");
 
2708         if (mkdir(git_path_seq_dir(), 0777) < 0)
 
2709                 return error_errno(_("could not create sequencer directory '%s'"),
 
2710                                    git_path_seq_dir());
 
2715 static int save_head(const char *head)
 
2717         struct lock_file head_lock = LOCK_INIT;
 
2718         struct strbuf buf = STRBUF_INIT;
 
2722         fd = hold_lock_file_for_update(&head_lock, git_path_head_file(), 0);
 
2724                 return error_errno(_("could not lock HEAD"));
 
2725         strbuf_addf(&buf, "%s\n", head);
 
2726         written = write_in_full(fd, buf.buf, buf.len);
 
2727         strbuf_release(&buf);
 
2729                 error_errno(_("could not write to '%s'"), git_path_head_file());
 
2730                 rollback_lock_file(&head_lock);
 
2733         if (commit_lock_file(&head_lock) < 0)
 
2734                 return error(_("failed to finalize '%s'"), git_path_head_file());
 
2738 static int rollback_is_safe(void)
 
2740         struct strbuf sb = STRBUF_INIT;
 
2741         struct object_id expected_head, actual_head;
 
2743         if (strbuf_read_file(&sb, git_path_abort_safety_file(), 0) >= 0) {
 
2745                 if (get_oid_hex(sb.buf, &expected_head)) {
 
2746                         strbuf_release(&sb);
 
2747                         die(_("could not parse %s"), git_path_abort_safety_file());
 
2749                 strbuf_release(&sb);
 
2751         else if (errno == ENOENT)
 
2752                 oidclr(&expected_head);
 
2754                 die_errno(_("could not read '%s'"), git_path_abort_safety_file());
 
2756         if (get_oid("HEAD", &actual_head))
 
2757                 oidclr(&actual_head);
 
2759         return oideq(&actual_head, &expected_head);
 
2762 static int reset_merge(const struct object_id *oid)
 
2765         struct strvec argv = STRVEC_INIT;
 
2767         strvec_pushl(&argv, "reset", "--merge", NULL);
 
2769         if (!is_null_oid(oid))
 
2770                 strvec_push(&argv, oid_to_hex(oid));
 
2772         ret = run_command_v_opt(argv.v, RUN_GIT_CMD);
 
2773         strvec_clear(&argv);
 
2778 static int rollback_single_pick(struct repository *r)
 
2780         struct object_id head_oid;
 
2782         if (!refs_ref_exists(get_main_ref_store(r), "CHERRY_PICK_HEAD") &&
 
2783             !refs_ref_exists(get_main_ref_store(r), "REVERT_HEAD"))
 
2784                 return error(_("no cherry-pick or revert in progress"));
 
2785         if (read_ref_full("HEAD", 0, &head_oid, NULL))
 
2786                 return error(_("cannot resolve HEAD"));
 
2787         if (is_null_oid(&head_oid))
 
2788                 return error(_("cannot abort from a branch yet to be born"));
 
2789         return reset_merge(&head_oid);
 
2792 static int skip_single_pick(void)
 
2794         struct object_id head;
 
2796         if (read_ref_full("HEAD", 0, &head, NULL))
 
2797                 return error(_("cannot resolve HEAD"));
 
2798         return reset_merge(&head);
 
2801 int sequencer_rollback(struct repository *r, struct replay_opts *opts)
 
2804         struct object_id oid;
 
2805         struct strbuf buf = STRBUF_INIT;
 
2808         f = fopen(git_path_head_file(), "r");
 
2809         if (!f && errno == ENOENT) {
 
2811                  * There is no multiple-cherry-pick in progress.
 
2812                  * If CHERRY_PICK_HEAD or REVERT_HEAD indicates
 
2813                  * a single-cherry-pick in progress, abort that.
 
2815                 return rollback_single_pick(r);
 
2818                 return error_errno(_("cannot open '%s'"), git_path_head_file());
 
2819         if (strbuf_getline_lf(&buf, f)) {
 
2820                 error(_("cannot read '%s': %s"), git_path_head_file(),
 
2821                       ferror(f) ?  strerror(errno) : _("unexpected end of file"));
 
2826         if (parse_oid_hex(buf.buf, &oid, &p) || *p != '\0') {
 
2827                 error(_("stored pre-cherry-pick HEAD file '%s' is corrupt"),
 
2828                         git_path_head_file());
 
2831         if (is_null_oid(&oid)) {
 
2832                 error(_("cannot abort from a branch yet to be born"));
 
2836         if (!rollback_is_safe()) {
 
2837                 /* Do not error, just do not rollback */
 
2838                 warning(_("You seem to have moved HEAD. "
 
2839                           "Not rewinding, check your HEAD!"));
 
2841         if (reset_merge(&oid))
 
2843         strbuf_release(&buf);
 
2844         return sequencer_remove_state(opts);
 
2846         strbuf_release(&buf);
 
2850 int sequencer_skip(struct repository *r, struct replay_opts *opts)
 
2852         enum replay_action action = -1;
 
2853         sequencer_get_last_command(r, &action);
 
2856          * Check whether the subcommand requested to skip the commit is actually
 
2857          * in progress and that it's safe to skip the commit.
 
2859          * opts->action tells us which subcommand requested to skip the commit.
 
2860          * If the corresponding .git/<ACTION>_HEAD exists, we know that the
 
2861          * action is in progress and we can skip the commit.
 
2863          * Otherwise we check that the last instruction was related to the
 
2864          * particular subcommand we're trying to execute and barf if that's not
 
2867          * Finally we check that the rollback is "safe", i.e., has the HEAD
 
2868          * moved? In this case, it doesn't make sense to "reset the merge" and
 
2869          * "skip the commit" as the user already handled this by committing. But
 
2870          * we'd not want to barf here, instead give advice on how to proceed. We
 
2871          * only need to check that when .git/<ACTION>_HEAD doesn't exist because
 
2872          * it gets removed when the user commits, so if it still exists we're
 
2873          * sure the user can't have committed before.
 
2875         switch (opts->action) {
 
2877                 if (!refs_ref_exists(get_main_ref_store(r), "REVERT_HEAD")) {
 
2878                         if (action != REPLAY_REVERT)
 
2879                                 return error(_("no revert in progress"));
 
2880                         if (!rollback_is_safe())
 
2885                 if (!refs_ref_exists(get_main_ref_store(r),
 
2886                                      "CHERRY_PICK_HEAD")) {
 
2887                         if (action != REPLAY_PICK)
 
2888                                 return error(_("no cherry-pick in progress"));
 
2889                         if (!rollback_is_safe())
 
2894                 BUG("unexpected action in sequencer_skip");
 
2897         if (skip_single_pick())
 
2898                 return error(_("failed to skip the commit"));
 
2899         if (!is_directory(git_path_seq_dir()))
 
2902         return sequencer_continue(r, opts);
 
2905         error(_("there is nothing to skip"));
 
2907         if (advice_resolve_conflict) {
 
2908                 advise(_("have you committed already?\n"
 
2909                          "try \"git %s --continue\""),
 
2910                          action == REPLAY_REVERT ? "revert" : "cherry-pick");
 
2915 static int save_todo(struct todo_list *todo_list, struct replay_opts *opts)
 
2917         struct lock_file todo_lock = LOCK_INIT;
 
2918         const char *todo_path = get_todo_path(opts);
 
2919         int next = todo_list->current, offset, fd;
 
2922          * rebase -i writes "git-rebase-todo" without the currently executing
 
2923          * command, appending it to "done" instead.
 
2925         if (is_rebase_i(opts))
 
2928         fd = hold_lock_file_for_update(&todo_lock, todo_path, 0);
 
2930                 return error_errno(_("could not lock '%s'"), todo_path);
 
2931         offset = get_item_line_offset(todo_list, next);
 
2932         if (write_in_full(fd, todo_list->buf.buf + offset,
 
2933                         todo_list->buf.len - offset) < 0)
 
2934                 return error_errno(_("could not write to '%s'"), todo_path);
 
2935         if (commit_lock_file(&todo_lock) < 0)
 
2936                 return error(_("failed to finalize '%s'"), todo_path);
 
2938         if (is_rebase_i(opts) && next > 0) {
 
2939                 const char *done = rebase_path_done();
 
2940                 int fd = open(done, O_CREAT | O_WRONLY | O_APPEND, 0666);
 
2945                 if (write_in_full(fd, get_item_line(todo_list, next - 1),
 
2946                                   get_item_line_length(todo_list, next - 1))
 
2948                         ret = error_errno(_("could not write to '%s'"), done);
 
2950                         ret = error_errno(_("failed to finalize '%s'"), done);
 
2956 static int save_opts(struct replay_opts *opts)
 
2958         const char *opts_file = git_path_opts_file();
 
2961         if (opts->no_commit)
 
2962                 res |= git_config_set_in_file_gently(opts_file,
 
2963                                         "options.no-commit", "true");
 
2965                 res |= git_config_set_in_file_gently(opts_file,
 
2966                                         "options.edit", "true");
 
2967         if (opts->allow_empty)
 
2968                 res |= git_config_set_in_file_gently(opts_file,
 
2969                                         "options.allow-empty", "true");
 
2970         if (opts->allow_empty_message)
 
2971                 res |= git_config_set_in_file_gently(opts_file,
 
2972                                 "options.allow-empty-message", "true");
 
2973         if (opts->keep_redundant_commits)
 
2974                 res |= git_config_set_in_file_gently(opts_file,
 
2975                                 "options.keep-redundant-commits", "true");
 
2977                 res |= git_config_set_in_file_gently(opts_file,
 
2978                                         "options.signoff", "true");
 
2979         if (opts->record_origin)
 
2980                 res |= git_config_set_in_file_gently(opts_file,
 
2981                                         "options.record-origin", "true");
 
2983                 res |= git_config_set_in_file_gently(opts_file,
 
2984                                         "options.allow-ff", "true");
 
2985         if (opts->mainline) {
 
2986                 struct strbuf buf = STRBUF_INIT;
 
2987                 strbuf_addf(&buf, "%d", opts->mainline);
 
2988                 res |= git_config_set_in_file_gently(opts_file,
 
2989                                         "options.mainline", buf.buf);
 
2990                 strbuf_release(&buf);
 
2993                 res |= git_config_set_in_file_gently(opts_file,
 
2994                                         "options.strategy", opts->strategy);
 
2996                 res |= git_config_set_in_file_gently(opts_file,
 
2997                                         "options.gpg-sign", opts->gpg_sign);
 
3000                 for (i = 0; i < opts->xopts_nr; i++)
 
3001                         res |= git_config_set_multivar_in_file_gently(opts_file,
 
3002                                         "options.strategy-option",
 
3003                                         opts->xopts[i], "^$", 0);
 
3005         if (opts->allow_rerere_auto)
 
3006                 res |= git_config_set_in_file_gently(opts_file,
 
3007                                 "options.allow-rerere-auto",
 
3008                                 opts->allow_rerere_auto == RERERE_AUTOUPDATE ?
 
3011         if (opts->explicit_cleanup)
 
3012                 res |= git_config_set_in_file_gently(opts_file,
 
3013                                 "options.default-msg-cleanup",
 
3014                                 describe_cleanup_mode(opts->default_msg_cleanup));
 
3018 static int make_patch(struct repository *r,
 
3019                       struct commit *commit,
 
3020                       struct replay_opts *opts)
 
3022         struct strbuf buf = STRBUF_INIT;
 
3023         struct rev_info log_tree_opt;
 
3024         const char *subject, *p;
 
3027         p = short_commit_name(commit);
 
3028         if (write_message(p, strlen(p), rebase_path_stopped_sha(), 1) < 0)
 
3030         res |= write_rebase_head(&commit->object.oid);
 
3032         strbuf_addf(&buf, "%s/patch", get_dir(opts));
 
3033         memset(&log_tree_opt, 0, sizeof(log_tree_opt));
 
3034         repo_init_revisions(r, &log_tree_opt, NULL);
 
3035         log_tree_opt.abbrev = 0;
 
3036         log_tree_opt.diff = 1;
 
3037         log_tree_opt.diffopt.output_format = DIFF_FORMAT_PATCH;
 
3038         log_tree_opt.disable_stdin = 1;
 
3039         log_tree_opt.no_commit_id = 1;
 
3040         log_tree_opt.diffopt.file = fopen(buf.buf, "w");
 
3041         log_tree_opt.diffopt.use_color = GIT_COLOR_NEVER;
 
3042         if (!log_tree_opt.diffopt.file)
 
3043                 res |= error_errno(_("could not open '%s'"), buf.buf);
 
3045                 res |= log_tree_commit(&log_tree_opt, commit);
 
3046                 fclose(log_tree_opt.diffopt.file);
 
3050         strbuf_addf(&buf, "%s/message", get_dir(opts));
 
3051         if (!file_exists(buf.buf)) {
 
3052                 const char *encoding = get_commit_output_encoding();
 
3053                 const char *commit_buffer = logmsg_reencode(commit, NULL, encoding);
 
3054                 find_commit_subject(commit_buffer, &subject);
 
3055                 res |= write_message(subject, strlen(subject), buf.buf, 1);
 
3056                 unuse_commit_buffer(commit, commit_buffer);
 
3058         strbuf_release(&buf);
 
3063 static int intend_to_amend(void)
 
3065         struct object_id head;
 
3068         if (get_oid("HEAD", &head))
 
3069                 return error(_("cannot read HEAD"));
 
3071         p = oid_to_hex(&head);
 
3072         return write_message(p, strlen(p), rebase_path_amend(), 1);
 
3075 static int error_with_patch(struct repository *r,
 
3076                             struct commit *commit,
 
3077                             const char *subject, int subject_len,
 
3078                             struct replay_opts *opts,
 
3079                             int exit_code, int to_amend)
 
3082                 if (make_patch(r, commit, opts))
 
3084         } else if (copy_file(rebase_path_message(),
 
3085                              git_path_merge_msg(r), 0666))
 
3086                 return error(_("unable to copy '%s' to '%s'"),
 
3087                              git_path_merge_msg(r), rebase_path_message());
 
3090                 if (intend_to_amend())
 
3094                         _("You can amend the commit now, with\n"
 
3096                           "  git commit --amend %s\n"
 
3098                           "Once you are satisfied with your changes, run\n"
 
3100                           "  git rebase --continue\n"),
 
3101                         gpg_sign_opt_quoted(opts));
 
3102         } else if (exit_code) {
 
3104                         fprintf_ln(stderr, _("Could not apply %s... %.*s"),
 
3105                                    short_commit_name(commit), subject_len, subject);
 
3108                          * We don't have the hash of the parent so
 
3109                          * just print the line from the todo file.
 
3111                         fprintf_ln(stderr, _("Could not merge %.*s"),
 
3112                                    subject_len, subject);
 
3118 static int error_failed_squash(struct repository *r,
 
3119                                struct commit *commit,
 
3120                                struct replay_opts *opts,
 
3122                                const char *subject)
 
3124         if (copy_file(rebase_path_message(), rebase_path_squash_msg(), 0666))
 
3125                 return error(_("could not copy '%s' to '%s'"),
 
3126                         rebase_path_squash_msg(), rebase_path_message());
 
3127         unlink(git_path_merge_msg(r));
 
3128         if (copy_file(git_path_merge_msg(r), rebase_path_message(), 0666))
 
3129                 return error(_("could not copy '%s' to '%s'"),
 
3130                              rebase_path_message(),
 
3131                              git_path_merge_msg(r));
 
3132         return error_with_patch(r, commit, subject, subject_len, opts, 1, 0);
 
3135 static int do_exec(struct repository *r, const char *command_line)
 
3137         struct strvec child_env = STRVEC_INIT;
 
3138         const char *child_argv[] = { NULL, NULL };
 
3141         fprintf(stderr, _("Executing: %s\n"), command_line);
 
3142         child_argv[0] = command_line;
 
3143         strvec_pushf(&child_env, "GIT_DIR=%s", absolute_path(get_git_dir()));
 
3144         strvec_pushf(&child_env, "GIT_WORK_TREE=%s",
 
3145                      absolute_path(get_git_work_tree()));
 
3146         status = run_command_v_opt_cd_env(child_argv, RUN_USING_SHELL, NULL,
 
3149         /* force re-reading of the cache */
 
3150         if (discard_index(r->index) < 0 || repo_read_index(r) < 0)
 
3151                 return error(_("could not read index"));
 
3153         dirty = require_clean_work_tree(r, "rebase", NULL, 1, 1);
 
3156                 warning(_("execution failed: %s\n%s"
 
3157                           "You can fix the problem, and then run\n"
 
3159                           "  git rebase --continue\n"
 
3162                         dirty ? N_("and made changes to the index and/or the "
 
3163                                 "working tree\n") : "");
 
3165                         /* command not found */
 
3168                 warning(_("execution succeeded: %s\nbut "
 
3169                           "left changes to the index and/or the working tree\n"
 
3170                           "Commit or stash your changes, and then run\n"
 
3172                           "  git rebase --continue\n"
 
3173                           "\n"), command_line);
 
3177         strvec_clear(&child_env);
 
3182 static int safe_append(const char *filename, const char *fmt, ...)
 
3185         struct lock_file lock = LOCK_INIT;
 
3186         int fd = hold_lock_file_for_update(&lock, filename,
 
3187                                            LOCK_REPORT_ON_ERROR);
 
3188         struct strbuf buf = STRBUF_INIT;
 
3193         if (strbuf_read_file(&buf, filename, 0) < 0 && errno != ENOENT) {
 
3194                 error_errno(_("could not read '%s'"), filename);
 
3195                 rollback_lock_file(&lock);
 
3198         strbuf_complete(&buf, '\n');
 
3200         strbuf_vaddf(&buf, fmt, ap);
 
3203         if (write_in_full(fd, buf.buf, buf.len) < 0) {
 
3204                 error_errno(_("could not write to '%s'"), filename);
 
3205                 strbuf_release(&buf);
 
3206                 rollback_lock_file(&lock);
 
3209         if (commit_lock_file(&lock) < 0) {
 
3210                 strbuf_release(&buf);
 
3211                 rollback_lock_file(&lock);
 
3212                 return error(_("failed to finalize '%s'"), filename);
 
3215         strbuf_release(&buf);
 
3219 static int do_label(struct repository *r, const char *name, int len)
 
3221         struct ref_store *refs = get_main_ref_store(r);
 
3222         struct ref_transaction *transaction;
 
3223         struct strbuf ref_name = STRBUF_INIT, err = STRBUF_INIT;
 
3224         struct strbuf msg = STRBUF_INIT;
 
3226         struct object_id head_oid;
 
3228         if (len == 1 && *name == '#')
 
3229                 return error(_("illegal label name: '%.*s'"), len, name);
 
3231         strbuf_addf(&ref_name, "refs/rewritten/%.*s", len, name);
 
3232         strbuf_addf(&msg, "rebase (label) '%.*s'", len, name);
 
3234         transaction = ref_store_transaction_begin(refs, &err);
 
3236                 error("%s", err.buf);
 
3238         } else if (get_oid("HEAD", &head_oid)) {
 
3239                 error(_("could not read HEAD"));
 
3241         } else if (ref_transaction_update(transaction, ref_name.buf, &head_oid,
 
3242                                           NULL, 0, msg.buf, &err) < 0 ||
 
3243                    ref_transaction_commit(transaction, &err)) {
 
3244                 error("%s", err.buf);
 
3247         ref_transaction_free(transaction);
 
3248         strbuf_release(&err);
 
3249         strbuf_release(&msg);
 
3252                 ret = safe_append(rebase_path_refs_to_delete(),
 
3253                                   "%s\n", ref_name.buf);
 
3254         strbuf_release(&ref_name);
 
3259 static const char *reflog_message(struct replay_opts *opts,
 
3260         const char *sub_action, const char *fmt, ...);
 
3262 static int do_reset(struct repository *r,
 
3263                     const char *name, int len,
 
3264                     struct replay_opts *opts)
 
3266         struct strbuf ref_name = STRBUF_INIT;
 
3267         struct object_id oid;
 
3268         struct lock_file lock = LOCK_INIT;
 
3269         struct tree_desc desc;
 
3271         struct unpack_trees_options unpack_tree_opts;
 
3274         if (repo_hold_locked_index(r, &lock, LOCK_REPORT_ON_ERROR) < 0)
 
3277         if (len == 10 && !strncmp("[new root]", name, len)) {
 
3278                 if (!opts->have_squash_onto) {
 
3280                         if (commit_tree("", 0, the_hash_algo->empty_tree,
 
3281                                         NULL, &opts->squash_onto,
 
3283                                 return error(_("writing fake root commit"));
 
3284                         opts->have_squash_onto = 1;
 
3285                         hex = oid_to_hex(&opts->squash_onto);
 
3286                         if (write_message(hex, strlen(hex),
 
3287                                           rebase_path_squash_onto(), 0))
 
3288                                 return error(_("writing squash-onto"));
 
3290                 oidcpy(&oid, &opts->squash_onto);
 
3294                 /* Determine the length of the label */
 
3295                 for (i = 0; i < len; i++)
 
3296                         if (isspace(name[i]))
 
3300                 strbuf_addf(&ref_name, "refs/rewritten/%.*s", len, name);
 
3301                 if (get_oid(ref_name.buf, &oid) &&
 
3302                     get_oid(ref_name.buf + strlen("refs/rewritten/"), &oid)) {
 
3303                         error(_("could not read '%s'"), ref_name.buf);
 
3304                         rollback_lock_file(&lock);
 
3305                         strbuf_release(&ref_name);
 
3310         memset(&unpack_tree_opts, 0, sizeof(unpack_tree_opts));
 
3311         setup_unpack_trees_porcelain(&unpack_tree_opts, "reset");
 
3312         unpack_tree_opts.head_idx = 1;
 
3313         unpack_tree_opts.src_index = r->index;
 
3314         unpack_tree_opts.dst_index = r->index;
 
3315         unpack_tree_opts.fn = oneway_merge;
 
3316         unpack_tree_opts.merge = 1;
 
3317         unpack_tree_opts.update = 1;
 
3318         init_checkout_metadata(&unpack_tree_opts.meta, name, &oid, NULL);
 
3320         if (repo_read_index_unmerged(r)) {
 
3321                 rollback_lock_file(&lock);
 
3322                 strbuf_release(&ref_name);
 
3323                 return error_resolve_conflict(_(action_name(opts)));
 
3326         if (!fill_tree_descriptor(r, &desc, &oid)) {
 
3327                 error(_("failed to find tree of %s"), oid_to_hex(&oid));
 
3328                 rollback_lock_file(&lock);
 
3329                 free((void *)desc.buffer);
 
3330                 strbuf_release(&ref_name);
 
3334         if (unpack_trees(1, &desc, &unpack_tree_opts)) {
 
3335                 rollback_lock_file(&lock);
 
3336                 free((void *)desc.buffer);
 
3337                 strbuf_release(&ref_name);
 
3341         tree = parse_tree_indirect(&oid);
 
3342         prime_cache_tree(r, r->index, tree);
 
3344         if (write_locked_index(r->index, &lock, COMMIT_LOCK) < 0)
 
3345                 ret = error(_("could not write index"));
 
3346         free((void *)desc.buffer);
 
3349                 ret = update_ref(reflog_message(opts, "reset", "'%.*s'",
 
3350                                                 len, name), "HEAD", &oid,
 
3351                                  NULL, 0, UPDATE_REFS_MSG_ON_ERR);
 
3353         strbuf_release(&ref_name);
 
3357 static struct commit *lookup_label(const char *label, int len,
 
3360         struct commit *commit;
 
3363         strbuf_addf(buf, "refs/rewritten/%.*s", len, label);
 
3364         commit = lookup_commit_reference_by_name(buf->buf);
 
3366                 /* fall back to non-rewritten ref or commit */
 
3367                 strbuf_splice(buf, 0, strlen("refs/rewritten/"), "", 0);
 
3368                 commit = lookup_commit_reference_by_name(buf->buf);
 
3372                 error(_("could not resolve '%s'"), buf->buf);
 
3377 static int do_merge(struct repository *r,
 
3378                     struct commit *commit,
 
3379                     const char *arg, int arg_len,
 
3380                     int flags, struct replay_opts *opts)
 
3382         int run_commit_flags = (flags & TODO_EDIT_MERGE_MSG) ?
 
3383                 EDIT_MSG | VERIFY_MSG : 0;
 
3384         struct strbuf ref_name = STRBUF_INIT;
 
3385         struct commit *head_commit, *merge_commit, *i;
 
3386         struct commit_list *bases, *j, *reversed = NULL;
 
3387         struct commit_list *to_merge = NULL, **tail = &to_merge;
 
3388         const char *strategy = !opts->xopts_nr &&
 
3389                 (!opts->strategy || !strcmp(opts->strategy, "recursive")) ?
 
3390                 NULL : opts->strategy;
 
3391         struct merge_options o;
 
3392         int merge_arg_len, oneline_offset, can_fast_forward, ret, k;
 
3393         static struct lock_file lock;
 
3396         if (repo_hold_locked_index(r, &lock, LOCK_REPORT_ON_ERROR) < 0) {
 
3401         head_commit = lookup_commit_reference_by_name("HEAD");
 
3403                 ret = error(_("cannot merge without a current revision"));
 
3408          * For octopus merges, the arg starts with the list of revisions to be
 
3409          * merged. The list is optionally followed by '#' and the oneline.
 
3411         merge_arg_len = oneline_offset = arg_len;
 
3412         for (p = arg; p - arg < arg_len; p += strspn(p, " \t\n")) {
 
3415                 if (*p == '#' && (!p[1] || isspace(p[1]))) {
 
3416                         p += 1 + strspn(p + 1, " \t\n");
 
3417                         oneline_offset = p - arg;
 
3420                 k = strcspn(p, " \t\n");
 
3423                 merge_commit = lookup_label(p, k, &ref_name);
 
3424                 if (!merge_commit) {
 
3425                         ret = error(_("unable to parse '%.*s'"), k, p);
 
3428                 tail = &commit_list_insert(merge_commit, tail)->next;
 
3430                 merge_arg_len = p - arg;
 
3434                 ret = error(_("nothing to merge: '%.*s'"), arg_len, arg);
 
3438         if (opts->have_squash_onto &&
 
3439             oideq(&head_commit->object.oid, &opts->squash_onto)) {
 
3441                  * When the user tells us to "merge" something into a
 
3442                  * "[new root]", let's simply fast-forward to the merge head.
 
3444                 rollback_lock_file(&lock);
 
3446                         ret = error(_("octopus merge cannot be executed on "
 
3447                                       "top of a [new root]"));
 
3449                         ret = fast_forward_to(r, &to_merge->item->object.oid,
 
3450                                               &head_commit->object.oid, 0,
 
3456                 const char *encoding = get_commit_output_encoding();
 
3457                 const char *message = logmsg_reencode(commit, NULL, encoding);
 
3462                         ret = error(_("could not get commit message of '%s'"),
 
3463                                     oid_to_hex(&commit->object.oid));
 
3466                 write_author_script(message);
 
3467                 find_commit_subject(message, &body);
 
3469                 ret = write_message(body, len, git_path_merge_msg(r), 0);
 
3470                 unuse_commit_buffer(commit, message);
 
3472                         error_errno(_("could not write '%s'"),
 
3473                                     git_path_merge_msg(r));
 
3477                 struct strbuf buf = STRBUF_INIT;
 
3480                 strbuf_addf(&buf, "author %s", git_author_info(0));
 
3481                 write_author_script(buf.buf);
 
3484                 if (oneline_offset < arg_len) {
 
3485                         p = arg + oneline_offset;
 
3486                         len = arg_len - oneline_offset;
 
3488                         strbuf_addf(&buf, "Merge %s '%.*s'",
 
3489                                     to_merge->next ? "branches" : "branch",
 
3490                                     merge_arg_len, arg);
 
3495                 ret = write_message(p, len, git_path_merge_msg(r), 0);
 
3496                 strbuf_release(&buf);
 
3498                         error_errno(_("could not write '%s'"),
 
3499                                     git_path_merge_msg(r));
 
3505          * If HEAD is not identical to the first parent of the original merge
 
3506          * commit, we cannot fast-forward.
 
3508         can_fast_forward = opts->allow_ff && commit && commit->parents &&
 
3509                 oideq(&commit->parents->item->object.oid,
 
3510                       &head_commit->object.oid);
 
3513          * If any merge head is different from the original one, we cannot
 
3516         if (can_fast_forward) {
 
3517                 struct commit_list *p = commit->parents->next;
 
3519                 for (j = to_merge; j && p; j = j->next, p = p->next)
 
3520                         if (!oideq(&j->item->object.oid,
 
3521                                    &p->item->object.oid)) {
 
3522                                 can_fast_forward = 0;
 
3526                  * If the number of merge heads differs from the original merge
 
3527                  * commit, we cannot fast-forward.
 
3530                         can_fast_forward = 0;
 
3533         if (can_fast_forward) {
 
3534                 rollback_lock_file(&lock);
 
3535                 ret = fast_forward_to(r, &commit->object.oid,
 
3536                                       &head_commit->object.oid, 0, opts);
 
3537                 if (flags & TODO_EDIT_MERGE_MSG) {
 
3538                         run_commit_flags |= AMEND_MSG;
 
3539                         goto fast_forward_edit;
 
3544         if (strategy || to_merge->next) {
 
3546                 struct child_process cmd = CHILD_PROCESS_INIT;
 
3548                 if (read_env_script(&cmd.env_array)) {
 
3549                         const char *gpg_opt = gpg_sign_opt_quoted(opts);
 
3551                         ret = error(_(staged_changes_advice), gpg_opt, gpg_opt);
 
3556                 strvec_push(&cmd.args, "merge");
 
3557                 strvec_push(&cmd.args, "-s");
 
3559                         strvec_push(&cmd.args, "octopus");
 
3561                         strvec_push(&cmd.args, strategy);
 
3562                         for (k = 0; k < opts->xopts_nr; k++)
 
3563                                 strvec_pushf(&cmd.args,
 
3564                                              "-X%s", opts->xopts[k]);
 
3566                 strvec_push(&cmd.args, "--no-edit");
 
3567                 strvec_push(&cmd.args, "--no-ff");
 
3568                 strvec_push(&cmd.args, "--no-log");
 
3569                 strvec_push(&cmd.args, "--no-stat");
 
3570                 strvec_push(&cmd.args, "-F");
 
3571                 strvec_push(&cmd.args, git_path_merge_msg(r));
 
3573                         strvec_push(&cmd.args, opts->gpg_sign);
 
3575                 /* Add the tips to be merged */
 
3576                 for (j = to_merge; j; j = j->next)
 
3577                         strvec_push(&cmd.args,
 
3578                                     oid_to_hex(&j->item->object.oid));
 
3580                 strbuf_release(&ref_name);
 
3581                 refs_delete_ref(get_main_ref_store(r), "", "CHERRY_PICK_HEAD",
 
3583                 rollback_lock_file(&lock);
 
3585                 rollback_lock_file(&lock);
 
3586                 ret = run_command(&cmd);
 
3588                 /* force re-reading of the cache */
 
3589                 if (!ret && (discard_index(r->index) < 0 ||
 
3590                              repo_read_index(r) < 0))
 
3591                         ret = error(_("could not read index"));
 
3595         merge_commit = to_merge->item;
 
3596         bases = get_merge_bases(head_commit, merge_commit);
 
3597         if (bases && oideq(&merge_commit->object.oid,
 
3598                            &bases->item->object.oid)) {
 
3600                 /* skip merging an ancestor of HEAD */
 
3604         write_message(oid_to_hex(&merge_commit->object.oid), the_hash_algo->hexsz,
 
3605                       git_path_merge_head(r), 0);
 
3606         write_message("no-ff", 5, git_path_merge_mode(r), 0);
 
3608         for (j = bases; j; j = j->next)
 
3609                 commit_list_insert(j->item, &reversed);
 
3610         free_commit_list(bases);
 
3613         init_merge_options(&o, r);
 
3615         o.branch2 = ref_name.buf;
 
3616         o.buffer_output = 2;
 
3618         ret = merge_recursive(&o, head_commit, merge_commit, reversed, &i);
 
3620                 fputs(o.obuf.buf, stdout);
 
3621         strbuf_release(&o.obuf);
 
3623                 error(_("could not even attempt to merge '%.*s'"),
 
3624                       merge_arg_len, arg);
 
3628          * The return value of merge_recursive() is 1 on clean, and 0 on
 
3631          * Let's reverse that, so that do_merge() returns 0 upon success and
 
3632          * 1 upon failed merge (keeping the return value -1 for the cases where
 
3633          * we will want to reschedule the `merge` command).
 
3637         if (r->index->cache_changed &&
 
3638             write_locked_index(r->index, &lock, COMMIT_LOCK)) {
 
3639                 ret = error(_("merge: Unable to write new index file"));
 
3643         rollback_lock_file(&lock);
 
3645                 repo_rerere(r, opts->allow_rerere_auto);
 
3648                  * In case of problems, we now want to return a positive
 
3649                  * value (a negative one would indicate that the `merge`
 
3650                  * command needs to be rescheduled).
 
3653                 ret = !!run_git_commit(r, git_path_merge_msg(r), opts,
 
3657         strbuf_release(&ref_name);
 
3658         rollback_lock_file(&lock);
 
3659         free_commit_list(to_merge);
 
3663 static int is_final_fixup(struct todo_list *todo_list)
 
3665         int i = todo_list->current;
 
3667         if (!is_fixup(todo_list->items[i].command))
 
3670         while (++i < todo_list->nr)
 
3671                 if (is_fixup(todo_list->items[i].command))
 
3673                 else if (!is_noop(todo_list->items[i].command))
 
3678 static enum todo_command peek_command(struct todo_list *todo_list, int offset)
 
3682         for (i = todo_list->current + offset; i < todo_list->nr; i++)
 
3683                 if (!is_noop(todo_list->items[i].command))
 
3684                         return todo_list->items[i].command;
 
3689 void create_autostash(struct repository *r, const char *path,
 
3690                       const char *default_reflog_action)
 
3692         struct strbuf buf = STRBUF_INIT;
 
3693         struct lock_file lock_file = LOCK_INIT;
 
3696         fd = repo_hold_locked_index(r, &lock_file, 0);
 
3697         refresh_index(r->index, REFRESH_QUIET, NULL, NULL, NULL);
 
3699                 repo_update_index_if_able(r, &lock_file);
 
3700         rollback_lock_file(&lock_file);
 
3702         if (has_unstaged_changes(r, 1) ||
 
3703             has_uncommitted_changes(r, 1)) {
 
3704                 struct child_process stash = CHILD_PROCESS_INIT;
 
3705                 struct object_id oid;
 
3707                 strvec_pushl(&stash.args,
 
3708                              "stash", "create", "autostash", NULL);
 
3712                 if (capture_command(&stash, &buf, GIT_MAX_HEXSZ))
 
3713                         die(_("Cannot autostash"));
 
3714                 strbuf_trim_trailing_newline(&buf);
 
3715                 if (get_oid(buf.buf, &oid))
 
3716                         die(_("Unexpected stash response: '%s'"),
 
3719                 strbuf_add_unique_abbrev(&buf, &oid, DEFAULT_ABBREV);
 
3721                 if (safe_create_leading_directories_const(path))
 
3722                         die(_("Could not create directory for '%s'"),
 
3724                 write_file(path, "%s", oid_to_hex(&oid));
 
3725                 printf(_("Created autostash: %s\n"), buf.buf);
 
3726                 if (reset_head(r, NULL, "reset --hard",
 
3727                                NULL, RESET_HEAD_HARD, NULL, NULL,
 
3728                                default_reflog_action) < 0)
 
3729                         die(_("could not reset --hard"));
 
3731                 if (discard_index(r->index) < 0 ||
 
3732                         repo_read_index(r) < 0)
 
3733                         die(_("could not read index"));
 
3735         strbuf_release(&buf);
 
3738 static int apply_save_autostash_oid(const char *stash_oid, int attempt_apply)
 
3740         struct child_process child = CHILD_PROCESS_INIT;
 
3743         if (attempt_apply) {
 
3745                 child.no_stdout = 1;
 
3746                 child.no_stderr = 1;
 
3747                 strvec_push(&child.args, "stash");
 
3748                 strvec_push(&child.args, "apply");
 
3749                 strvec_push(&child.args, stash_oid);
 
3750                 ret = run_command(&child);
 
3753         if (attempt_apply && !ret)
 
3754                 fprintf(stderr, _("Applied autostash.\n"));
 
3756                 struct child_process store = CHILD_PROCESS_INIT;
 
3759                 strvec_push(&store.args, "stash");
 
3760                 strvec_push(&store.args, "store");
 
3761                 strvec_push(&store.args, "-m");
 
3762                 strvec_push(&store.args, "autostash");
 
3763                 strvec_push(&store.args, "-q");
 
3764                 strvec_push(&store.args, stash_oid);
 
3765                 if (run_command(&store))
 
3766                         ret = error(_("cannot store %s"), stash_oid);
 
3770                                   "Your changes are safe in the stash.\n"
 
3771                                   "You can run \"git stash pop\" or"
 
3772                                   " \"git stash drop\" at any time.\n"),
 
3774                                 _("Applying autostash resulted in conflicts.") :
 
3775                                 _("Autostash exists; creating a new stash entry."));
 
3781 static int apply_save_autostash(const char *path, int attempt_apply)
 
3783         struct strbuf stash_oid = STRBUF_INIT;
 
3786         if (!read_oneliner(&stash_oid, path,
 
3787                            READ_ONELINER_SKIP_IF_EMPTY)) {
 
3788                 strbuf_release(&stash_oid);
 
3791         strbuf_trim(&stash_oid);
 
3793         ret = apply_save_autostash_oid(stash_oid.buf, attempt_apply);
 
3796         strbuf_release(&stash_oid);
 
3800 int save_autostash(const char *path)
 
3802         return apply_save_autostash(path, 0);
 
3805 int apply_autostash(const char *path)
 
3807         return apply_save_autostash(path, 1);
 
3810 int apply_autostash_oid(const char *stash_oid)
 
3812         return apply_save_autostash_oid(stash_oid, 1);
 
3815 static const char *reflog_message(struct replay_opts *opts,
 
3816         const char *sub_action, const char *fmt, ...)
 
3819         static struct strbuf buf = STRBUF_INIT;
 
3820         char *reflog_action = getenv(GIT_REFLOG_ACTION);
 
3824         strbuf_addstr(&buf, reflog_action ? reflog_action : action_name(opts));
 
3826                 strbuf_addf(&buf, " (%s)", sub_action);
 
3828                 strbuf_addstr(&buf, ": ");
 
3829                 strbuf_vaddf(&buf, fmt, ap);
 
3836 static int run_git_checkout(struct repository *r, struct replay_opts *opts,
 
3837                             const char *commit, const char *action)
 
3839         struct child_process cmd = CHILD_PROCESS_INIT;
 
3844         strvec_push(&cmd.args, "checkout");
 
3845         strvec_push(&cmd.args, commit);
 
3846         strvec_pushf(&cmd.env_array, GIT_REFLOG_ACTION "=%s", action);
 
3849                 ret = run_command(&cmd);
 
3851                 ret = run_command_silent_on_success(&cmd);
 
3854                 discard_index(r->index);
 
3859 static int checkout_onto(struct repository *r, struct replay_opts *opts,
 
3860                          const char *onto_name, const struct object_id *onto,
 
3861                          const char *orig_head)
 
3863         struct object_id oid;
 
3864         const char *action = reflog_message(opts, "start", "checkout %s", onto_name);
 
3866         if (get_oid(orig_head, &oid))
 
3867                 return error(_("%s: not a valid OID"), orig_head);
 
3869         if (run_git_checkout(r, opts, oid_to_hex(onto), action)) {
 
3870                 apply_autostash(rebase_path_autostash());
 
3871                 sequencer_remove_state(opts);
 
3872                 return error(_("could not detach HEAD"));
 
3875         return update_ref(NULL, "ORIG_HEAD", &oid, NULL, 0, UPDATE_REFS_MSG_ON_ERR);
 
3878 static int stopped_at_head(struct repository *r)
 
3880         struct object_id head;
 
3881         struct commit *commit;
 
3882         struct commit_message message;
 
3884         if (get_oid("HEAD", &head) ||
 
3885             !(commit = lookup_commit(r, &head)) ||
 
3886             parse_commit(commit) || get_message(commit, &message))
 
3887                 fprintf(stderr, _("Stopped at HEAD\n"));
 
3889                 fprintf(stderr, _("Stopped at %s\n"), message.label);
 
3890                 free_message(commit, &message);
 
3896 static const char rescheduled_advice[] =
 
3897 N_("Could not execute the todo command\n"
 
3901 "It has been rescheduled; To edit the command before continuing, please\n"
 
3902 "edit the todo list first:\n"
 
3904 "    git rebase --edit-todo\n"
 
3905 "    git rebase --continue\n");
 
3907 static int pick_commits(struct repository *r,
 
3908                         struct todo_list *todo_list,
 
3909                         struct replay_opts *opts)
 
3911         int res = 0, reschedule = 0;
 
3912         char *prev_reflog_action;
 
3914         /* Note that 0 for 3rd parameter of setenv means set only if not set */
 
3915         setenv(GIT_REFLOG_ACTION, action_name(opts), 0);
 
3916         prev_reflog_action = xstrdup(getenv(GIT_REFLOG_ACTION));
 
3918                 assert(!(opts->signoff || opts->no_commit ||
 
3919                                 opts->record_origin || opts->edit));
 
3920         if (read_and_refresh_cache(r, opts))
 
3923         while (todo_list->current < todo_list->nr) {
 
3924                 struct todo_item *item = todo_list->items + todo_list->current;
 
3925                 const char *arg = todo_item_get_arg(todo_list, item);
 
3928                 if (save_todo(todo_list, opts))
 
3930                 if (is_rebase_i(opts)) {
 
3931                         if (item->command != TODO_COMMENT) {
 
3932                                 FILE *f = fopen(rebase_path_msgnum(), "w");
 
3934                                 todo_list->done_nr++;
 
3937                                         fprintf(f, "%d\n", todo_list->done_nr);
 
3941                                         fprintf(stderr, _("Rebasing (%d/%d)%s"),
 
3943                                                 todo_list->total_nr,
 
3944                                                 opts->verbose ? "\n" : "\r");
 
3946                         unlink(rebase_path_message());
 
3947                         unlink(rebase_path_author_script());
 
3948                         unlink(rebase_path_stopped_sha());
 
3949                         unlink(rebase_path_amend());
 
3950                         unlink(git_path_merge_head(r));
 
3951                         delete_ref(NULL, "REBASE_HEAD", NULL, REF_NO_DEREF);
 
3953                         if (item->command == TODO_BREAK) {
 
3956                                 return stopped_at_head(r);
 
3959                 if (item->command <= TODO_SQUASH) {
 
3960                         if (is_rebase_i(opts))
 
3961                                 setenv(GIT_REFLOG_ACTION, reflog_message(opts,
 
3962                                         command_to_string(item->command), NULL),
 
3964                         res = do_pick_commit(r, item->command, item->commit,
 
3965                                              opts, is_final_fixup(todo_list),
 
3967                         if (is_rebase_i(opts))
 
3968                                 setenv(GIT_REFLOG_ACTION, prev_reflog_action, 1);
 
3969                         if (is_rebase_i(opts) && res < 0) {
 
3971                                 advise(_(rescheduled_advice),
 
3972                                        get_item_line_length(todo_list,
 
3973                                                             todo_list->current),
 
3974                                        get_item_line(todo_list,
 
3975                                                      todo_list->current));
 
3976                                 todo_list->current--;
 
3977                                 if (save_todo(todo_list, opts))
 
3980                         if (item->command == TODO_EDIT) {
 
3981                                 struct commit *commit = item->commit;
 
3986                                                 _("Stopped at %s...  %.*s\n"),
 
3987                                                 short_commit_name(commit),
 
3988                                                 item->arg_len, arg);
 
3990                                 return error_with_patch(r, commit,
 
3991                                         arg, item->arg_len, opts, res, !res);
 
3993                         if (is_rebase_i(opts) && !res)
 
3994                                 record_in_rewritten(&item->commit->object.oid,
 
3995                                         peek_command(todo_list, 1));
 
3996                         if (res && is_fixup(item->command)) {
 
3999                                 return error_failed_squash(r, item->commit, opts,
 
4000                                         item->arg_len, arg);
 
4001                         } else if (res && is_rebase_i(opts) && item->commit) {
 
4003                                 struct object_id oid;
 
4006                                  * If we are rewording and have either
 
4007                                  * fast-forwarded already, or are about to
 
4008                                  * create a new root commit, we want to amend,
 
4009                                  * otherwise we do not.
 
4011                                 if (item->command == TODO_REWORD &&
 
4012                                     !get_oid("HEAD", &oid) &&
 
4013                                     (oideq(&item->commit->object.oid, &oid) ||
 
4014                                      (opts->have_squash_onto &&
 
4015                                       oideq(&opts->squash_onto, &oid))))
 
4018                                 return res | error_with_patch(r, item->commit,
 
4019                                                 arg, item->arg_len, opts,
 
4022                 } else if (item->command == TODO_EXEC) {
 
4023                         char *end_of_arg = (char *)(arg + item->arg_len);
 
4024                         int saved = *end_of_arg;
 
4029                         res = do_exec(r, arg);
 
4030                         *end_of_arg = saved;
 
4033                                 if (opts->reschedule_failed_exec)
 
4037                 } else if (item->command == TODO_LABEL) {
 
4038                         if ((res = do_label(r, arg, item->arg_len)))
 
4040                 } else if (item->command == TODO_RESET) {
 
4041                         if ((res = do_reset(r, arg, item->arg_len, opts)))
 
4043                 } else if (item->command == TODO_MERGE) {
 
4044                         if ((res = do_merge(r, item->commit,
 
4046                                             item->flags, opts)) < 0)
 
4048                         else if (item->commit)
 
4049                                 record_in_rewritten(&item->commit->object.oid,
 
4050                                                     peek_command(todo_list, 1));
 
4052                                 /* failed with merge conflicts */
 
4053                                 return error_with_patch(r, item->commit,
 
4056                 } else if (!is_noop(item->command))
 
4057                         return error(_("unknown command %d"), item->command);
 
4060                         advise(_(rescheduled_advice),
 
4061                                get_item_line_length(todo_list,
 
4062                                                     todo_list->current),
 
4063                                get_item_line(todo_list, todo_list->current));
 
4064                         todo_list->current--;
 
4065                         if (save_todo(todo_list, opts))
 
4068                                 return error_with_patch(r,
 
4072                 } else if (is_rebase_i(opts) && check_todo && !res) {
 
4075                         if (stat(get_todo_path(opts), &st)) {
 
4076                                 res = error_errno(_("could not stat '%s'"),
 
4077                                                   get_todo_path(opts));
 
4078                         } else if (match_stat_data(&todo_list->stat, &st)) {
 
4079                                 /* Reread the todo file if it has changed. */
 
4080                                 todo_list_release(todo_list);
 
4081                                 if (read_populate_todo(r, todo_list, opts))
 
4082                                         res = -1; /* message was printed */
 
4083                                 /* `current` will be incremented below */
 
4084                                 todo_list->current = -1;
 
4088                 todo_list->current++;
 
4093         if (is_rebase_i(opts)) {
 
4094                 struct strbuf head_ref = STRBUF_INIT, buf = STRBUF_INIT;
 
4097                 /* Stopped in the middle, as planned? */
 
4098                 if (todo_list->current < todo_list->nr)
 
4101                 if (read_oneliner(&head_ref, rebase_path_head_name(), 0) &&
 
4102                                 starts_with(head_ref.buf, "refs/")) {
 
4104                         struct object_id head, orig;
 
4107                         if (get_oid("HEAD", &head)) {
 
4108                                 res = error(_("cannot read HEAD"));
 
4110                                 strbuf_release(&head_ref);
 
4111                                 strbuf_release(&buf);
 
4114                         if (!read_oneliner(&buf, rebase_path_orig_head(), 0) ||
 
4115                                         get_oid_hex(buf.buf, &orig)) {
 
4116                                 res = error(_("could not read orig-head"));
 
4117                                 goto cleanup_head_ref;
 
4120                         if (!read_oneliner(&buf, rebase_path_onto(), 0)) {
 
4121                                 res = error(_("could not read 'onto'"));
 
4122                                 goto cleanup_head_ref;
 
4124                         msg = reflog_message(opts, "finish", "%s onto %s",
 
4125                                 head_ref.buf, buf.buf);
 
4126                         if (update_ref(msg, head_ref.buf, &head, &orig,
 
4127                                        REF_NO_DEREF, UPDATE_REFS_MSG_ON_ERR)) {
 
4128                                 res = error(_("could not update %s"),
 
4130                                 goto cleanup_head_ref;
 
4132                         msg = reflog_message(opts, "finish", "returning to %s",
 
4134                         if (create_symref("HEAD", head_ref.buf, msg)) {
 
4135                                 res = error(_("could not update HEAD to %s"),
 
4137                                 goto cleanup_head_ref;
 
4142                 if (opts->verbose) {
 
4143                         struct rev_info log_tree_opt;
 
4144                         struct object_id orig, head;
 
4146                         memset(&log_tree_opt, 0, sizeof(log_tree_opt));
 
4147                         repo_init_revisions(r, &log_tree_opt, NULL);
 
4148                         log_tree_opt.diff = 1;
 
4149                         log_tree_opt.diffopt.output_format =
 
4150                                 DIFF_FORMAT_DIFFSTAT;
 
4151                         log_tree_opt.disable_stdin = 1;
 
4153                         if (read_oneliner(&buf, rebase_path_orig_head(), 0) &&
 
4154                             !get_oid(buf.buf, &orig) &&
 
4155                             !get_oid("HEAD", &head)) {
 
4156                                 diff_tree_oid(&orig, &head, "",
 
4157                                               &log_tree_opt.diffopt);
 
4158                                 log_tree_diff_flush(&log_tree_opt);
 
4161                 flush_rewritten_pending();
 
4162                 if (!stat(rebase_path_rewritten_list(), &st) &&
 
4164                         struct child_process child = CHILD_PROCESS_INIT;
 
4165                         const char *post_rewrite_hook =
 
4166                                 find_hook("post-rewrite");
 
4168                         child.in = open(rebase_path_rewritten_list(), O_RDONLY);
 
4170                         strvec_push(&child.args, "notes");
 
4171                         strvec_push(&child.args, "copy");
 
4172                         strvec_push(&child.args, "--for-rewrite=rebase");
 
4173                         /* we don't care if this copying failed */
 
4174                         run_command(&child);
 
4176                         if (post_rewrite_hook) {
 
4177                                 struct child_process hook = CHILD_PROCESS_INIT;
 
4179                                 hook.in = open(rebase_path_rewritten_list(),
 
4181                                 hook.stdout_to_stderr = 1;
 
4182                                 hook.trace2_hook_name = "post-rewrite";
 
4183                                 strvec_push(&hook.args, post_rewrite_hook);
 
4184                                 strvec_push(&hook.args, "rebase");
 
4185                                 /* we don't care if this hook failed */
 
4189                 apply_autostash(rebase_path_autostash());
 
4195                                 _("Successfully rebased and updated %s.\n"),
 
4199                 strbuf_release(&buf);
 
4200                 strbuf_release(&head_ref);
 
4204          * Sequence of picks finished successfully; cleanup by
 
4205          * removing the .git/sequencer directory
 
4207         return sequencer_remove_state(opts);
 
4210 static int continue_single_pick(struct repository *r)
 
4212         const char *argv[] = { "commit", NULL };
 
4214         if (!refs_ref_exists(get_main_ref_store(r), "CHERRY_PICK_HEAD") &&
 
4215             !refs_ref_exists(get_main_ref_store(r), "REVERT_HEAD"))
 
4216                 return error(_("no cherry-pick or revert in progress"));
 
4217         return run_command_v_opt(argv, RUN_GIT_CMD);
 
4220 static int commit_staged_changes(struct repository *r,
 
4221                                  struct replay_opts *opts,
 
4222                                  struct todo_list *todo_list)
 
4224         unsigned int flags = ALLOW_EMPTY | EDIT_MSG;
 
4225         unsigned int final_fixup = 0, is_clean;
 
4227         if (has_unstaged_changes(r, 1))
 
4228                 return error(_("cannot rebase: You have unstaged changes."));
 
4230         is_clean = !has_uncommitted_changes(r, 0);
 
4232         if (file_exists(rebase_path_amend())) {
 
4233                 struct strbuf rev = STRBUF_INIT;
 
4234                 struct object_id head, to_amend;
 
4236                 if (get_oid("HEAD", &head))
 
4237                         return error(_("cannot amend non-existing commit"));
 
4238                 if (!read_oneliner(&rev, rebase_path_amend(), 0))
 
4239                         return error(_("invalid file: '%s'"), rebase_path_amend());
 
4240                 if (get_oid_hex(rev.buf, &to_amend))
 
4241                         return error(_("invalid contents: '%s'"),
 
4242                                 rebase_path_amend());
 
4243                 if (!is_clean && !oideq(&head, &to_amend))
 
4244                         return error(_("\nYou have uncommitted changes in your "
 
4245                                        "working tree. Please, commit them\n"
 
4246                                        "first and then run 'git rebase "
 
4247                                        "--continue' again."));
 
4249                  * When skipping a failed fixup/squash, we need to edit the
 
4250                  * commit message, the current fixup list and count, and if it
 
4251                  * was the last fixup/squash in the chain, we need to clean up
 
4252                  * the commit message and if there was a squash, let the user
 
4255                 if (!is_clean || !opts->current_fixup_count)
 
4256                         ; /* this is not the final fixup */
 
4257                 else if (!oideq(&head, &to_amend) ||
 
4258                          !file_exists(rebase_path_stopped_sha())) {
 
4259                         /* was a final fixup or squash done manually? */
 
4260                         if (!is_fixup(peek_command(todo_list, 0))) {
 
4261                                 unlink(rebase_path_fixup_msg());
 
4262                                 unlink(rebase_path_squash_msg());
 
4263                                 unlink(rebase_path_current_fixups());
 
4264                                 strbuf_reset(&opts->current_fixups);
 
4265                                 opts->current_fixup_count = 0;
 
4268                         /* we are in a fixup/squash chain */
 
4269                         const char *p = opts->current_fixups.buf;
 
4270                         int len = opts->current_fixups.len;
 
4272                         opts->current_fixup_count--;
 
4274                                 BUG("Incorrect current_fixups:\n%s", p);
 
4275                         while (len && p[len - 1] != '\n')
 
4277                         strbuf_setlen(&opts->current_fixups, len);
 
4278                         if (write_message(p, len, rebase_path_current_fixups(),
 
4280                                 return error(_("could not write file: '%s'"),
 
4281                                              rebase_path_current_fixups());
 
4284                          * If a fixup/squash in a fixup/squash chain failed, the
 
4285                          * commit message is already correct, no need to commit
 
4288                          * Only if it is the final command in the fixup/squash
 
4289                          * chain, and only if the chain is longer than a single
 
4290                          * fixup/squash command (which was just skipped), do we
 
4291                          * actually need to re-commit with a cleaned up commit
 
4294                         if (opts->current_fixup_count > 0 &&
 
4295                             !is_fixup(peek_command(todo_list, 0))) {
 
4298                                  * If there was not a single "squash" in the
 
4299                                  * chain, we only need to clean up the commit
 
4300                                  * message, no need to bother the user with
 
4301                                  * opening the commit message in the editor.
 
4303                                 if (!starts_with(p, "squash ") &&
 
4304                                     !strstr(p, "\nsquash "))
 
4305                                         flags = (flags & ~EDIT_MSG) | CLEANUP_MSG;
 
4306                         } else if (is_fixup(peek_command(todo_list, 0))) {
 
4308                                  * We need to update the squash message to skip
 
4309                                  * the latest commit message.
 
4311                                 struct commit *commit;
 
4312                                 const char *path = rebase_path_squash_msg();
 
4313                                 const char *encoding = get_commit_output_encoding();
 
4315                                 if (parse_head(r, &commit) ||
 
4316                                     !(p = logmsg_reencode(commit, NULL, encoding)) ||
 
4317                                     write_message(p, strlen(p), path, 0)) {
 
4318                                         unuse_commit_buffer(commit, p);
 
4319                                         return error(_("could not write file: "
 
4322                                 unuse_commit_buffer(commit, p);
 
4326                 strbuf_release(&rev);
 
4331                 if (refs_ref_exists(get_main_ref_store(r),
 
4332                                     "CHERRY_PICK_HEAD") &&
 
4333                     refs_delete_ref(get_main_ref_store(r), "",
 
4334                                     "CHERRY_PICK_HEAD", NULL, 0))
 
4335                         return error(_("could not remove CHERRY_PICK_HEAD"));
 
4340         if (run_git_commit(r, final_fixup ? NULL : rebase_path_message(),
 
4342                 return error(_("could not commit staged changes."));
 
4343         unlink(rebase_path_amend());
 
4344         unlink(git_path_merge_head(r));
 
4346                 unlink(rebase_path_fixup_msg());
 
4347                 unlink(rebase_path_squash_msg());
 
4349         if (opts->current_fixup_count > 0) {
 
4351                  * Whether final fixup or not, we just cleaned up the commit
 
4354                 unlink(rebase_path_current_fixups());
 
4355                 strbuf_reset(&opts->current_fixups);
 
4356                 opts->current_fixup_count = 0;
 
4361 int sequencer_continue(struct repository *r, struct replay_opts *opts)
 
4363         struct todo_list todo_list = TODO_LIST_INIT;
 
4366         if (read_and_refresh_cache(r, opts))
 
4369         if (read_populate_opts(opts))
 
4371         if (is_rebase_i(opts)) {
 
4372                 if ((res = read_populate_todo(r, &todo_list, opts)))
 
4373                         goto release_todo_list;
 
4375                 if (file_exists(rebase_path_dropped())) {
 
4376                         if ((res = todo_list_check_against_backup(r, &todo_list)))
 
4377                                 goto release_todo_list;
 
4379                         unlink(rebase_path_dropped());
 
4382                 if (commit_staged_changes(r, opts, &todo_list)) {
 
4384                         goto release_todo_list;
 
4386         } else if (!file_exists(get_todo_path(opts)))
 
4387                 return continue_single_pick(r);
 
4388         else if ((res = read_populate_todo(r, &todo_list, opts)))
 
4389                 goto release_todo_list;
 
4391         if (!is_rebase_i(opts)) {
 
4392                 /* Verify that the conflict has been resolved */
 
4393                 if (refs_ref_exists(get_main_ref_store(r),
 
4394                                     "CHERRY_PICK_HEAD") ||
 
4395                     refs_ref_exists(get_main_ref_store(r), "REVERT_HEAD")) {
 
4396                         res = continue_single_pick(r);
 
4398                                 goto release_todo_list;
 
4400                 if (index_differs_from(r, "HEAD", NULL, 0)) {
 
4401                         res = error_dirty_index(r, opts);
 
4402                         goto release_todo_list;
 
4404                 todo_list.current++;
 
4405         } else if (file_exists(rebase_path_stopped_sha())) {
 
4406                 struct strbuf buf = STRBUF_INIT;
 
4407                 struct object_id oid;
 
4409                 if (read_oneliner(&buf, rebase_path_stopped_sha(),
 
4410                                   READ_ONELINER_SKIP_IF_EMPTY) &&
 
4411                     !get_oid_committish(buf.buf, &oid))
 
4412                         record_in_rewritten(&oid, peek_command(&todo_list, 0));
 
4413                 strbuf_release(&buf);
 
4416         res = pick_commits(r, &todo_list, opts);
 
4418         todo_list_release(&todo_list);
 
4422 static int single_pick(struct repository *r,
 
4423                        struct commit *cmit,
 
4424                        struct replay_opts *opts)
 
4428         setenv(GIT_REFLOG_ACTION, action_name(opts), 0);
 
4429         return do_pick_commit(r, opts->action == REPLAY_PICK ?
 
4430                               TODO_PICK : TODO_REVERT, cmit, opts, 0,
 
4434 int sequencer_pick_revisions(struct repository *r,
 
4435                              struct replay_opts *opts)
 
4437         struct todo_list todo_list = TODO_LIST_INIT;
 
4438         struct object_id oid;
 
4442         if (read_and_refresh_cache(r, opts))
 
4445         for (i = 0; i < opts->revs->pending.nr; i++) {
 
4446                 struct object_id oid;
 
4447                 const char *name = opts->revs->pending.objects[i].name;
 
4449                 /* This happens when using --stdin. */
 
4453                 if (!get_oid(name, &oid)) {
 
4454                         if (!lookup_commit_reference_gently(r, &oid, 1)) {
 
4455                                 enum object_type type = oid_object_info(r,
 
4458                                 return error(_("%s: can't cherry-pick a %s"),
 
4459                                         name, type_name(type));
 
4462                         return error(_("%s: bad revision"), name);
 
4466          * If we were called as "git cherry-pick <commit>", just
 
4467          * cherry-pick/revert it, set CHERRY_PICK_HEAD /
 
4468          * REVERT_HEAD, and don't touch the sequencer state.
 
4469          * This means it is possible to cherry-pick in the middle
 
4470          * of a cherry-pick sequence.
 
4472         if (opts->revs->cmdline.nr == 1 &&
 
4473             opts->revs->cmdline.rev->whence == REV_CMD_REV &&
 
4474             opts->revs->no_walk &&
 
4475             !opts->revs->cmdline.rev->flags) {
 
4476                 struct commit *cmit;
 
4477                 if (prepare_revision_walk(opts->revs))
 
4478                         return error(_("revision walk setup failed"));
 
4479                 cmit = get_revision(opts->revs);
 
4481                         return error(_("empty commit set passed"));
 
4482                 if (get_revision(opts->revs))
 
4483                         BUG("unexpected extra commit from walk");
 
4484                 return single_pick(r, cmit, opts);
 
4488          * Start a new cherry-pick/ revert sequence; but
 
4489          * first, make sure that an existing one isn't in
 
4493         if (walk_revs_populate_todo(&todo_list, opts) ||
 
4494                         create_seq_dir(r) < 0)
 
4496         if (get_oid("HEAD", &oid) && (opts->action == REPLAY_REVERT))
 
4497                 return error(_("can't revert as initial commit"));
 
4498         if (save_head(oid_to_hex(&oid)))
 
4500         if (save_opts(opts))
 
4502         update_abort_safety_file();
 
4503         res = pick_commits(r, &todo_list, opts);
 
4504         todo_list_release(&todo_list);
 
4508 void append_signoff(struct strbuf *msgbuf, size_t ignore_footer, unsigned flag)
 
4510         unsigned no_dup_sob = flag & APPEND_SIGNOFF_DEDUP;
 
4511         struct strbuf sob = STRBUF_INIT;
 
4514         strbuf_addstr(&sob, sign_off_header);
 
4515         strbuf_addstr(&sob, fmt_name(WANT_COMMITTER_IDENT));
 
4516         strbuf_addch(&sob, '\n');
 
4519                 strbuf_complete_line(msgbuf);
 
4522          * If the whole message buffer is equal to the sob, pretend that we
 
4523          * found a conforming footer with a matching sob
 
4525         if (msgbuf->len - ignore_footer == sob.len &&
 
4526             !strncmp(msgbuf->buf, sob.buf, sob.len))
 
4529                 has_footer = has_conforming_footer(msgbuf, &sob, ignore_footer);
 
4532                 const char *append_newlines = NULL;
 
4533                 size_t len = msgbuf->len - ignore_footer;
 
4537                          * The buffer is completely empty.  Leave foom for
 
4538                          * the title and body to be filled in by the user.
 
4540                         append_newlines = "\n\n";
 
4541                 } else if (len == 1) {
 
4543                          * Buffer contains a single newline.  Add another
 
4544                          * so that we leave room for the title and body.
 
4546                         append_newlines = "\n";
 
4547                 } else if (msgbuf->buf[len - 2] != '\n') {
 
4549                          * Buffer ends with a single newline.  Add another
 
4550                          * so that there is an empty line between the message
 
4553                         append_newlines = "\n";
 
4554                 } /* else, the buffer already ends with two newlines. */
 
4556                 if (append_newlines)
 
4557                         strbuf_splice(msgbuf, msgbuf->len - ignore_footer, 0,
 
4558                                 append_newlines, strlen(append_newlines));
 
4561         if (has_footer != 3 && (!no_dup_sob || has_footer != 2))
 
4562                 strbuf_splice(msgbuf, msgbuf->len - ignore_footer, 0,
 
4565         strbuf_release(&sob);
 
4568 struct labels_entry {
 
4569         struct hashmap_entry entry;
 
4570         char label[FLEX_ARRAY];
 
4573 static int labels_cmp(const void *fndata, const struct hashmap_entry *eptr,
 
4574                       const struct hashmap_entry *entry_or_key, const void *key)
 
4576         const struct labels_entry *a, *b;
 
4578         a = container_of(eptr, const struct labels_entry, entry);
 
4579         b = container_of(entry_or_key, const struct labels_entry, entry);
 
4581         return key ? strcmp(a->label, key) : strcmp(a->label, b->label);
 
4584 struct string_entry {
 
4585         struct oidmap_entry entry;
 
4586         char string[FLEX_ARRAY];
 
4589 struct label_state {
 
4590         struct oidmap commit2label;
 
4591         struct hashmap labels;
 
4595 static const char *label_oid(struct object_id *oid, const char *label,
 
4596                              struct label_state *state)
 
4598         struct labels_entry *labels_entry;
 
4599         struct string_entry *string_entry;
 
4600         struct object_id dummy;
 
4603         string_entry = oidmap_get(&state->commit2label, oid);
 
4605                 return string_entry->string;
 
4608          * For "uninteresting" commits, i.e. commits that are not to be
 
4609          * rebased, and which can therefore not be labeled, we use a unique
 
4610          * abbreviation of the commit name. This is slightly more complicated
 
4611          * than calling find_unique_abbrev() because we also need to make
 
4612          * sure that the abbreviation does not conflict with any other
 
4615          * We disallow "interesting" commits to be labeled by a string that
 
4616          * is a valid full-length hash, to ensure that we always can find an
 
4617          * abbreviation for any uninteresting commit's names that does not
 
4618          * clash with any other label.
 
4620         strbuf_reset(&state->buf);
 
4624                 strbuf_grow(&state->buf, GIT_MAX_HEXSZ);
 
4625                 label = p = state->buf.buf;
 
4627                 find_unique_abbrev_r(p, oid, default_abbrev);
 
4630                  * We may need to extend the abbreviated hash so that there is
 
4631                  * no conflicting label.
 
4633                 if (hashmap_get_from_hash(&state->labels, strihash(p), p)) {
 
4634                         size_t i = strlen(p) + 1;
 
4636                         oid_to_hex_r(p, oid);
 
4637                         for (; i < the_hash_algo->hexsz; i++) {
 
4640                                 if (!hashmap_get_from_hash(&state->labels,
 
4647                 struct strbuf *buf = &state->buf;
 
4650                  * Sanitize labels by replacing non-alpha-numeric characters
 
4651                  * (including white-space ones) by dashes, as they might be
 
4652                  * illegal in file names (and hence in ref names).
 
4654                  * Note that we retain non-ASCII UTF-8 characters (identified
 
4655                  * via the most significant bit). They should be all acceptable
 
4656                  * in file names. We do not validate the UTF-8 here, that's not
 
4657                  * the job of this function.
 
4659                 for (; *label; label++)
 
4660                         if ((*label & 0x80) || isalnum(*label))
 
4661                                 strbuf_addch(buf, *label);
 
4662                         /* avoid leading dash and double-dashes */
 
4663                         else if (buf->len && buf->buf[buf->len - 1] != '-')
 
4664                                 strbuf_addch(buf, '-');
 
4666                         strbuf_addstr(buf, "rev-");
 
4667                         strbuf_add_unique_abbrev(buf, oid, default_abbrev);
 
4671                 if ((buf->len == the_hash_algo->hexsz &&
 
4672                      !get_oid_hex(label, &dummy)) ||
 
4673                     (buf->len == 1 && *label == '#') ||
 
4674                     hashmap_get_from_hash(&state->labels,
 
4675                                           strihash(label), label)) {
 
4677                          * If the label already exists, or if the label is a
 
4678                          * valid full OID, or the label is a '#' (which we use
 
4679                          * as a separator between merge heads and oneline), we
 
4680                          * append a dash and a number to make it unique.
 
4682                         size_t len = buf->len;
 
4684                         for (i = 2; ; i++) {
 
4685                                 strbuf_setlen(buf, len);
 
4686                                 strbuf_addf(buf, "-%d", i);
 
4687                                 if (!hashmap_get_from_hash(&state->labels,
 
4697         FLEX_ALLOC_STR(labels_entry, label, label);
 
4698         hashmap_entry_init(&labels_entry->entry, strihash(label));
 
4699         hashmap_add(&state->labels, &labels_entry->entry);
 
4701         FLEX_ALLOC_STR(string_entry, string, label);
 
4702         oidcpy(&string_entry->entry.oid, oid);
 
4703         oidmap_put(&state->commit2label, string_entry);
 
4705         return string_entry->string;
 
4708 static int make_script_with_merges(struct pretty_print_context *pp,
 
4709                                    struct rev_info *revs, struct strbuf *out,
 
4712         int keep_empty = flags & TODO_LIST_KEEP_EMPTY;
 
4713         int rebase_cousins = flags & TODO_LIST_REBASE_COUSINS;
 
4714         int root_with_onto = flags & TODO_LIST_ROOT_WITH_ONTO;
 
4715         struct strbuf buf = STRBUF_INIT, oneline = STRBUF_INIT;
 
4716         struct strbuf label = STRBUF_INIT;
 
4717         struct commit_list *commits = NULL, **tail = &commits, *iter;
 
4718         struct commit_list *tips = NULL, **tips_tail = &tips;
 
4719         struct commit *commit;
 
4720         struct oidmap commit2todo = OIDMAP_INIT;
 
4721         struct string_entry *entry;
 
4722         struct oidset interesting = OIDSET_INIT, child_seen = OIDSET_INIT,
 
4723                 shown = OIDSET_INIT;
 
4724         struct label_state state = { OIDMAP_INIT, { NULL }, STRBUF_INIT };
 
4726         int abbr = flags & TODO_LIST_ABBREVIATE_CMDS;
 
4727         const char *cmd_pick = abbr ? "p" : "pick",
 
4728                 *cmd_label = abbr ? "l" : "label",
 
4729                 *cmd_reset = abbr ? "t" : "reset",
 
4730                 *cmd_merge = abbr ? "m" : "merge";
 
4732         oidmap_init(&commit2todo, 0);
 
4733         oidmap_init(&state.commit2label, 0);
 
4734         hashmap_init(&state.labels, labels_cmp, NULL, 0);
 
4735         strbuf_init(&state.buf, 32);
 
4737         if (revs->cmdline.nr && (revs->cmdline.rev[0].flags & BOTTOM)) {
 
4738                 struct labels_entry *onto_label_entry;
 
4739                 struct object_id *oid = &revs->cmdline.rev[0].item->oid;
 
4740                 FLEX_ALLOC_STR(entry, string, "onto");
 
4741                 oidcpy(&entry->entry.oid, oid);
 
4742                 oidmap_put(&state.commit2label, entry);
 
4744                 FLEX_ALLOC_STR(onto_label_entry, label, "onto");
 
4745                 hashmap_entry_init(&onto_label_entry->entry, strihash("onto"));
 
4746                 hashmap_add(&state.labels, &onto_label_entry->entry);
 
4751          * - get onelines for all commits
 
4752          * - gather all branch tips (i.e. 2nd or later parents of merges)
 
4753          * - label all branch tips
 
4755         while ((commit = get_revision(revs))) {
 
4756                 struct commit_list *to_merge;
 
4757                 const char *p1, *p2;
 
4758                 struct object_id *oid;
 
4761                 tail = &commit_list_insert(commit, tail)->next;
 
4762                 oidset_insert(&interesting, &commit->object.oid);
 
4764                 is_empty = is_original_commit_empty(commit);
 
4765                 if (!is_empty && (commit->object.flags & PATCHSAME))
 
4767                 if (is_empty && !keep_empty)
 
4770                 strbuf_reset(&oneline);
 
4771                 pretty_print_commit(pp, commit, &oneline);
 
4773                 to_merge = commit->parents ? commit->parents->next : NULL;
 
4775                         /* non-merge commit: easy case */
 
4777                         strbuf_addf(&buf, "%s %s %s", cmd_pick,
 
4778                                     oid_to_hex(&commit->object.oid),
 
4781                                 strbuf_addf(&buf, " %c empty",
 
4784                         FLEX_ALLOC_STR(entry, string, buf.buf);
 
4785                         oidcpy(&entry->entry.oid, &commit->object.oid);
 
4786                         oidmap_put(&commit2todo, entry);
 
4791                 /* Create a label */
 
4792                 strbuf_reset(&label);
 
4793                 if (skip_prefix(oneline.buf, "Merge ", &p1) &&
 
4794                     (p1 = strchr(p1, '\'')) &&
 
4795                     (p2 = strchr(++p1, '\'')))
 
4796                         strbuf_add(&label, p1, p2 - p1);
 
4797                 else if (skip_prefix(oneline.buf, "Merge pull request ",
 
4799                          (p1 = strstr(p1, " from ")))
 
4800                         strbuf_addstr(&label, p1 + strlen(" from "));
 
4802                         strbuf_addbuf(&label, &oneline);
 
4805                 strbuf_addf(&buf, "%s -C %s",
 
4806                             cmd_merge, oid_to_hex(&commit->object.oid));
 
4808                 /* label the tips of merged branches */
 
4809                 for (; to_merge; to_merge = to_merge->next) {
 
4810                         oid = &to_merge->item->object.oid;
 
4811                         strbuf_addch(&buf, ' ');
 
4813                         if (!oidset_contains(&interesting, oid)) {
 
4814                                 strbuf_addstr(&buf, label_oid(oid, NULL,
 
4819                         tips_tail = &commit_list_insert(to_merge->item,
 
4822                         strbuf_addstr(&buf, label_oid(oid, label.buf, &state));
 
4824                 strbuf_addf(&buf, " # %s", oneline.buf);
 
4826                 FLEX_ALLOC_STR(entry, string, buf.buf);
 
4827                 oidcpy(&entry->entry.oid, &commit->object.oid);
 
4828                 oidmap_put(&commit2todo, entry);
 
4833          * - label branch points
 
4834          * - add HEAD to the branch tips
 
4836         for (iter = commits; iter; iter = iter->next) {
 
4837                 struct commit_list *parent = iter->item->parents;
 
4838                 for (; parent; parent = parent->next) {
 
4839                         struct object_id *oid = &parent->item->object.oid;
 
4840                         if (!oidset_contains(&interesting, oid))
 
4842                         if (oidset_insert(&child_seen, oid))
 
4843                                 label_oid(oid, "branch-point", &state);
 
4846                 /* Add HEAD as implicit "tip of branch" */
 
4848                         tips_tail = &commit_list_insert(iter->item,
 
4853          * Third phase: output the todo list. This is a bit tricky, as we
 
4854          * want to avoid jumping back and forth between revisions. To
 
4855          * accomplish that goal, we walk backwards from the branch tips,
 
4856          * gathering commits not yet shown, reversing the list on the fly,
 
4857          * then outputting that list (labeling revisions as needed).
 
4859         strbuf_addf(out, "%s onto\n", cmd_label);
 
4860         for (iter = tips; iter; iter = iter->next) {
 
4861                 struct commit_list *list = NULL, *iter2;
 
4863                 commit = iter->item;
 
4864                 if (oidset_contains(&shown, &commit->object.oid))
 
4866                 entry = oidmap_get(&state.commit2label, &commit->object.oid);
 
4869                         strbuf_addf(out, "\n%c Branch %s\n", comment_line_char, entry->string);
 
4871                         strbuf_addch(out, '\n');
 
4873                 while (oidset_contains(&interesting, &commit->object.oid) &&
 
4874                        !oidset_contains(&shown, &commit->object.oid)) {
 
4875                         commit_list_insert(commit, &list);
 
4876                         if (!commit->parents) {
 
4880                         commit = commit->parents->item;
 
4884                         strbuf_addf(out, "%s %s\n", cmd_reset,
 
4885                                     rebase_cousins || root_with_onto ?
 
4886                                     "onto" : "[new root]");
 
4888                         const char *to = NULL;
 
4890                         entry = oidmap_get(&state.commit2label,
 
4891                                            &commit->object.oid);
 
4894                         else if (!rebase_cousins)
 
4895                                 to = label_oid(&commit->object.oid, NULL,
 
4898                         if (!to || !strcmp(to, "onto"))
 
4899                                 strbuf_addf(out, "%s onto\n", cmd_reset);
 
4901                                 strbuf_reset(&oneline);
 
4902                                 pretty_print_commit(pp, commit, &oneline);
 
4903                                 strbuf_addf(out, "%s %s # %s\n",
 
4904                                             cmd_reset, to, oneline.buf);
 
4908                 for (iter2 = list; iter2; iter2 = iter2->next) {
 
4909                         struct object_id *oid = &iter2->item->object.oid;
 
4910                         entry = oidmap_get(&commit2todo, oid);
 
4911                         /* only show if not already upstream */
 
4913                                 strbuf_addf(out, "%s\n", entry->string);
 
4914                         entry = oidmap_get(&state.commit2label, oid);
 
4916                                 strbuf_addf(out, "%s %s\n",
 
4917                                             cmd_label, entry->string);
 
4918                         oidset_insert(&shown, oid);
 
4921                 free_commit_list(list);
 
4924         free_commit_list(commits);
 
4925         free_commit_list(tips);
 
4927         strbuf_release(&label);
 
4928         strbuf_release(&oneline);
 
4929         strbuf_release(&buf);
 
4931         oidmap_free(&commit2todo, 1);
 
4932         oidmap_free(&state.commit2label, 1);
 
4933         hashmap_free_entries(&state.labels, struct labels_entry, entry);
 
4934         strbuf_release(&state.buf);
 
4939 int sequencer_make_script(struct repository *r, struct strbuf *out, int argc,
 
4940                           const char **argv, unsigned flags)
 
4942         char *format = NULL;
 
4943         struct pretty_print_context pp = {0};
 
4944         struct rev_info revs;
 
4945         struct commit *commit;
 
4946         int keep_empty = flags & TODO_LIST_KEEP_EMPTY;
 
4947         const char *insn = flags & TODO_LIST_ABBREVIATE_CMDS ? "p" : "pick";
 
4948         int rebase_merges = flags & TODO_LIST_REBASE_MERGES;
 
4949         int reapply_cherry_picks = flags & TODO_LIST_REAPPLY_CHERRY_PICKS;
 
4951         repo_init_revisions(r, &revs, NULL);
 
4952         revs.verbose_header = 1;
 
4954                 revs.max_parents = 1;
 
4955         revs.cherry_mark = !reapply_cherry_picks;
 
4958         revs.right_only = 1;
 
4959         revs.sort_order = REV_SORT_IN_GRAPH_ORDER;
 
4960         revs.topo_order = 1;
 
4962         revs.pretty_given = 1;
 
4963         git_config_get_string("rebase.instructionFormat", &format);
 
4964         if (!format || !*format) {
 
4966                 format = xstrdup("%s");
 
4968         get_commit_format(format, &revs);
 
4970         pp.fmt = revs.commit_format;
 
4971         pp.output_encoding = get_log_output_encoding();
 
4973         if (setup_revisions(argc, argv, &revs, NULL) > 1)
 
4974                 return error(_("make_script: unhandled options"));
 
4976         if (prepare_revision_walk(&revs) < 0)
 
4977                 return error(_("make_script: error preparing revisions"));
 
4980                 return make_script_with_merges(&pp, &revs, out, flags);
 
4982         while ((commit = get_revision(&revs))) {
 
4983                 int is_empty = is_original_commit_empty(commit);
 
4985                 if (!is_empty && (commit->object.flags & PATCHSAME))
 
4987                 if (is_empty && !keep_empty)
 
4989                 strbuf_addf(out, "%s %s ", insn,
 
4990                             oid_to_hex(&commit->object.oid));
 
4991                 pretty_print_commit(&pp, commit, out);
 
4993                         strbuf_addf(out, " %c empty", comment_line_char);
 
4994                 strbuf_addch(out, '\n');
 
5000  * Add commands after pick and (series of) squash/fixup commands
 
5003 void todo_list_add_exec_commands(struct todo_list *todo_list,
 
5004                                  struct string_list *commands)
 
5006         struct strbuf *buf = &todo_list->buf;
 
5007         size_t base_offset = buf->len;
 
5008         int i, insert, nr = 0, alloc = 0;
 
5009         struct todo_item *items = NULL, *base_items = NULL;
 
5011         base_items = xcalloc(commands->nr, sizeof(struct todo_item));
 
5012         for (i = 0; i < commands->nr; i++) {
 
5013                 size_t command_len = strlen(commands->items[i].string);
 
5015                 strbuf_addstr(buf, commands->items[i].string);
 
5016                 strbuf_addch(buf, '\n');
 
5018                 base_items[i].command = TODO_EXEC;
 
5019                 base_items[i].offset_in_buf = base_offset;
 
5020                 base_items[i].arg_offset = base_offset + strlen("exec ");
 
5021                 base_items[i].arg_len = command_len - strlen("exec ");
 
5023                 base_offset += command_len + 1;
 
5027          * Insert <commands> after every pick. Here, fixup/squash chains
 
5028          * are considered part of the pick, so we insert the commands *after*
 
5029          * those chains if there are any.
 
5031          * As we insert the exec commands immediately after rearranging
 
5032          * any fixups and before the user edits the list, a fixup chain
 
5033          * can never contain comments (any comments are empty picks that
 
5034          * have been commented out because the user did not specify
 
5035          * --keep-empty).  So, it is safe to insert an exec command
 
5036          * without looking at the command following a comment.
 
5039         for (i = 0; i < todo_list->nr; i++) {
 
5040                 enum todo_command command = todo_list->items[i].command;
 
5041                 if (insert && !is_fixup(command)) {
 
5042                         ALLOC_GROW(items, nr + commands->nr, alloc);
 
5043                         COPY_ARRAY(items + nr, base_items, commands->nr);
 
5049                 ALLOC_GROW(items, nr + 1, alloc);
 
5050                 items[nr++] = todo_list->items[i];
 
5052                 if (command == TODO_PICK || command == TODO_MERGE)
 
5056         /* insert or append final <commands> */
 
5057         if (insert || nr == todo_list->nr) {
 
5058                 ALLOC_GROW(items, nr + commands->nr, alloc);
 
5059                 COPY_ARRAY(items + nr, base_items, commands->nr);
 
5064         FREE_AND_NULL(todo_list->items);
 
5065         todo_list->items = items;
 
5067         todo_list->alloc = alloc;
 
5070 static void todo_list_to_strbuf(struct repository *r, struct todo_list *todo_list,
 
5071                                 struct strbuf *buf, int num, unsigned flags)
 
5073         struct todo_item *item;
 
5074         int i, max = todo_list->nr;
 
5076         if (num > 0 && num < max)
 
5079         for (item = todo_list->items, i = 0; i < max; i++, item++) {
 
5082                 /* if the item is not a command write it and continue */
 
5083                 if (item->command >= TODO_COMMENT) {
 
5084                         strbuf_addf(buf, "%.*s\n", item->arg_len,
 
5085                                     todo_item_get_arg(todo_list, item));
 
5089                 /* add command to the buffer */
 
5090                 cmd = command_to_char(item->command);
 
5091                 if ((flags & TODO_LIST_ABBREVIATE_CMDS) && cmd)
 
5092                         strbuf_addch(buf, cmd);
 
5094                         strbuf_addstr(buf, command_to_string(item->command));
 
5098                         const char *oid = flags & TODO_LIST_SHORTEN_IDS ?
 
5099                                           short_commit_name(item->commit) :
 
5100                                           oid_to_hex(&item->commit->object.oid);
 
5102                         if (item->command == TODO_MERGE) {
 
5103                                 if (item->flags & TODO_EDIT_MERGE_MSG)
 
5104                                         strbuf_addstr(buf, " -c");
 
5106                                         strbuf_addstr(buf, " -C");
 
5109                         strbuf_addf(buf, " %s", oid);
 
5112                 /* add all the rest */
 
5114                         strbuf_addch(buf, '\n');
 
5116                         strbuf_addf(buf, " %.*s\n", item->arg_len,
 
5117                                     todo_item_get_arg(todo_list, item));
 
5121 int todo_list_write_to_file(struct repository *r, struct todo_list *todo_list,
 
5122                             const char *file, const char *shortrevisions,
 
5123                             const char *shortonto, int num, unsigned flags)
 
5126         struct strbuf buf = STRBUF_INIT;
 
5128         todo_list_to_strbuf(r, todo_list, &buf, num, flags);
 
5129         if (flags & TODO_LIST_APPEND_TODO_HELP)
 
5130                 append_todo_help(count_commands(todo_list),
 
5131                                  shortrevisions, shortonto, &buf);
 
5133         res = write_message(buf.buf, buf.len, file, 0);
 
5134         strbuf_release(&buf);
 
5139 /* skip picking commits whose parents are unchanged */
 
5140 static int skip_unnecessary_picks(struct repository *r,
 
5141                                   struct todo_list *todo_list,
 
5142                                   struct object_id *base_oid)
 
5144         struct object_id *parent_oid;
 
5147         for (i = 0; i < todo_list->nr; i++) {
 
5148                 struct todo_item *item = todo_list->items + i;
 
5150                 if (item->command >= TODO_NOOP)
 
5152                 if (item->command != TODO_PICK)
 
5154                 if (parse_commit(item->commit)) {
 
5155                         return error(_("could not parse commit '%s'"),
 
5156                                 oid_to_hex(&item->commit->object.oid));
 
5158                 if (!item->commit->parents)
 
5159                         break; /* root commit */
 
5160                 if (item->commit->parents->next)
 
5161                         break; /* merge commit */
 
5162                 parent_oid = &item->commit->parents->item->object.oid;
 
5163                 if (!oideq(parent_oid, base_oid))
 
5165                 oidcpy(base_oid, &item->commit->object.oid);
 
5168                 const char *done_path = rebase_path_done();
 
5170                 if (todo_list_write_to_file(r, todo_list, done_path, NULL, NULL, i, 0)) {
 
5171                         error_errno(_("could not write to '%s'"), done_path);
 
5175                 MOVE_ARRAY(todo_list->items, todo_list->items + i, todo_list->nr - i);
 
5177                 todo_list->current = 0;
 
5178                 todo_list->done_nr += i;
 
5180                 if (is_fixup(peek_command(todo_list, 0)))
 
5181                         record_in_rewritten(base_oid, peek_command(todo_list, 0));
 
5187 int complete_action(struct repository *r, struct replay_opts *opts, unsigned flags,
 
5188                     const char *shortrevisions, const char *onto_name,
 
5189                     struct commit *onto, const char *orig_head,
 
5190                     struct string_list *commands, unsigned autosquash,
 
5191                     struct todo_list *todo_list)
 
5193         const char *shortonto, *todo_file = rebase_path_todo();
 
5194         struct todo_list new_todo = TODO_LIST_INIT;
 
5195         struct strbuf *buf = &todo_list->buf, buf2 = STRBUF_INIT;
 
5196         struct object_id oid = onto->object.oid;
 
5199         shortonto = find_unique_abbrev(&oid, DEFAULT_ABBREV);
 
5201         if (buf->len == 0) {
 
5202                 struct todo_item *item = append_new_todo(todo_list);
 
5203                 item->command = TODO_NOOP;
 
5204                 item->commit = NULL;
 
5205                 item->arg_len = item->arg_offset = item->flags = item->offset_in_buf = 0;
 
5208         if (autosquash && todo_list_rearrange_squash(todo_list))
 
5212                 todo_list_add_exec_commands(todo_list, commands);
 
5214         if (count_commands(todo_list) == 0) {
 
5215                 apply_autostash(rebase_path_autostash());
 
5216                 sequencer_remove_state(opts);
 
5218                 return error(_("nothing to do"));
 
5221         res = edit_todo_list(r, todo_list, &new_todo, shortrevisions,
 
5225         else if (res == -2) {
 
5226                 apply_autostash(rebase_path_autostash());
 
5227                 sequencer_remove_state(opts);
 
5230         } else if (res == -3) {
 
5231                 apply_autostash(rebase_path_autostash());
 
5232                 sequencer_remove_state(opts);
 
5233                 todo_list_release(&new_todo);
 
5235                 return error(_("nothing to do"));
 
5236         } else if (res == -4) {
 
5237                 checkout_onto(r, opts, onto_name, &onto->object.oid, orig_head);
 
5238                 todo_list_release(&new_todo);
 
5243         /* Expand the commit IDs */
 
5244         todo_list_to_strbuf(r, &new_todo, &buf2, -1, 0);
 
5245         strbuf_swap(&new_todo.buf, &buf2);
 
5246         strbuf_release(&buf2);
 
5247         new_todo.total_nr -= new_todo.nr;
 
5248         if (todo_list_parse_insn_buffer(r, new_todo.buf.buf, &new_todo) < 0)
 
5249                 BUG("invalid todo list after expanding IDs:\n%s",
 
5252         if (opts->allow_ff && skip_unnecessary_picks(r, &new_todo, &oid)) {
 
5253                 todo_list_release(&new_todo);
 
5254                 return error(_("could not skip unnecessary pick commands"));
 
5257         if (todo_list_write_to_file(r, &new_todo, todo_file, NULL, NULL, -1,
 
5258                                     flags & ~(TODO_LIST_SHORTEN_IDS))) {
 
5259                 todo_list_release(&new_todo);
 
5260                 return error_errno(_("could not write '%s'"), todo_file);
 
5265         if (checkout_onto(r, opts, onto_name, &oid, orig_head))
 
5268         if (require_clean_work_tree(r, "rebase", "", 1, 1))
 
5271         todo_list_write_total_nr(&new_todo);
 
5272         res = pick_commits(r, &new_todo, opts);
 
5275         todo_list_release(&new_todo);
 
5280 struct subject2item_entry {
 
5281         struct hashmap_entry entry;
 
5283         char subject[FLEX_ARRAY];
 
5286 static int subject2item_cmp(const void *fndata,
 
5287                             const struct hashmap_entry *eptr,
 
5288                             const struct hashmap_entry *entry_or_key,
 
5291         const struct subject2item_entry *a, *b;
 
5293         a = container_of(eptr, const struct subject2item_entry, entry);
 
5294         b = container_of(entry_or_key, const struct subject2item_entry, entry);
 
5296         return key ? strcmp(a->subject, key) : strcmp(a->subject, b->subject);
 
5299 define_commit_slab(commit_todo_item, struct todo_item *);
 
5302  * Rearrange the todo list that has both "pick commit-id msg" and "pick
 
5303  * commit-id fixup!/squash! msg" in it so that the latter is put immediately
 
5304  * after the former, and change "pick" to "fixup"/"squash".
 
5306  * Note that if the config has specified a custom instruction format, each log
 
5307  * message will have to be retrieved from the commit (as the oneline in the
 
5308  * script cannot be trusted) in order to normalize the autosquash arrangement.
 
5310 int todo_list_rearrange_squash(struct todo_list *todo_list)
 
5312         struct hashmap subject2item;
 
5313         int rearranged = 0, *next, *tail, i, nr = 0, alloc = 0;
 
5315         struct commit_todo_item commit_todo;
 
5316         struct todo_item *items = NULL;
 
5318         init_commit_todo_item(&commit_todo);
 
5320          * The hashmap maps onelines to the respective todo list index.
 
5322          * If any items need to be rearranged, the next[i] value will indicate
 
5323          * which item was moved directly after the i'th.
 
5325          * In that case, last[i] will indicate the index of the latest item to
 
5326          * be moved to appear after the i'th.
 
5328         hashmap_init(&subject2item, subject2item_cmp, NULL, todo_list->nr);
 
5329         ALLOC_ARRAY(next, todo_list->nr);
 
5330         ALLOC_ARRAY(tail, todo_list->nr);
 
5331         ALLOC_ARRAY(subjects, todo_list->nr);
 
5332         for (i = 0; i < todo_list->nr; i++) {
 
5333                 struct strbuf buf = STRBUF_INIT;
 
5334                 struct todo_item *item = todo_list->items + i;
 
5335                 const char *commit_buffer, *subject, *p;
 
5338                 struct subject2item_entry *entry;
 
5340                 next[i] = tail[i] = -1;
 
5341                 if (!item->commit || item->command == TODO_DROP) {
 
5346                 if (is_fixup(item->command)) {
 
5347                         clear_commit_todo_item(&commit_todo);
 
5348                         return error(_("the script was already rearranged."));
 
5351                 *commit_todo_item_at(&commit_todo, item->commit) = item;
 
5353                 parse_commit(item->commit);
 
5354                 commit_buffer = logmsg_reencode(item->commit, NULL, "UTF-8");
 
5355                 find_commit_subject(commit_buffer, &subject);
 
5356                 format_subject(&buf, subject, " ");
 
5357                 subject = subjects[i] = strbuf_detach(&buf, &subject_len);
 
5358                 unuse_commit_buffer(item->commit, commit_buffer);
 
5359                 if ((skip_prefix(subject, "fixup! ", &p) ||
 
5360                      skip_prefix(subject, "squash! ", &p))) {
 
5361                         struct commit *commit2;
 
5366                                 if (!skip_prefix(p, "fixup! ", &p) &&
 
5367                                     !skip_prefix(p, "squash! ", &p))
 
5371                         entry = hashmap_get_entry_from_hash(&subject2item,
 
5373                                                 struct subject2item_entry,
 
5376                                 /* found by title */
 
5378                         else if (!strchr(p, ' ') &&
 
5380                                   lookup_commit_reference_by_name(p)) &&
 
5381                                  *commit_todo_item_at(&commit_todo, commit2))
 
5382                                 /* found by commit name */
 
5383                                 i2 = *commit_todo_item_at(&commit_todo, commit2)
 
5386                                 /* copy can be a prefix of the commit subject */
 
5387                                 for (i2 = 0; i2 < i; i2++)
 
5389                                             starts_with(subjects[i2], p))
 
5397                         todo_list->items[i].command =
 
5398                                 starts_with(subject, "fixup!") ?
 
5399                                 TODO_FIXUP : TODO_SQUASH;
 
5404                                 next[i] = next[tail[i2]];
 
5408                 } else if (!hashmap_get_from_hash(&subject2item,
 
5409                                                 strhash(subject), subject)) {
 
5410                         FLEX_ALLOC_MEM(entry, subject, subject, subject_len);
 
5412                         hashmap_entry_init(&entry->entry,
 
5413                                         strhash(entry->subject));
 
5414                         hashmap_put(&subject2item, &entry->entry);
 
5419                 for (i = 0; i < todo_list->nr; i++) {
 
5420                         enum todo_command command = todo_list->items[i].command;
 
5424                          * Initially, all commands are 'pick's. If it is a
 
5425                          * fixup or a squash now, we have rearranged it.
 
5427                         if (is_fixup(command))
 
5431                                 ALLOC_GROW(items, nr + 1, alloc);
 
5432                                 items[nr++] = todo_list->items[cur];
 
5437                 FREE_AND_NULL(todo_list->items);
 
5438                 todo_list->items = items;
 
5440                 todo_list->alloc = alloc;
 
5445         for (i = 0; i < todo_list->nr; i++)
 
5448         hashmap_free_entries(&subject2item, struct subject2item_entry, entry);
 
5450         clear_commit_todo_item(&commit_todo);
 
5455 int sequencer_determine_whence(struct repository *r, enum commit_whence *whence)
 
5457         if (refs_ref_exists(get_main_ref_store(r), "CHERRY_PICK_HEAD")) {
 
5458                 struct object_id cherry_pick_head, rebase_head;
 
5460                 if (file_exists(git_path_seq_dir()))
 
5461                         *whence = FROM_CHERRY_PICK_MULTI;
 
5462                 if (file_exists(rebase_path()) &&
 
5463                     !get_oid("REBASE_HEAD", &rebase_head) &&
 
5464                     !get_oid("CHERRY_PICK_HEAD", &cherry_pick_head) &&
 
5465                     oideq(&rebase_head, &cherry_pick_head))
 
5466                         *whence = FROM_REBASE_PICK;
 
5468                         *whence = FROM_CHERRY_PICK_SINGLE;