diff options
author | Marco Costalba <mcostalba@gmail.com> | 2007-07-22 10:23:05 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2007-07-22 10:40:21 +0200 |
commit | c4640fe8d9e25fd3e206a39233c71a6dbb68917e (patch) | |
tree | 5ef0602a6f3405f89f769f55017dac4df25a55b5 /commit.c | |
parent | Synonyms: -i == --regexp-ignore-case, -E == --extended-regexp (diff) | |
download | git-c4640fe8d9e25fd3e206a39233c71a6dbb68917e.tar.xz git-c4640fe8d9e25fd3e206a39233c71a6dbb68917e.zip |
Avoid to duplicate commit message when is not encoded
When a commit message doesn't have encoding information
and encoding output is utf-8 (default) then an useless
xstrdup() of commit message is done.
If we assume most of users live in an utf-8 world, this
useless copy is the common case.
Performance issue found with KCachegrind.
Signed-off-by: Marco Costalba <mcostalba@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'commit.c')
-rw-r--r-- | commit.c | 5 |
1 files changed, 4 insertions, 1 deletions
@@ -721,7 +721,10 @@ static char *logmsg_reencode(const struct commit *commit, encoding = get_header(commit, "encoding"); use_encoding = encoding ? encoding : utf8; if (!strcmp(use_encoding, output_encoding)) - out = xstrdup(commit->buffer); + if (encoding) /* we'll strip encoding header later */ + out = xstrdup(commit->buffer); + else + return NULL; /* nothing to do */ else out = reencode_string(commit->buffer, output_encoding, use_encoding); |