| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 1 | #ifndef REVISION_H |
| 2 | #define REVISION_H |
| 3 | |
| Elijah Newren | ef3ca95 | 2018-08-15 17:54:05 | [diff] [blame] | 4 | #include "commit.h" |
| Pierre Habouzit | 6b61ec0 | 2008-07-09 21:38:34 | [diff] [blame] | 5 | #include "parse-options.h" |
| Jeff King | 0843acf | 2008-08-25 06:15:05 | [diff] [blame] | 6 | #include "grep.h" |
| Thomas Rast | 894a9d3 | 2010-03-12 17:04:26 | [diff] [blame] | 7 | #include "notes.h" |
| Olga Telezhnaya | cf39471 | 2017-12-12 08:55:35 | [diff] [blame] | 8 | #include "pretty.h" |
| Felipe Contreras | 19ecb56 | 2013-10-31 09:25:36 | [diff] [blame] | 9 | #include "diff.h" |
| Nguyễn Thái Ngọc Duy | 87be252 | 2018-05-19 05:28:24 | [diff] [blame] | 10 | #include "commit-slab-decl.h" |
| Pierre Habouzit | 6b61ec0 | 2008-07-09 21:38:34 | [diff] [blame] | 11 | |
| Heba Waly | 301d595 | 2019-11-17 21:04:48 | [diff] [blame] | 12 | /** |
| 13 | * The revision walking API offers functions to build a list of revisions |
| 14 | * and then iterate over that list. |
| 15 | * |
| 16 | * Calling sequence |
| 17 | * ---------------- |
| 18 | * |
| 19 | * The walking API has a given calling sequence: first you need to initialize |
| 20 | * a rev_info structure, then add revisions to control what kind of revision |
| 21 | * list do you want to get, finally you can iterate over the revision list. |
| 22 | * |
| 23 | */ |
| 24 | |
| Nguyễn Thái Ngọc Duy | 208acbf | 2014-03-25 13:23:26 | [diff] [blame] | 25 | /* Remember to update object flag allocation in object.h */ |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 26 | #define SEEN (1u<<0) |
| 27 | #define UNINTERESTING (1u<<1) |
| Linus Torvalds | 7dc0fe3 | 2007-11-13 07:16:08 | [diff] [blame] | 28 | #define TREESAME (1u<<2) |
| Linus Torvalds | 765ac8e | 2006-02-28 23:07:20 | [diff] [blame] | 29 | #define SHOWN (1u<<3) |
| Junio C Hamano | 7ae0b0c | 2006-03-01 08:58:56 | [diff] [blame] | 30 | #define TMP_MARK (1u<<4) /* for isolated cases; clean after use */ |
| Junio C Hamano | 384e99a | 2006-03-28 07:58:34 | [diff] [blame] | 31 | #define BOUNDARY (1u<<5) |
| Junio C Hamano | 2b06469 | 2007-03-06 00:10:28 | [diff] [blame] | 32 | #define CHILD_SHOWN (1u<<6) |
| Junio C Hamano | 1b65a5a | 2006-04-17 01:12:49 | [diff] [blame] | 33 | #define ADDED (1u<<7) /* Parents already parsed and added? */ |
| Junio C Hamano | 577ed5c | 2006-10-23 00:32:47 | [diff] [blame] | 34 | #define SYMMETRIC_LEFT (1u<<8) |
| Michael J Gruber | adbbb31 | 2011-03-07 12:31:40 | [diff] [blame] | 35 | #define PATCHSAME (1u<<9) |
| Kevin Bracey | 7f34a46 | 2013-05-16 15:32:38 | [diff] [blame] | 36 | #define BOTTOM (1u<<10) |
| Derrick Stolee | 8d049e1 | 2020-04-10 12:19:43 | [diff] [blame] | 37 | |
| 38 | /* WARNING: This is also used as REACHABLE in commit-graph.c. */ |
| 39 | #define PULL_MERGE (1u<<15) |
| René Scharfe | 23c4319 | 2020-06-24 13:05:38 | [diff] [blame] | 40 | |
| 41 | #define TOPO_WALK_EXPLORED (1u<<23) |
| 42 | #define TOPO_WALK_INDEGREE (1u<<24) |
| 43 | |
| Matthew DeVore | 99c9aa9 | 2018-10-05 21:31:24 | [diff] [blame] | 44 | /* |
| 45 | * Indicates object was reached by traversal. i.e. not given by user on |
| 46 | * command-line or stdin. |
| 47 | * NEEDSWORK: NOT_USER_GIVEN doesn't apply to commits because we only support |
| 48 | * filtering trees and blobs, but it may be useful to support filtering commits |
| 49 | * in the future. |
| 50 | */ |
| 51 | #define NOT_USER_GIVEN (1u<<25) |
| Nguyễn Thái Ngọc Duy | 1b32dec | 2014-03-25 13:23:27 | [diff] [blame] | 52 | #define TRACK_LINEAR (1u<<26) |
| Derrick Stolee | 8d049e1 | 2020-04-10 12:19:43 | [diff] [blame] | 53 | #define ALL_REV_FLAGS (((1u<<11)-1) | NOT_USER_GIVEN | TRACK_LINEAR | PULL_MERGE) |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 54 | |
| Lars Hjemli | 33e7018 | 2009-08-15 14:23:12 | [diff] [blame] | 55 | #define DECORATE_SHORT_REFS 1 |
| 56 | #define DECORATE_FULL_REFS 2 |
| 57 | |
| Linus Torvalds | 9153983 | 2006-04-17 18:59:32 | [diff] [blame] | 58 | struct log_info; |
| Nguyễn Thái Ngọc Duy | 2abf350 | 2018-09-21 15:57:38 | [diff] [blame] | 59 | struct repository; |
| 60 | struct rev_info; |
| Thomas Rast | 894a9d3 | 2010-03-12 17:04:26 | [diff] [blame] | 61 | struct string_list; |
| Thomas Rast | 53d00b3 | 2013-07-31 20:13:20 | [diff] [blame] | 62 | struct saved_parents; |
| Garima Singh | a56b946 | 2020-04-06 16:59:52 | [diff] [blame] | 63 | struct bloom_key; |
| 64 | struct bloom_filter_settings; |
| Nguyễn Thái Ngọc Duy | 87be252 | 2018-05-19 05:28:24 | [diff] [blame] | 65 | define_shared_commit_slab(revision_sources, char *); |
| Fredrik Kuivinen | 8efdc32 | 2006-03-10 09:21:39 | [diff] [blame] | 66 | |
| Junio C Hamano | 281eee4 | 2011-08-26 00:35:39 | [diff] [blame] | 67 | struct rev_cmdline_info { |
| 68 | unsigned int nr; |
| 69 | unsigned int alloc; |
| 70 | struct rev_cmdline_entry { |
| 71 | struct object *item; |
| 72 | const char *name; |
| 73 | enum { |
| 74 | REV_CMD_REF, |
| 75 | REV_CMD_PARENTS_ONLY, |
| 76 | REV_CMD_LEFT, |
| 77 | REV_CMD_RIGHT, |
| Kevin Bracey | a765499 | 2013-05-13 15:00:47 | [diff] [blame] | 78 | REV_CMD_MERGE_BASE, |
| Junio C Hamano | 281eee4 | 2011-08-26 00:35:39 | [diff] [blame] | 79 | REV_CMD_REV |
| 80 | } whence; |
| 81 | unsigned flags; |
| 82 | } *rev; |
| 83 | }; |
| 84 | |
| Martin von Zweigbergk | ca92e59 | 2012-08-29 06:15:54 | [diff] [blame] | 85 | #define REVISION_WALK_WALK 0 |
| 86 | #define REVISION_WALK_NO_WALK_SORTED 1 |
| 87 | #define REVISION_WALK_NO_WALK_UNSORTED 2 |
| 88 | |
| Derrick Stolee | f1f5de4 | 2019-01-16 18:25:58 | [diff] [blame] | 89 | struct oidset; |
| Derrick Stolee | f0d9cc4 | 2018-11-01 13:46:20 | [diff] [blame] | 90 | struct topo_walk_info; |
| 91 | |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 92 | struct rev_info { |
| 93 | /* Starting list */ |
| 94 | struct commit_list *commits; |
| Linus Torvalds | 1f1e895 | 2006-06-20 00:42:35 | [diff] [blame] | 95 | struct object_array pending; |
| Nguyễn Thái Ngọc Duy | 2abf350 | 2018-09-21 15:57:38 | [diff] [blame] | 96 | struct repository *repo; |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 97 | |
| Junio C Hamano | 86ab490 | 2007-03-05 21:10:06 | [diff] [blame] | 98 | /* Parents of shown commits */ |
| 99 | struct object_array boundary_commits; |
| 100 | |
| Junio C Hamano | 281eee4 | 2011-08-26 00:35:39 | [diff] [blame] | 101 | /* The end-points specified by the end user */ |
| 102 | struct rev_cmdline_info cmdline; |
| 103 | |
| Junio C Hamano | e7b432c | 2013-08-30 23:37:55 | [diff] [blame] | 104 | /* excluding from --branches, --refs, etc. expansion */ |
| 105 | struct string_list *ref_excludes; |
| 106 | |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 107 | /* Basic information */ |
| 108 | const char *prefix; |
| Pierre Habouzit | 02e5422 | 2008-07-08 13:19:33 | [diff] [blame] | 109 | const char *def; |
| Nguyễn Thái Ngọc Duy | afe069d | 2010-12-17 12:43:06 | [diff] [blame] | 110 | struct pathspec prune_data; |
| Junio C Hamano | 08f704f | 2013-06-06 23:07:14 | [diff] [blame] | 111 | |
| Jeff King | 7ba8262 | 2017-08-02 22:25:27 | [diff] [blame] | 112 | /* |
| 113 | * Whether the arguments parsed by setup_revisions() included any |
| 114 | * "input" revisions that might still have yielded an empty pending |
| 115 | * list (e.g., patterns like "--all" or "--glob"). |
| 116 | */ |
| 117 | int rev_input_given; |
| 118 | |
| Jeff King | a12cbe2 | 2018-08-22 21:37:23 | [diff] [blame] | 119 | /* |
| 120 | * Whether we read from stdin due to the --stdin option. |
| 121 | */ |
| 122 | int read_from_stdin; |
| 123 | |
| Junio C Hamano | 08f704f | 2013-06-06 23:07:14 | [diff] [blame] | 124 | /* topo-sort */ |
| 125 | enum rev_sort_order sort_order; |
| 126 | |
| SZEDER Gábor | e35b6ac | 2017-06-10 11:41:01 | [diff] [blame] | 127 | unsigned int early_output; |
| 128 | |
| 129 | unsigned int ignore_missing:1, |
| Vicent Marti | 2db1a43 | 2014-03-28 10:00:43 | [diff] [blame] | 130 | ignore_missing_links:1; |
| Linus Torvalds | cdcefbc | 2007-11-03 18:11:10 | [diff] [blame] | 131 | |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 132 | /* Traversal flags */ |
| 133 | unsigned int dense:1, |
| Linus Torvalds | 53b2c82 | 2007-11-05 21:22:34 | [diff] [blame] | 134 | prune:1, |
| Martin von Zweigbergk | ca92e59 | 2012-08-29 06:15:54 | [diff] [blame] | 135 | no_walk:2, |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 136 | remove_empty_trees:1, |
| Linus Torvalds | 9202434 | 2006-06-11 17:57:35 | [diff] [blame] | 137 | simplify_history:1, |
| Derrick Stolee | 8d049e1 | 2020-04-10 12:19:43 | [diff] [blame] | 138 | show_pulls:1, |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 139 | topo_order:1, |
| Junio C Hamano | 6546b59 | 2008-07-31 08:17:41 | [diff] [blame] | 140 | simplify_merges:1, |
| Linus Torvalds | 78892e3 | 2008-11-03 19:25:46 | [diff] [blame] | 141 | simplify_by_decoration:1, |
| Nguyễn Thái Ngọc Duy | ff9445b | 2017-08-23 12:36:49 | [diff] [blame] | 142 | single_worktree:1, |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 143 | tag_objects:1, |
| 144 | tree_objects:1, |
| 145 | blob_objects:1, |
| Junio C Hamano | 5a48d24 | 2011-09-01 22:43:34 | [diff] [blame] | 146 | verify_objects:1, |
| Linus Torvalds | d9a8368 | 2006-02-27 16:54:36 | [diff] [blame] | 147 | edge_hint:1, |
| brian m. carlson | 1684c1b | 2014-12-24 23:05:39 | [diff] [blame] | 148 | edge_hint_aggressive:1, |
| Linus Torvalds | d9a8368 | 2006-02-27 16:54:36 | [diff] [blame] | 149 | limited:1, |
| Junio C Hamano | 03a9683 | 2009-02-28 08:00:21 | [diff] [blame] | 150 | unpacked:1, |
| Junio C Hamano | 86ab490 | 2007-03-05 21:10:06 | [diff] [blame] | 151 | boundary:2, |
| Thomas Rast | f69c501 | 2010-06-10 11:47:23 | [diff] [blame] | 152 | count:1, |
| Junio C Hamano | 74bd902 | 2006-12-16 23:31:25 | [diff] [blame] | 153 | left_right:1, |
| Michael J Gruber | 60adf7d | 2011-02-21 16:09:11 | [diff] [blame] | 154 | left_only:1, |
| 155 | right_only:1, |
| Adam Simpkins | 885cf80 | 2008-05-04 10:36:52 | [diff] [blame] | 156 | rewrite_parents:1, |
| 157 | print_parents:1, |
| Linus Torvalds | d467a52 | 2008-11-03 19:23:57 | [diff] [blame] | 158 | show_decorations:1, |
| Junio C Hamano | 0053e90 | 2007-03-13 08:57:22 | [diff] [blame] | 159 | reverse:1, |
| Thomas Rast | 498bcd3 | 2008-08-29 19:18:38 | [diff] [blame] | 160 | reverse_output_stage:1, |
| Junio C Hamano | d7a17ca | 2007-04-09 10:40:38 | [diff] [blame] | 161 | cherry_pick:1, |
| Michael J Gruber | adbbb31 | 2011-03-07 12:31:40 | [diff] [blame] | 162 | cherry_mark:1, |
| Linus Torvalds | ad3f9a7 | 2009-10-27 18:28:07 | [diff] [blame] | 163 | bisect:1, |
| Junio C Hamano | ebdc94f | 2010-04-20 20:48:39 | [diff] [blame] | 164 | ancestry_path:1, |
| Thomas Rast | 12da1d1 | 2013-03-28 16:47:32 | [diff] [blame] | 165 | first_parent_only:1, |
| Stefan Beller | ce5b6f9 | 2017-11-16 02:00:35 | [diff] [blame] | 166 | line_level_traverse:1, |
| Junio C Hamano | f3d618d | 2018-02-13 21:39:03 | [diff] [blame] | 167 | tree_blobs_in_commit_order:1, |
| Jonathan Tan | df11e19 | 2017-12-08 15:27:15 | [diff] [blame] | 168 | |
| Matthew DeVore | 7c0fe33 | 2018-10-05 21:31:23 | [diff] [blame] | 169 | /* |
| 170 | * Blobs are shown without regard for their existence. |
| 171 | * But not so for trees: unless exclude_promisor_objects |
| 172 | * is set and the tree in question is a promisor object; |
| 173 | * OR ignore_missing_links is set, the revision walker |
| 174 | * dies with a "bad tree object HASH" message when |
| 175 | * encountering a missing tree. For callers that can |
| 176 | * handle missing trees and want them to be filterable |
| 177 | * and showable, set this to true. The revision walker |
| 178 | * will filter and show such a missing tree as usual, |
| 179 | * but will not attempt to recurse into this tree |
| 180 | * object. |
| 181 | */ |
| 182 | do_not_die_on_missing_tree:1, |
| 183 | |
| Jonathan Tan | df11e19 | 2017-12-08 15:27:15 | [diff] [blame] | 184 | /* for internal use only */ |
| 185 | exclude_promisor_objects:1; |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 186 | |
| Linus Torvalds | cd2bdc5 | 2006-04-14 23:52:13 | [diff] [blame] | 187 | /* Diff flags */ |
| 188 | unsigned int diff:1, |
| 189 | full_diff:1, |
| 190 | show_root_diff:1, |
| Sergey Organov | 572fc9a | 2020-08-31 20:14:22 | [diff] [blame] | 191 | match_missing:1, |
| Linus Torvalds | cd2bdc5 | 2006-04-14 23:52:13 | [diff] [blame] | 192 | no_commit_id:1, |
| 193 | verbose_header:1, |
| Linus Torvalds | cd2bdc5 | 2006-04-14 23:52:13 | [diff] [blame] | 194 | combine_merges:1, |
| Elijah Newren | d76ce4f | 2019-02-08 01:12:46 | [diff] [blame] | 195 | combined_all_paths:1, |
| Linus Torvalds | cd2bdc5 | 2006-04-14 23:52:13 | [diff] [blame] | 196 | dense_combined_merges:1, |
| 197 | always_show_header:1; |
| Jeff King | 6fae74b | 2020-07-29 20:10:20 | [diff] [blame] | 198 | int ignore_merges:2; |
| Linus Torvalds | cd2bdc5 | 2006-04-14 23:52:13 | [diff] [blame] | 199 | |
| 200 | /* Format info */ |
| Denton Liu | 1d72975 | 2019-12-12 00:49:50 | [diff] [blame] | 201 | int show_notes; |
| Linus Torvalds | 9153983 | 2006-04-17 18:59:32 | [diff] [blame] | 202 | unsigned int shown_one:1, |
| Junio C Hamano | bd1470b | 2012-10-18 04:27:22 | [diff] [blame] | 203 | shown_dashes:1, |
| Pierre Habouzit | 02e5422 | 2008-07-08 13:19:33 | [diff] [blame] | 204 | show_merge:1, |
| Junio C Hamano | 66b2ed0 | 2010-01-20 21:59:36 | [diff] [blame] | 205 | show_notes_given:1, |
| Junio C Hamano | 0c37f1f | 2011-10-18 22:53:23 | [diff] [blame] | 206 | show_signature:1, |
| Junio C Hamano | 66b2ed0 | 2010-01-20 21:59:36 | [diff] [blame] | 207 | pretty_given:1, |
| Junio C Hamano | 4da45be | 2008-04-08 00:11:34 | [diff] [blame] | 208 | abbrev_commit:1, |
| Jay Soffian | 0c47695 | 2011-05-18 17:56:04 | [diff] [blame] | 209 | abbrev_commit_given:1, |
| brian m. carlson | 3a30aa1 | 2015-12-15 01:52:04 | [diff] [blame] | 210 | zero_commit:1, |
| Adam Simpkins | 7fefda5 | 2008-05-04 10:36:54 | [diff] [blame] | 211 | use_terminator:1, |
| Jeff King | f4ea32f | 2009-09-24 08:28:15 | [diff] [blame] | 212 | missing_newline:1, |
| Jeff King | 9553d2b | 2011-05-26 22:28:17 | [diff] [blame] | 213 | date_mode_explicit:1, |
| Emma Brooks | 19d097e | 2020-04-08 04:31:38 | [diff] [blame] | 214 | preserve_subject:1, |
| 215 | encode_email_headers:1; |
| Junio C Hamano | 8b3dce5 | 2009-11-03 14:59:18 | [diff] [blame] | 216 | unsigned int disable_stdin:1; |
| Nguyễn Thái Ngọc Duy | 1b32dec | 2014-03-25 13:23:27 | [diff] [blame] | 217 | /* --show-linear-break */ |
| 218 | unsigned int track_linear:1, |
| 219 | track_first_time:1, |
| 220 | linear:1; |
| Junio C Hamano | 8b3dce5 | 2009-11-03 14:59:18 | [diff] [blame] | 221 | |
| Jeff King | a5481a6 | 2015-06-25 16:55:02 | [diff] [blame] | 222 | struct date_mode date_mode; |
| Junio C Hamano | 0893eec | 2016-03-29 22:49:24 | [diff] [blame] | 223 | int expand_tabs_in_log; /* unset if negative */ |
| 224 | int expand_tabs_in_log_default; |
| Junio C Hamano | 106d710 | 2006-09-06 09:12:09 | [diff] [blame] | 225 | |
| Linus Torvalds | cd2bdc5 | 2006-04-14 23:52:13 | [diff] [blame] | 226 | unsigned int abbrev; |
| 227 | enum cmit_fmt commit_format; |
| Linus Torvalds | 9153983 | 2006-04-17 18:59:32 | [diff] [blame] | 228 | struct log_info *loginfo; |
| Johannes Schindelin | 596524b | 2006-05-05 02:30:52 | [diff] [blame] | 229 | int nr, total; |
| Johannes Schindelin | 698ce6f | 2006-05-20 13:40:29 | [diff] [blame] | 230 | const char *mime_boundary; |
| Stephen Boyd | 108dab2 | 2009-03-23 02:14:05 | [diff] [blame] | 231 | const char *patch_suffix; |
| 232 | int numbered_files; |
| Junio C Hamano | 5fe10fe | 2012-12-22 08:21:23 | [diff] [blame] | 233 | int reroll_count; |
| Daniel Barkalow | e1a3734 | 2008-02-19 03:56:06 | [diff] [blame] | 234 | char *message_id; |
| Jeff King | a908047 | 2013-07-03 07:08:22 | [diff] [blame] | 235 | struct ident_split from_ident; |
| Thomas Rast | b079c50 | 2009-02-19 21:26:31 | [diff] [blame] | 236 | struct string_list *ref_message_ids; |
| Nguyễn Thái Ngọc Duy | 5289c56 | 2013-02-12 10:17:38 | [diff] [blame] | 237 | int add_signoff; |
| Johannes Schindelin | 20ff068 | 2006-06-02 13:21:17 | [diff] [blame] | 238 | const char *extra_headers; |
| Junio C Hamano | 52883fb | 2006-12-25 19:48:35 | [diff] [blame] | 239 | const char *log_reencode; |
| Robin H. Johnson | 2d9e4a4 | 2007-04-11 23:58:07 | [diff] [blame] | 240 | const char *subject_prefix; |
| Johannes Schindelin | c112f68 | 2007-03-03 23:12:06 | [diff] [blame] | 241 | int no_inline; |
| Marco Costalba | 9fa3465 | 2007-07-20 18:15:13 | [diff] [blame] | 242 | int show_log_size; |
| Antoine Pelisse | 0e2913b | 2013-01-05 21:26:41 | [diff] [blame] | 243 | struct string_list *mailmap; |
| Linus Torvalds | cd2bdc5 | 2006-04-14 23:52:13 | [diff] [blame] | 244 | |
| Junio C Hamano | 8ecae9b | 2006-09-17 22:43:40 | [diff] [blame] | 245 | /* Filter by commit log message */ |
| Jeff King | 0843acf | 2008-08-25 06:15:05 | [diff] [blame] | 246 | struct grep_opt grep_filter; |
| Christoph Junghans | 22dfa8a | 2015-01-13 01:33:32 | [diff] [blame] | 247 | /* Negate the match of grep_filter */ |
| 248 | int invert_grep; |
| Junio C Hamano | 8ecae9b | 2006-09-17 22:43:40 | [diff] [blame] | 249 | |
| Adam Simpkins | 7fefda5 | 2008-05-04 10:36:54 | [diff] [blame] | 250 | /* Display history graph */ |
| 251 | struct git_graph *graph; |
| 252 | |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 253 | /* special limits */ |
| Junio C Hamano | d5db6c9 | 2006-12-20 02:25:32 | [diff] [blame] | 254 | int skip_count; |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 255 | int max_count; |
| Johannes Schindelin | dddbad7 | 2017-04-26 19:29:31 | [diff] [blame] | 256 | timestamp_t max_age; |
| 257 | timestamp_t min_age; |
| Michael J Gruber | ad5aeed | 2011-03-21 10:14:06 | [diff] [blame] | 258 | int min_parents; |
| 259 | int max_parents; |
| Vicent Marti | a330de3 | 2013-10-24 18:01:41 | [diff] [blame] | 260 | int (*include_check)(struct commit *, void *); |
| 261 | void *include_check_data; |
| Fredrik Kuivinen | 8efdc32 | 2006-03-10 09:21:39 | [diff] [blame] | 262 | |
| Linus Torvalds | cd2bdc5 | 2006-04-14 23:52:13 | [diff] [blame] | 263 | /* diff info for patches and for paths limiting */ |
| Junio C Hamano | c4e05b1 | 2006-04-11 01:14:54 | [diff] [blame] | 264 | struct diff_options diffopt; |
| Linus Torvalds | cd2bdc5 | 2006-04-14 23:52:13 | [diff] [blame] | 265 | struct diff_options pruning; |
| Junio C Hamano | c4e05b1 | 2006-04-11 01:14:54 | [diff] [blame] | 266 | |
| Johannes Schindelin | 8860fd4 | 2007-01-11 10:47:48 | [diff] [blame] | 267 | struct reflog_walk_info *reflog_info; |
| Junio C Hamano | f35f560 | 2008-04-03 09:12:06 | [diff] [blame] | 268 | struct decoration children; |
| Junio C Hamano | faf0156 | 2008-08-14 17:59:44 | [diff] [blame] | 269 | struct decoration merge_simplification; |
| Kevin Bracey | d0af663 | 2013-05-16 15:32:34 | [diff] [blame] | 270 | struct decoration treesame; |
| Thomas Rast | 894a9d3 | 2010-03-12 17:04:26 | [diff] [blame] | 271 | |
| 272 | /* notes-specific options: which refs to show */ |
| 273 | struct display_notes_opt notes_opt; |
| Thomas Rast | f69c501 | 2010-06-10 11:47:23 | [diff] [blame] | 274 | |
| Eric Sunshine | 126facf | 2018-07-22 09:57:05 | [diff] [blame] | 275 | /* interdiff */ |
| 276 | const struct object_id *idiff_oid1; |
| 277 | const struct object_id *idiff_oid2; |
| Eric Sunshine | 5ac290f | 2018-07-22 09:57:06 | [diff] [blame] | 278 | const char *idiff_title; |
| Eric Sunshine | 126facf | 2018-07-22 09:57:05 | [diff] [blame] | 279 | |
| Eric Sunshine | 31e2617 | 2018-07-22 09:57:13 | [diff] [blame] | 280 | /* range-diff */ |
| 281 | const char *rdiff1; |
| 282 | const char *rdiff2; |
| 283 | int creation_factor; |
| Eric Sunshine | 4ee9968 | 2018-07-22 09:57:15 | [diff] [blame] | 284 | const char *rdiff_title; |
| Eric Sunshine | 31e2617 | 2018-07-22 09:57:13 | [diff] [blame] | 285 | |
| Thomas Rast | f69c501 | 2010-06-10 11:47:23 | [diff] [blame] | 286 | /* commit counts */ |
| 287 | int count_left; |
| 288 | int count_right; |
| Michael J Gruber | b388e14 | 2011-04-26 08:24:29 | [diff] [blame] | 289 | int count_same; |
| Thomas Rast | 12da1d1 | 2013-03-28 16:47:32 | [diff] [blame] | 290 | |
| 291 | /* line level range that we are chasing */ |
| 292 | struct decoration line_log_data; |
| Thomas Rast | 53d00b3 | 2013-07-31 20:13:20 | [diff] [blame] | 293 | |
| 294 | /* copies of the parent lists, for --full-diff display */ |
| 295 | struct saved_parents *saved_parents_slab; |
| Nguyễn Thái Ngọc Duy | 1b32dec | 2014-03-25 13:23:27 | [diff] [blame] | 296 | |
| 297 | struct commit_list *previous_parents; |
| 298 | const char *break_bar; |
| Nguyễn Thái Ngọc Duy | 87be252 | 2018-05-19 05:28:24 | [diff] [blame] | 299 | |
| 300 | struct revision_sources *sources; |
| Derrick Stolee | f0d9cc4 | 2018-11-01 13:46:20 | [diff] [blame] | 301 | |
| 302 | struct topo_walk_info *topo_walk_info; |
| Garima Singh | a56b946 | 2020-04-06 16:59:52 | [diff] [blame] | 303 | |
| 304 | /* Commit graph bloom filter fields */ |
| SZEDER Gábor | c525ce9 | 2020-07-01 13:27:30 | [diff] [blame] | 305 | /* The bloom filter key(s) for the pathspec */ |
| 306 | struct bloom_key *bloom_keys; |
| 307 | int bloom_keys_nr; |
| 308 | |
| Garima Singh | a56b946 | 2020-04-06 16:59:52 | [diff] [blame] | 309 | /* |
| 310 | * The bloom filter settings used to generate the key. |
| 311 | * This is loaded from the commit-graph being used. |
| 312 | */ |
| 313 | struct bloom_filter_settings *bloom_filter_settings; |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 314 | }; |
| 315 | |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 316 | int ref_excluded(struct string_list *, const char *path); |
| Junio C Hamano | ff32d34 | 2013-11-01 19:02:45 | [diff] [blame] | 317 | void clear_ref_exclusion(struct string_list **); |
| 318 | void add_ref_exclusion(struct string_list **, const char *exclude); |
| 319 | |
| 320 | |
| Fredrik Kuivinen | 8efdc32 | 2006-03-10 09:21:39 | [diff] [blame] | 321 | #define REV_TREE_SAME 0 |
| Linus Torvalds | ceff8e7 | 2009-06-03 01:34:01 | [diff] [blame] | 322 | #define REV_TREE_NEW 1 /* Only new files */ |
| 323 | #define REV_TREE_OLD 2 /* Only files removed */ |
| 324 | #define REV_TREE_DIFFERENT 3 /* Mixed changes */ |
| Fredrik Kuivinen | 8efdc32 | 2006-03-10 09:21:39 | [diff] [blame] | 325 | |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 326 | /* revision.c */ |
| Linus Torvalds | cdcefbc | 2007-11-03 18:11:10 | [diff] [blame] | 327 | typedef void (*show_early_output_fn_t)(struct rev_info *, struct commit_list *); |
| Brandon Casey | 4dc1db0 | 2008-08-21 00:34:30 | [diff] [blame] | 328 | extern volatile show_early_output_fn_t show_early_output; |
| Fredrik Kuivinen | 8efdc32 | 2006-03-10 09:21:39 | [diff] [blame] | 329 | |
| Junio C Hamano | 32962c9 | 2010-03-09 06:58:09 | [diff] [blame] | 330 | struct setup_revision_opt { |
| 331 | const char *def; |
| Junio C Hamano | b449005 | 2010-03-09 07:27:25 | [diff] [blame] | 332 | void (*tweak)(struct rev_info *, struct setup_revision_opt *); |
| Nguyễn Thái Ngọc Duy | 2abf350 | 2018-09-21 15:57:38 | [diff] [blame] | 333 | const char *submodule; /* TODO: drop this and use rev_info->repo */ |
| Matthew DeVore | bbcde41 | 2018-12-03 22:10:19 | [diff] [blame] | 334 | unsigned int assume_dashdash:1, |
| 335 | allow_exclude_promisor_objects:1; |
| Junio C Hamano | d5f6b1d | 2012-07-02 19:43:05 | [diff] [blame] | 336 | unsigned revarg_opt; |
| Junio C Hamano | 32962c9 | 2010-03-09 06:58:09 | [diff] [blame] | 337 | }; |
| 338 | |
| Nguyễn Thái Ngọc Duy | 2abf350 | 2018-09-21 15:57:38 | [diff] [blame] | 339 | #ifndef NO_THE_REPOSITORY_COMPATIBILITY_MACROS |
| 340 | #define init_revisions(revs, prefix) repo_init_revisions(the_repository, revs, prefix) |
| 341 | #endif |
| Heba Waly | 301d595 | 2019-11-17 21:04:48 | [diff] [blame] | 342 | |
| 343 | /** |
| 344 | * Initialize a rev_info structure with default values. The third parameter may |
| 345 | * be NULL or can be prefix path, and then the `.prefix` variable will be set |
| 346 | * to it. This is typically the first function you want to call when you want |
| 347 | * to deal with a revision list. After calling this function, you are free to |
| 348 | * customize options, like set `.ignore_merges` to 0 if you don't want to |
| 349 | * ignore merges, and so on. |
| 350 | */ |
| Nguyễn Thái Ngọc Duy | 2abf350 | 2018-09-21 15:57:38 | [diff] [blame] | 351 | void repo_init_revisions(struct repository *r, |
| 352 | struct rev_info *revs, |
| 353 | const char *prefix); |
| Heba Waly | 301d595 | 2019-11-17 21:04:48 | [diff] [blame] | 354 | |
| 355 | /** |
| 356 | * Parse revision information, filling in the `rev_info` structure, and |
| 357 | * removing the used arguments from the argument list. Returns the number |
| 358 | * of arguments left that weren't recognized, which are also moved to the |
| 359 | * head of the argument list. The last parameter is used in case no |
| 360 | * parameter given by the first two arguments. |
| 361 | */ |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 362 | int setup_revisions(int argc, const char **argv, struct rev_info *revs, |
| 363 | struct setup_revision_opt *); |
| Heba Waly | 301d595 | 2019-11-17 21:04:48 | [diff] [blame] | 364 | |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 365 | void parse_revision_opt(struct rev_info *revs, struct parse_opt_ctx_t *ctx, |
| 366 | const struct option *options, |
| 367 | const char * const usagestr[]); |
| Junio C Hamano | 8e676e8 | 2012-07-02 19:33:52 | [diff] [blame] | 368 | #define REVARG_CANNOT_BE_FILENAME 01 |
| Junio C Hamano | d5f6b1d | 2012-07-02 19:43:05 | [diff] [blame] | 369 | #define REVARG_COMMITTISH 02 |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 370 | int handle_revision_arg(const char *arg, struct rev_info *revs, |
| 371 | int flags, unsigned revarg_opt); |
| Junio C Hamano | 5d6f093 | 2006-09-06 04:28:36 | [diff] [blame] | 372 | |
| Heba Waly | 301d595 | 2019-11-17 21:04:48 | [diff] [blame] | 373 | /** |
| 374 | * Reset the flags used by the revision walking api. You can use this to do |
| 375 | * multiple sequential revision walks. |
| 376 | */ |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 377 | void reset_revision_walk(void); |
| Heba Waly | 301d595 | 2019-11-17 21:04:48 | [diff] [blame] | 378 | |
| 379 | /** |
| 380 | * Prepares the rev_info structure for a walk. You should check if it returns |
| 381 | * any error (non-zero return code) and if it does not, you can start using |
| 382 | * get_revision() to do the iteration. |
| 383 | */ |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 384 | int prepare_revision_walk(struct rev_info *revs); |
| Heba Waly | 301d595 | 2019-11-17 21:04:48 | [diff] [blame] | 385 | |
| 386 | /** |
| 387 | * Takes a pointer to a `rev_info` structure and iterates over it, returning a |
| 388 | * `struct commit *` each time you call it. The end of the revision list is |
| 389 | * indicated by returning a NULL pointer. |
| 390 | */ |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 391 | struct commit *get_revision(struct rev_info *revs); |
| Heba Waly | 301d595 | 2019-11-17 21:04:48 | [diff] [blame] | 392 | |
| Denton Liu | 4982516 | 2019-11-20 00:51:13 | [diff] [blame] | 393 | const char *get_revision_mark(const struct rev_info *revs, |
| 394 | const struct commit *commit); |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 395 | void put_revision_mark(const struct rev_info *revs, |
| 396 | const struct commit *commit); |
| Linus Torvalds | a4a88b2 | 2006-02-28 19:24:00 | [diff] [blame] | 397 | |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 398 | void mark_parents_uninteresting(struct commit *commit); |
| Nguyễn Thái Ngọc Duy | b3c7eef | 2018-09-21 15:57:39 | [diff] [blame] | 399 | void mark_tree_uninteresting(struct repository *r, struct tree *tree); |
| Derrick Stolee | f1f5de4 | 2019-01-16 18:25:58 | [diff] [blame] | 400 | void mark_trees_uninteresting_sparse(struct repository *r, struct oidset *trees); |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 401 | |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 402 | void show_object_with_name(FILE *, struct object *, const char *); |
| Junio C Hamano | 91f1751 | 2011-08-17 21:30:34 | [diff] [blame] | 403 | |
| Heba Waly | 301d595 | 2019-11-17 21:04:48 | [diff] [blame] | 404 | /** |
| 405 | * This function can be used if you want to add commit objects as revision |
| 406 | * information. You can use the `UNINTERESTING` object flag to indicate if |
| 407 | * you want to include or exclude the given commit (and commits reachable |
| 408 | * from the given commit) from the revision list. |
| 409 | * |
| 410 | * NOTE: If you have the commits as a string list then you probably want to |
| 411 | * use setup_revisions(), instead of parsing each string and using this |
| 412 | * function. |
| 413 | */ |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 414 | void add_pending_object(struct rev_info *revs, |
| 415 | struct object *obj, const char *name); |
| Heba Waly | 301d595 | 2019-11-17 21:04:48 | [diff] [blame] | 416 | |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 417 | void add_pending_oid(struct rev_info *revs, |
| 418 | const char *name, const struct object_id *oid, |
| 419 | unsigned int flags); |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 420 | |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 421 | void add_head_to_pending(struct rev_info *); |
| 422 | void add_reflogs_to_pending(struct rev_info *, unsigned int flags); |
| 423 | void add_index_objects_to_pending(struct rev_info *, unsigned int flags); |
| Junio C Hamano | 3384a2d | 2007-12-11 18:09:04 | [diff] [blame] | 424 | |
| Linus Torvalds | 252a7c0 | 2007-11-04 20:12:05 | [diff] [blame] | 425 | enum commit_action { |
| 426 | commit_ignore, |
| 427 | commit_show, |
| 428 | commit_error |
| 429 | }; |
| 430 | |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 431 | enum commit_action get_commit_action(struct rev_info *revs, |
| 432 | struct commit *commit); |
| 433 | enum commit_action simplify_commit(struct rev_info *revs, |
| 434 | struct commit *commit); |
| Linus Torvalds | 252a7c0 | 2007-11-04 20:12:05 | [diff] [blame] | 435 | |
| Bo Yang | c7edcae | 2013-03-28 16:47:31 | [diff] [blame] | 436 | enum rewrite_result { |
| 437 | rewrite_one_ok, |
| 438 | rewrite_one_noparents, |
| 439 | rewrite_one_error |
| 440 | }; |
| 441 | |
| 442 | typedef enum rewrite_result (*rewrite_parent_fn_t)(struct rev_info *revs, struct commit **pp); |
| 443 | |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 444 | int rewrite_parents(struct rev_info *revs, |
| 445 | struct commit *commit, |
| 446 | rewrite_parent_fn_t rewrite_parent); |
| Thomas Rast | 53d00b3 | 2013-07-31 20:13:20 | [diff] [blame] | 447 | |
| 448 | /* |
| Junio C Hamano | 0131c49 | 2015-01-14 22:49:24 | [diff] [blame] | 449 | * The log machinery saves the original parent list so that |
| 450 | * get_saved_parents() can later tell what the real parents of the |
| 451 | * commits are, when commit->parents has been modified by history |
| 452 | * simpification. |
| Thomas Rast | 53d00b3 | 2013-07-31 20:13:20 | [diff] [blame] | 453 | * |
| 454 | * get_saved_parents() will transparently return commit->parents if |
| 455 | * history simplification is off. |
| 456 | */ |
| Nguyễn Thái Ngọc Duy | d16ec9c | 2018-06-30 09:20:30 | [diff] [blame] | 457 | struct commit_list *get_saved_parents(struct rev_info *revs, const struct commit *commit); |
| Thomas Rast | 53d00b3 | 2013-07-31 20:13:20 | [diff] [blame] | 458 | |
| Linus Torvalds | ae56354 | 2006-02-26 00:19:46 | [diff] [blame] | 459 | #endif |