diff options
author | Junio C Hamano <gitster@pobox.com> | 2016-11-29 22:27:55 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2016-11-29 22:27:55 +0100 |
commit | f2ad912f996d2f21a8e6bccc10c2d3ef7acbf3ea (patch) | |
tree | ddd478a6e752b491093c37921a5848d38dd32e39 | |
parent | Merge branch 'mm/send-email-cc-cruft-after-address' into maint (diff) | |
parent | hex: make wraparound of the index into ring-buffer explicit (diff) | |
download | git-f2ad912f996d2f21a8e6bccc10c2d3ef7acbf3ea.tar.xz git-f2ad912f996d2f21a8e6bccc10c2d3ef7acbf3ea.zip |
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
-rw-r--r-- | hex.c | 3 | ||||
-rw-r--r-- | path.c | 3 |
2 files changed, 4 insertions, 2 deletions
@@ -78,7 +78,8 @@ char *sha1_to_hex(const unsigned char *sha1) { static int bufno; static char hexbuffer[4][GIT_SHA1_HEXSZ + 1]; - return sha1_to_hex_r(hexbuffer[3 & ++bufno], sha1); + bufno = (bufno + 1) % ARRAY_SIZE(hexbuffer); + return sha1_to_hex_r(hexbuffer[bufno], sha1); } char *oid_to_hex(const struct object_id *oid) @@ -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; } |