From: Alex Riesen Date: Thu, 19 Mar 2009 22:27:32 +0000 (+0100) Subject: Microoptimize strbuf_cmp X-Git-Tag: v1.6.3-rc0~127 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=8f0246551c3964eeb16d9c9f39845bd53af8bda8;p=git.git Microoptimize strbuf_cmp It can be less object code and may be even faster, even if at the moment there is no callers to take an advantage of that. This implementation can be trivially made inlinable later. Signed-off-by: Alex Riesen Signed-off-by: Junio C Hamano --- diff --git a/strbuf.c b/strbuf.c index 6ed06840b..bfbd81632 100644 --- a/strbuf.c +++ b/strbuf.c @@ -139,14 +139,11 @@ void strbuf_list_free(struct strbuf **sbs) int strbuf_cmp(const struct strbuf *a, const struct strbuf *b) { - int cmp; - if (a->len < b->len) { - cmp = memcmp(a->buf, b->buf, a->len); - return cmp ? cmp : -1; - } else { - cmp = memcmp(a->buf, b->buf, b->len); - return cmp ? cmp : a->len != b->len; - } + int len = a->len < b->len ? a->len: b->len; + int cmp = memcmp(a->buf, b->buf, len); + if (cmp) + return cmp; + return a->len < b->len ? -1: a->len != b->len; } void strbuf_splice(struct strbuf *sb, size_t pos, size_t len,