summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLibravatar Junio C Hamano <gitster@pobox.com>2016-10-27 14:58:49 -0700
committerLibravatar Junio C Hamano <gitster@pobox.com>2016-10-27 14:58:49 -0700
commit00d7cc0c0b324b1b1c75b97d05423a2dc3af70cf (patch)
treeda7ccf9ac82d892abf7b745187aa84ff7014f95c
parentMerge branch 'sb/submodule-ignore-trailing-slash' (diff)
parenthex: make wraparound of the index into ring-buffer explicit (diff)
downloadtgif-00d7cc0c0b324b1b1c75b97d05423a2dc3af70cf.tar.xz
Merge branch 'rs/ring-buffer-wraparound'
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.c3
-rw-r--r--path.c3
2 files changed, 4 insertions, 2 deletions
diff --git a/hex.c b/hex.c
index ab2610e498..845b01a874 100644
--- a/hex.c
+++ b/hex.c
@@ -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)
diff --git a/path.c b/path.c
index a8e72955f6..52d889c88e 100644
--- a/path.c
+++ b/path.c
@@ -25,7 +25,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;
}