diff options
author | Junio C Hamano <junkio@cox.net> | 2007-05-03 13:00:43 -0700 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2007-05-03 22:12:40 -0700 |
commit | cdda666201710dcf50d7ebee804aac65fdec32fd (patch) | |
tree | a10bca66929a8a81dea529ffecfc670297207c78 | |
parent | 9cf04301b182c4c57d62ea63554d109db613f9d3 (diff) | |
download | git-cdda666201710dcf50d7ebee804aac65fdec32fd.tar.gz git-cdda666201710dcf50d7ebee804aac65fdec32fd.tar.xz |
diff.c: fix "size cache" handling.
We broke the size-cache handling when we changed the function
signature of sha1_object_info() in 21666f1a. We obviously
wanted to cache the size we obtained when sha1_object_info()
succeeded, not when it failed.
Signed-off-by: Junio C Hamano <junkio@cox.net>
-rw-r--r-- | diff.c | 13 |
1 files changed, 7 insertions, 6 deletions
@@ -1468,14 +1468,15 @@ int diff_populate_filespec(struct diff_filespec *s, int size_only) enum object_type type; struct sha1_size_cache *e; + if (size_only && use_size_cache && + (e = locate_size_cache(s->sha1, 1, 0)) != NULL) { + s->size = e->size; + return 0; + } + if (size_only) { - e = locate_size_cache(s->sha1, 1, 0); - if (e) { - s->size = e->size; - return 0; - } type = sha1_object_info(s->sha1, &s->size); - if (type < 0) + if (use_size_cache && 0 < type) locate_size_cache(s->sha1, 0, s->size); } else { |