aboutsummaryrefslogtreecommitdiff
path: root/path.c
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2016-11-29 13:27:55 -0800
committerJunio C Hamano <gitster@pobox.com>2016-11-29 13:27:55 -0800
commitf2ad912f996d2f21a8e6bccc10c2d3ef7acbf3ea (patch)
treeddd478a6e752b491093c37921a5848d38dd32e39 /path.c
parenta3f2781dd0c295b5be2c0b42776f806d4f40df05 (diff)
parentbb84735c80dbae6408b79b56f574ae672d2232d4 (diff)
downloadgit-f2ad912f996d2f21a8e6bccc10c2d3ef7acbf3ea.tar.xz
Merge branch 'rs/ring-buffer-wraparound' into maint
The code that we have used for the past 10+ years to cycle 4-element ring buffers turns out to be not quite portable in theoretical world. * rs/ring-buffer-wraparound: hex: make wraparound of the index into ring-buffer explicit
Diffstat (limited to 'path.c')
-rw-r--r--path.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/path.c b/path.c
index fe3c4d96c6..9bfaeda207 100644
--- a/path.c
+++ b/path.c
@@ -24,7 +24,8 @@ static struct strbuf *get_pathname(void)
STRBUF_INIT, STRBUF_INIT, STRBUF_INIT, STRBUF_INIT
};
static int index;
- struct strbuf *sb = &pathname_array[3 & ++index];
+ struct strbuf *sb = &pathname_array[index];
+ index = (index + 1) % ARRAY_SIZE(pathname_array);
strbuf_reset(sb);
return sb;
}