diff options
author | Junio C Hamano <gitster@pobox.com> | 2013-07-25 04:21:02 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2013-07-25 04:21:02 +0200 |
commit | 29143fc4e3e5236aa57a1f1ef63f775491159782 (patch) | |
tree | e0f64b9317ceac018bf1d58cb7668d73a3dd4104 /refs.c | |
parent | Merge branch 'sb/misc-fixes' (diff) | |
parent | refs: do not invalidate the packed-refs cache unnecessarily (diff) | |
download | git-29143fc4e3e5236aa57a1f1ef63f775491159782.tar.xz git-29143fc4e3e5236aa57a1f1ef63f775491159782.zip |
Merge branch 'mh/ref-races-optim-invalidate-cached'
* mh/ref-races-optim-invalidate-cached:
refs: do not invalidate the packed-refs cache unnecessarily
Diffstat (limited to 'refs.c')
-rw-r--r-- | refs.c | 9 |
1 files changed, 6 insertions, 3 deletions
@@ -2174,11 +2174,14 @@ int lock_packed_refs(int flags) { struct packed_ref_cache *packed_ref_cache; - /* Discard the old cache because it might be invalid: */ - clear_packed_ref_cache(&ref_cache); if (hold_lock_file_for_update(&packlock, git_path("packed-refs"), flags) < 0) return -1; - /* Read the current packed-refs while holding the lock: */ + /* + * Get the current packed-refs while holding the lock. If the + * packed-refs file has been modified since we last read it, + * this will automatically invalidate the cache and re-read + * the packed-refs file. + */ packed_ref_cache = get_packed_ref_cache(&ref_cache); packed_ref_cache->lock = &packlock; /* Increment the reference count to prevent it from being freed: */ |