Ramkumar Ramachandra | 26ae337 | 2011-08-04 16:09:11 +0530 | [diff] [blame] | 1 | #ifndef SEQUENCER_H |
| 2 | #define SEQUENCER_H |
| 3 | |
Elijah Newren | ef3ca95 | 2018-08-15 10:54:05 -0700 | [diff] [blame] | 4 | #include "cache.h" |
| 5 | #include "strbuf.h" |
Phillip Wood | 901ba7b | 2019-12-06 16:06:11 +0000 | [diff] [blame] | 6 | #include "wt-status.h" |
Elijah Newren | ef3ca95 | 2018-08-15 10:54:05 -0700 | [diff] [blame] | 7 | |
| 8 | struct commit; |
Nguyễn Thái Ngọc Duy | f11c958 | 2018-11-10 06:48:56 +0100 | [diff] [blame] | 9 | struct repository; |
Elijah Newren | ef3ca95 | 2018-08-15 10:54:05 -0700 | [diff] [blame] | 10 | |
Phillip Wood | 66618a5 | 2018-01-24 12:34:22 +0000 | [diff] [blame] | 11 | const char *git_path_commit_editmsg(void); |
Alban Gruin | 44b776c | 2018-08-10 18:51:28 +0200 | [diff] [blame] | 12 | const char *rebase_path_todo(void); |
Alban Gruin | a930eb0 | 2019-03-05 20:18:03 +0100 | [diff] [blame] | 13 | const char *rebase_path_todo_backup(void); |
Alban Gruin | 5a5445d | 2020-01-28 22:12:46 +0100 | [diff] [blame] | 14 | const char *rebase_path_dropped(void); |
Ramkumar Ramachandra | 26ae337 | 2011-08-04 16:09:11 +0530 | [diff] [blame] | 15 | |
Brandon Casey | bab4d10 | 2013-02-12 02:17:35 -0800 | [diff] [blame] | 16 | #define APPEND_SIGNOFF_DEDUP (1u << 0) |
| 17 | |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 18 | enum replay_action { |
| 19 | REPLAY_REVERT, |
Johannes Schindelin | 8458395 | 2017-01-02 16:26:28 +0100 | [diff] [blame] | 20 | REPLAY_PICK, |
| 21 | REPLAY_INTERACTIVE_REBASE |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 22 | }; |
| 23 | |
Phillip Wood | 28d6dae | 2017-12-13 11:46:21 +0000 | [diff] [blame] | 24 | enum commit_msg_cleanup_mode { |
| 25 | COMMIT_MSG_CLEANUP_SPACE, |
| 26 | COMMIT_MSG_CLEANUP_NONE, |
| 27 | COMMIT_MSG_CLEANUP_SCISSORS, |
| 28 | COMMIT_MSG_CLEANUP_ALL |
| 29 | }; |
| 30 | |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 31 | struct replay_opts { |
| 32 | enum replay_action action; |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 33 | |
Elijah Newren | 39edfd5 | 2021-03-31 06:52:20 +0000 | [diff] [blame] | 34 | /* Tri-state options: unspecified, false, or true */ |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 35 | int edit; |
Elijah Newren | 39edfd5 | 2021-03-31 06:52:20 +0000 | [diff] [blame] | 36 | |
| 37 | /* Boolean options */ |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 38 | int record_origin; |
| 39 | int no_commit; |
| 40 | int signoff; |
| 41 | int allow_ff; |
| 42 | int allow_rerere_auto; |
Neil Horman | df478b7 | 2012-04-11 16:21:53 -0400 | [diff] [blame] | 43 | int allow_empty; |
Chris Webb | 4bee958 | 2012-08-02 11:38:51 +0100 | [diff] [blame] | 44 | int allow_empty_message; |
Elijah Newren | e98c426 | 2020-02-15 21:36:25 +0000 | [diff] [blame] | 45 | int drop_redundant_commits; |
Neil Horman | b27cfb0 | 2012-04-20 10:36:15 -0400 | [diff] [blame] | 46 | int keep_redundant_commits; |
Johannes Schindelin | 556907f | 2017-01-02 16:26:53 +0100 | [diff] [blame] | 47 | int verbose; |
Elijah Newren | 899b49c | 2018-12-11 08:11:36 -0800 | [diff] [blame] | 48 | int quiet; |
Johannes Schindelin | d421afa | 2018-12-10 11:04:58 -0800 | [diff] [blame] | 49 | int reschedule_failed_exec; |
Phillip Wood | 7573cec | 2020-08-17 18:40:02 +0100 | [diff] [blame] | 50 | int committer_date_is_author_date; |
Phillip Wood | a3894aa | 2020-08-17 18:40:03 +0100 | [diff] [blame] | 51 | int ignore_date; |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 52 | |
| 53 | int mainline; |
| 54 | |
Johannes Schindelin | 03a4e26 | 2016-10-21 14:24:13 +0200 | [diff] [blame] | 55 | char *gpg_sign; |
Phillip Wood | 28d6dae | 2017-12-13 11:46:21 +0000 | [diff] [blame] | 56 | enum commit_msg_cleanup_mode default_msg_cleanup; |
Phillip Wood | d74f3e5 | 2019-03-29 11:08:42 +0000 | [diff] [blame] | 57 | int explicit_cleanup; |
Nicolas Vigier | 3253553 | 2014-01-24 00:50:58 +0000 | [diff] [blame] | 58 | |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 59 | /* Merge strategy */ |
Elijah Newren | 14c4586 | 2020-11-02 23:45:34 +0000 | [diff] [blame] | 60 | char *default_strategy; /* from config options */ |
Johannes Schindelin | 03a4e26 | 2016-10-21 14:24:13 +0200 | [diff] [blame] | 61 | char *strategy; |
| 62 | char **xopts; |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 63 | size_t xopts_nr, xopts_alloc; |
| 64 | |
Johannes Schindelin | e12a7ef | 2018-04-27 22:48:21 +0200 | [diff] [blame] | 65 | /* Used by fixup/squash */ |
| 66 | struct strbuf current_fixups; |
| 67 | int current_fixup_count; |
| 68 | |
Johannes Schindelin | d87d48b | 2018-05-04 01:01:17 +0200 | [diff] [blame] | 69 | /* placeholder commit for -i --root */ |
| 70 | struct object_id squash_onto; |
| 71 | int have_squash_onto; |
| 72 | |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 73 | /* Only used by REPLAY_NONE */ |
| 74 | struct rev_info *revs; |
| 75 | }; |
Elijah Newren | 39edfd5 | 2021-03-31 06:52:20 +0000 | [diff] [blame] | 76 | #define REPLAY_OPTS_INIT { .edit = -1, .action = -1, .current_fixups = STRBUF_INIT } |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 77 | |
Alban Gruin | 5d94d54 | 2018-12-29 17:03:59 +0100 | [diff] [blame] | 78 | /* |
| 79 | * Note that ordering matters in this enum. Not only must it match the mapping |
| 80 | * of todo_command_info (in sequencer.c), it is also divided into several |
| 81 | * sections that matter. When adding new commands, make sure you add it in the |
| 82 | * right section. |
| 83 | */ |
| 84 | enum todo_command { |
| 85 | /* commands that handle commits */ |
| 86 | TODO_PICK = 0, |
| 87 | TODO_REVERT, |
| 88 | TODO_EDIT, |
| 89 | TODO_REWORD, |
| 90 | TODO_FIXUP, |
| 91 | TODO_SQUASH, |
| 92 | /* commands that do something else than handling a single commit */ |
| 93 | TODO_EXEC, |
| 94 | TODO_BREAK, |
| 95 | TODO_LABEL, |
| 96 | TODO_RESET, |
| 97 | TODO_MERGE, |
| 98 | /* commands that do nothing but are counted for reporting progress */ |
| 99 | TODO_NOOP, |
| 100 | TODO_DROP, |
| 101 | /* comments (not counted for reporting progress) */ |
| 102 | TODO_COMMENT |
Alban Gruin | 44b776c | 2018-08-10 18:51:28 +0200 | [diff] [blame] | 103 | }; |
| 104 | |
Alban Gruin | 5d94d54 | 2018-12-29 17:03:59 +0100 | [diff] [blame] | 105 | struct todo_item { |
| 106 | enum todo_command command; |
| 107 | struct commit *commit; |
| 108 | unsigned int flags; |
Alban Gruin | 5d94d54 | 2018-12-29 17:03:59 +0100 | [diff] [blame] | 109 | int arg_len; |
Alban Gruin | 6ad656d | 2019-01-29 16:01:46 +0100 | [diff] [blame] | 110 | /* The offset of the command and its argument in the strbuf */ |
| 111 | size_t offset_in_buf, arg_offset; |
Alban Gruin | 5d94d54 | 2018-12-29 17:03:59 +0100 | [diff] [blame] | 112 | }; |
| 113 | |
| 114 | struct todo_list { |
| 115 | struct strbuf buf; |
| 116 | struct todo_item *items; |
| 117 | int nr, alloc, current; |
| 118 | int done_nr, total_nr; |
| 119 | struct stat_data stat; |
| 120 | }; |
| 121 | |
| 122 | #define TODO_LIST_INIT { STRBUF_INIT } |
| 123 | |
| 124 | int todo_list_parse_insn_buffer(struct repository *r, char *buf, |
| 125 | struct todo_list *todo_list); |
Alban Gruin | 616d774 | 2019-01-29 16:01:48 +0100 | [diff] [blame] | 126 | int todo_list_write_to_file(struct repository *r, struct todo_list *todo_list, |
| 127 | const char *file, const char *shortrevisions, |
| 128 | const char *shortonto, int num, unsigned flags); |
Alban Gruin | 5d94d54 | 2018-12-29 17:03:59 +0100 | [diff] [blame] | 129 | void todo_list_release(struct todo_list *todo_list); |
Alban Gruin | 6ad656d | 2019-01-29 16:01:46 +0100 | [diff] [blame] | 130 | const char *todo_item_get_arg(struct todo_list *todo_list, |
| 131 | struct todo_item *item); |
Alban Gruin | 44b776c | 2018-08-10 18:51:28 +0200 | [diff] [blame] | 132 | |
Phillip Wood | 28d6dae | 2017-12-13 11:46:21 +0000 | [diff] [blame] | 133 | /* Call this to setup defaults before parsing command line options */ |
| 134 | void sequencer_init_config(struct replay_opts *opts); |
Nguyễn Thái Ngọc Duy | f11c958 | 2018-11-10 06:48:56 +0100 | [diff] [blame] | 135 | int sequencer_pick_revisions(struct repository *repo, |
| 136 | struct replay_opts *opts); |
| 137 | int sequencer_continue(struct repository *repo, struct replay_opts *opts); |
Nguyễn Thái Ngọc Duy | 005af33 | 2018-11-10 06:48:57 +0100 | [diff] [blame] | 138 | int sequencer_rollback(struct repository *repo, struct replay_opts *opts); |
Rohit Ashiwal | de81ca3 | 2019-07-02 14:41:28 +0530 | [diff] [blame] | 139 | int sequencer_skip(struct repository *repo, struct replay_opts *opts); |
Johannes Schindelin | 2863584 | 2016-10-21 14:24:55 +0200 | [diff] [blame] | 140 | int sequencer_remove_state(struct replay_opts *opts); |
Ramkumar Ramachandra | 043a449 | 2012-01-11 23:45:57 +0530 | [diff] [blame] | 141 | |
Elijah Newren | b9cbd29 | 2020-04-11 02:44:25 +0000 | [diff] [blame] | 142 | #define TODO_LIST_KEEP_EMPTY (1U << 0) |
Liam Beguin | 313a48e | 2017-12-05 12:52:32 -0500 | [diff] [blame] | 143 | #define TODO_LIST_SHORTEN_IDS (1U << 1) |
Liam Beguin | d8ae6c8 | 2017-12-05 12:52:34 -0500 | [diff] [blame] | 144 | #define TODO_LIST_ABBREVIATE_CMDS (1U << 2) |
Johannes Schindelin | 1644c73 | 2018-04-25 14:29:03 +0200 | [diff] [blame] | 145 | #define TODO_LIST_REBASE_MERGES (1U << 3) |
Johannes Schindelin | 7543f6f | 2018-04-25 14:29:40 +0200 | [diff] [blame] | 146 | /* |
| 147 | * When rebasing merges, commits that do have the base commit as ancestor |
| 148 | * ("cousins") are *not* rebased onto the new base by default. If those |
| 149 | * commits should be rebased onto the new base, this flag needs to be passed. |
| 150 | */ |
| 151 | #define TODO_LIST_REBASE_COUSINS (1U << 4) |
Alban Gruin | 616d774 | 2019-01-29 16:01:48 +0100 | [diff] [blame] | 152 | #define TODO_LIST_APPEND_TODO_HELP (1U << 5) |
Johannes Schindelin | e1fac53 | 2019-07-31 08:18:49 -0700 | [diff] [blame] | 153 | /* |
| 154 | * When generating a script that rebases merges with `--root` *and* with |
| 155 | * `--onto`, we do not want to re-generate the root commits. |
| 156 | */ |
| 157 | #define TODO_LIST_ROOT_WITH_ONTO (1U << 6) |
Jonathan Tan | 0fcb4f6 | 2020-04-11 02:44:27 +0000 | [diff] [blame] | 158 | #define TODO_LIST_REAPPLY_CHERRY_PICKS (1U << 7) |
Johannes Schindelin | 62db524 | 2017-07-14 16:44:58 +0200 | [diff] [blame] | 159 | |
Alban Gruin | d358fc2 | 2019-03-05 20:17:56 +0100 | [diff] [blame] | 160 | int sequencer_make_script(struct repository *r, struct strbuf *out, int argc, |
| 161 | const char **argv, unsigned flags); |
Brandon Casey | bab4d10 | 2013-02-12 02:17:35 -0800 | [diff] [blame] | 162 | |
Alban Gruin | 1ba204d | 2019-03-05 20:17:58 +0100 | [diff] [blame] | 163 | void todo_list_add_exec_commands(struct todo_list *todo_list, |
| 164 | struct string_list *commands); |
Nguyễn Thái Ngọc Duy | 005af33 | 2018-11-10 06:48:57 +0100 | [diff] [blame] | 165 | int complete_action(struct repository *r, struct replay_opts *opts, unsigned flags, |
Alban Gruin | b97e187 | 2018-08-28 14:10:36 +0200 | [diff] [blame] | 166 | const char *shortrevisions, const char *onto_name, |
Phillip Wood | f3e27a0 | 2020-11-04 15:29:38 +0000 | [diff] [blame] | 167 | struct commit *onto, const struct object_id *orig_head, |
| 168 | struct string_list *commands, unsigned autosquash, |
| 169 | struct todo_list *todo_list); |
Alban Gruin | 79d7e88 | 2019-03-05 20:17:59 +0100 | [diff] [blame] | 170 | int todo_list_rearrange_squash(struct todo_list *todo_list); |
Johannes Schindelin | 3546c8d | 2017-07-14 16:45:11 +0200 | [diff] [blame] | 171 | |
Jeff King | 66e83d9 | 2018-08-22 20:50:51 -0400 | [diff] [blame] | 172 | /* |
| 173 | * Append a signoff to the commit message in "msgbuf". The ignore_footer |
| 174 | * parameter specifies the number of bytes at the end of msgbuf that should |
| 175 | * not be considered at all. I.e., they are not checked for existing trailers, |
| 176 | * and the new signoff will be spliced into the buffer before those bytes. |
| 177 | */ |
| 178 | void append_signoff(struct strbuf *msgbuf, size_t ignore_footer, unsigned flag); |
| 179 | |
Denton Liu | 1a2b985 | 2019-04-17 11:23:30 +0100 | [diff] [blame] | 180 | void append_conflicts_hint(struct index_state *istate, |
| 181 | struct strbuf *msgbuf, enum commit_msg_cleanup_mode cleanup_mode); |
Denton Liu | f29cd86 | 2019-04-17 11:23:25 +0100 | [diff] [blame] | 182 | enum commit_msg_cleanup_mode get_cleanup_mode(const char *cleanup_arg, |
| 183 | int use_editor); |
| 184 | |
| 185 | void cleanup_message(struct strbuf *msgbuf, |
| 186 | enum commit_msg_cleanup_mode cleanup_mode, int verbose); |
| 187 | |
Phillip Wood | d0aaa46 | 2017-11-10 11:09:42 +0000 | [diff] [blame] | 188 | int message_is_empty(const struct strbuf *sb, |
| 189 | enum commit_msg_cleanup_mode cleanup_mode); |
| 190 | int template_untouched(const struct strbuf *sb, const char *template_file, |
| 191 | enum commit_msg_cleanup_mode cleanup_mode); |
Phillip Wood | 0505d60 | 2017-11-17 11:34:47 +0000 | [diff] [blame] | 192 | int update_head_with_reflog(const struct commit *old_head, |
| 193 | const struct object_id *new_head, |
| 194 | const char *action, const struct strbuf *msg, |
| 195 | struct strbuf *err); |
Nguyễn Thái Ngọc Duy | 1d18d75 | 2019-01-12 09:13:23 +0700 | [diff] [blame] | 196 | void commit_post_rewrite(struct repository *r, |
| 197 | const struct commit *current_head, |
Phillip Wood | a87a6f3 | 2017-11-17 11:34:48 +0000 | [diff] [blame] | 198 | const struct object_id *new_head); |
Miklos Vajna | 5ed75e2 | 2012-09-14 08:52:03 +0200 | [diff] [blame] | 199 | |
Denton Liu | 0816f1d | 2020-04-07 10:28:03 -0400 | [diff] [blame] | 200 | void create_autostash(struct repository *r, const char *path, |
| 201 | const char *default_reflog_action); |
Denton Liu | 12b6e13 | 2020-04-07 10:28:05 -0400 | [diff] [blame] | 202 | int save_autostash(const char *path); |
Denton Liu | 86ed00a | 2020-04-07 10:27:58 -0400 | [diff] [blame] | 203 | int apply_autostash(const char *path); |
Denton Liu | 804fe31 | 2020-04-07 10:28:06 -0400 | [diff] [blame] | 204 | int apply_autostash_oid(const char *stash_oid); |
Denton Liu | 86ed00a | 2020-04-07 10:27:58 -0400 | [diff] [blame] | 205 | |
Phillip Wood | e47c6ca | 2017-11-24 11:07:54 +0000 | [diff] [blame] | 206 | #define SUMMARY_INITIAL_COMMIT (1 << 0) |
| 207 | #define SUMMARY_SHOW_AUTHOR_DATE (1 << 1) |
Nguyễn Thái Ngọc Duy | f11c958 | 2018-11-10 06:48:56 +0100 | [diff] [blame] | 208 | void print_commit_summary(struct repository *repo, |
| 209 | const char *prefix, |
| 210 | const struct object_id *oid, |
Phillip Wood | e47c6ca | 2017-11-24 11:07:54 +0000 | [diff] [blame] | 211 | unsigned int flags); |
Phillip Wood | bcd33ec | 2018-10-31 10:15:55 +0000 | [diff] [blame] | 212 | |
Denton Liu | c20de8b | 2020-04-07 10:27:54 -0400 | [diff] [blame] | 213 | #define READ_ONELINER_SKIP_IF_EMPTY (1 << 0) |
| 214 | #define READ_ONELINER_WARN_MISSING (1 << 1) |
| 215 | |
| 216 | /* |
| 217 | * Reads a file that was presumably written by a shell script, i.e. with an |
| 218 | * end-of-line marker that needs to be stripped. |
| 219 | * |
| 220 | * Note that only the last end-of-line marker is stripped, consistent with the |
| 221 | * behavior of "$(cat path)" in a shell script. |
| 222 | * |
| 223 | * Returns 1 if the file was read, 0 if it could not be read or does not exist. |
| 224 | */ |
| 225 | int read_oneliner(struct strbuf *buf, |
| 226 | const char *path, unsigned flags); |
Phillip Wood | bcd33ec | 2018-10-31 10:15:55 +0000 | [diff] [blame] | 227 | int read_author_script(const char *path, char **name, char **email, char **date, |
| 228 | int allow_missing); |
Alban Gruin | 6585068 | 2018-08-28 14:10:40 +0200 | [diff] [blame] | 229 | void parse_strategy_opts(struct replay_opts *opts, char *raw_opts); |
| 230 | int write_basic_state(struct replay_opts *opts, const char *head_name, |
Phillip Wood | a2bb10d | 2020-11-04 15:29:39 +0000 | [diff] [blame] | 231 | struct commit *onto, const struct object_id *orig_head); |
Junio C Hamano | f496b06 | 2019-07-09 15:25:44 -0700 | [diff] [blame] | 232 | void sequencer_post_commit_cleanup(struct repository *r, int verbose); |
Phillip Wood | 4a72486 | 2019-04-16 11:18:42 +0100 | [diff] [blame] | 233 | int sequencer_get_last_command(struct repository* r, |
| 234 | enum replay_action *action); |
Phillip Wood | 901ba7b | 2019-12-06 16:06:11 +0000 | [diff] [blame] | 235 | int sequencer_determine_whence(struct repository *r, enum commit_whence *whence); |
Phillip Wood | 12bb7a5 | 2019-10-15 10:25:30 +0000 | [diff] [blame] | 236 | #endif /* SEQUENCER_H */ |