git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] strbuf_write: omit system call when length is zero
@ 2016-02-25 22:34 Stefan Beller
  2016-02-25 23:04 ` Junio C Hamano
  2016-02-26  0:47 ` Duy Nguyen
  0 siblings, 2 replies; 5+ messages in thread
From: Stefan Beller @ 2016-02-25 22:34 UTC (permalink / raw)
  To: gitster; +Cc: git, Jens.Lehmann, peff, sunshine, jrnieder, Stefan Beller

In case the length of the buffer is zero, we do not need to call the
fwrite system call as a performance improvement.

Signed-off-by: Stefan Beller <sbeller@google.com>
---

 This applies on top of v17 for origin/sb/submodule-parallel-update.
 
 In case there are other reasons for origin/sb/submodule-parallel-update
 to need a reroll I'll squash it in. But as this is a pure performance
 optimization in a case we are not running into with that series and that
 series is clashing with Davids refs backend series, I figure we may not
 want to have a reroll for this fix alone.
 
 Thanks,
 Stefan
  

 strbuf.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/strbuf.c b/strbuf.c
index 71345cd..5f6da82 100644
--- a/strbuf.c
+++ b/strbuf.c
@@ -397,7 +397,7 @@ ssize_t strbuf_read_once(struct strbuf *sb, int fd, size_t hint)
 
 ssize_t strbuf_write(struct strbuf *sb, FILE *f)
 {
-	return fwrite(sb->buf, 1, sb->len, f);
+	return sb->len ? fwrite(sb->buf, 1, sb->len, f) : 0;
 }
 
 
-- 
2.7.2.374.ga5f0819.dirty

^ permalink raw reply related	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2016-02-26 17:10 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-02-25 22:34 [PATCH] strbuf_write: omit system call when length is zero Stefan Beller
2016-02-25 23:04 ` Junio C Hamano
2016-02-26  0:47 ` Duy Nguyen
2016-02-26  1:40   ` Junio C Hamano
2016-02-26 17:09     ` Stefan Beller

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).