Message ID | 20241227-b4-pks-commit-reach-sign-compare-v1-6-07c59c2aa632@pks.im (mailing list archive) |
---|---|
State | Accepted |
Commit | 0905ed201a87bc97dc4d47c0cb8fd65316f33269 |
Headers | show |
Series | commit-reach: -Wsign-compare follow-ups | expand |
On 24/12/27 11:46AM, Patrick Steinhardt wrote: > Similar as with the preceding commit, adapt "builtin/log.c" so that it > tracks array indices via `size_t` instead of using signed integers. This > fixes a couple of -Wsign-compare warnings and prepares the code for > a similar refactoring of `repo_get_merge_bases_many()` in a subsequent > commit. > > Signed-off-by: Patrick Steinhardt <ps@pks.im> > --- > builtin/log.c | 23 +++++++++++++---------- > 1 file changed, 13 insertions(+), 10 deletions(-) > [snip] > if (show_progress) > progress = start_delayed_progress(_("Generating patches"), total); > - while (0 <= --nr) { > + for (i = 0; i < nr; i++) { > + size_t idx = nr - i - 1; > int shown; > - display_progress(progress, total - nr); > - commit = list[nr]; > - rev.nr = total - nr + (start_number - 1); > + > + display_progress(progress, total - idx); > + commit = list[idx]; > + rev.nr = total - idx + (start_number - 1); Along with updating array indices variables to use `size_t`, the loop structure here is also changed. Instead of iterating backwards from `nr`, the loop iterator increases and each iteration computes the index starting from the end. This is functionally the same behavior and it looks like it was done to improve readability. > + > /* Make the second and subsequent mails replies to the first */ > if (cfg.thread) { > /* Have we already had a message ID? */ > > -- > 2.48.0.rc0.184.g0fc57dec57.dirty > >
On Thu, Jan 02, 2025 at 07:58:24PM -0600, Justin Tobler wrote: > On 24/12/27 11:46AM, Patrick Steinhardt wrote: > > Similar as with the preceding commit, adapt "builtin/log.c" so that it > > tracks array indices via `size_t` instead of using signed integers. This > > fixes a couple of -Wsign-compare warnings and prepares the code for > > a similar refactoring of `repo_get_merge_bases_many()` in a subsequent > > commit. > > > > Signed-off-by: Patrick Steinhardt <ps@pks.im> > > --- > > builtin/log.c | 23 +++++++++++++---------- > > 1 file changed, 13 insertions(+), 10 deletions(-) > > > [snip] > > if (show_progress) > > progress = start_delayed_progress(_("Generating patches"), total); > > - while (0 <= --nr) { > > + for (i = 0; i < nr; i++) { > > + size_t idx = nr - i - 1; > > int shown; > > - display_progress(progress, total - nr); > > - commit = list[nr]; > > - rev.nr = total - nr + (start_number - 1); > > + > > + display_progress(progress, total - idx); > > + commit = list[idx]; > > + rev.nr = total - idx + (start_number - 1); > > Along with updating array indices variables to use `size_t`, the loop > structure here is also changed. Instead of iterating backwards from > `nr`, the loop iterator increases and each iteration computes the index > starting from the end. This is functionally the same behavior and it > looks like it was done to improve readability. It wasn't really done to improve readability, but to retain correctness. Before this change we relied on `nr` being signed, and thus it could also have a negative value. Now that it's a `size_t` it would overflow eventually and that would make the loop condition a tautology. So I had to refactor the condition so that it doesn't rely on such an overflow anymore. Patrick
diff --git a/builtin/log.c b/builtin/log.c index 75e1b34123b348f57334d5592879398064de246e..805b2355d964915732edf5928d54fb6d06e394d4 100644 --- a/builtin/log.c +++ b/builtin/log.c @@ -1746,11 +1746,12 @@ struct base_tree_info { static struct commit *get_base_commit(const struct format_config *cfg, struct commit **list, - int total) + size_t total) { struct commit *base = NULL; struct commit **rev; - int i = 0, rev_nr = 0, auto_select, die_on_failure, ret; + int auto_select, die_on_failure, ret; + size_t i = 0, rev_nr = 0; switch (cfg->auto_base) { case AUTO_BASE_NEVER: @@ -1885,13 +1886,12 @@ define_commit_slab(commit_base, int); static void prepare_bases(struct base_tree_info *bases, struct commit *base, struct commit **list, - int total) + size_t total) { struct commit *commit; struct rev_info revs; struct diff_options diffopt; struct commit_base commit_base; - int i; if (!base) return; @@ -1906,7 +1906,7 @@ static void prepare_bases(struct base_tree_info *bases, repo_init_revisions(the_repository, &revs, NULL); revs.max_parents = 1; revs.topo_order = 1; - for (i = 0; i < total; i++) { + for (size_t i = 0; i < total; i++) { list[i]->object.flags &= ~UNINTERESTING; add_pending_object(&revs, &list[i]->object, "rev_list"); *commit_base_at(&commit_base, list[i]) = 1; @@ -2007,7 +2007,7 @@ int cmd_format_patch(int argc, struct rev_info rev; char *to_free = NULL; struct setup_revision_opt s_r_opt; - int nr = 0, total, i; + size_t nr = 0, total, i; int use_stdout = 0; int start_number = -1; int just_numbers = 0; @@ -2500,11 +2500,14 @@ int cmd_format_patch(int argc, if (show_progress) progress = start_delayed_progress(_("Generating patches"), total); - while (0 <= --nr) { + for (i = 0; i < nr; i++) { + size_t idx = nr - i - 1; int shown; - display_progress(progress, total - nr); - commit = list[nr]; - rev.nr = total - nr + (start_number - 1); + + display_progress(progress, total - idx); + commit = list[idx]; + rev.nr = total - idx + (start_number - 1); + /* Make the second and subsequent mails replies to the first */ if (cfg.thread) { /* Have we already had a message ID? */
Similar as with the preceding commit, adapt "builtin/log.c" so that it tracks array indices via `size_t` instead of using signed integers. This fixes a couple of -Wsign-compare warnings and prepares the code for a similar refactoring of `repo_get_merge_bases_many()` in a subsequent commit. Signed-off-by: Patrick Steinhardt <ps@pks.im> --- builtin/log.c | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-)