From: Denys Vlasenko <vda.linux@googlemail.com>
Date: Mon, 10 Dec 2018 14:12:58 +0000 (+0100)
Subject: bc: optimize bc_vec_concat()
X-Git-Tag: 1_30_0~234
X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=8b4cf0dbb08a8a526045051b442e45cb2359b224;p=oweals%2Fbusybox.git

bc: optimize bc_vec_concat()

function                                             old     new   delta
bc_vec_concat                                         71      66      -5

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
---

diff --git a/miscutils/bc.c b/miscutils/bc.c
index afd5c8d0e..71022569e 100644
--- a/miscutils/bc.c
+++ b/miscutils/bc.c
@@ -1165,13 +1165,14 @@ static void bc_vec_string(BcVec *v, size_t len, const char *str)
 
 static void bc_vec_concat(BcVec *v, const char *str)
 {
-	size_t len;
+	size_t len, slen;
 
 	if (v->len == 0) bc_vec_pushZeroByte(v);
 
-	len = v->len + strlen(str);
+	slen = strlen(str);
+	len = v->len + slen;
 
-	if (v->cap < len) bc_vec_grow(v, len - v->len);
+	if (v->cap < len) bc_vec_grow(v, slen);
 	strcpy(v->v + v->len - 1, str);
 
 	v->len = len;