1. 15 Feb, 2019 3 commits
    • refdb_fs: do not lazily copy packed ref cache · 83333814
      When creating a new iterator, we eagerly load loose refs but only lazily create
      a copy of packed refs. The lazy load only happens as soon as we have iterated
      over all loose refs, opening up a potentially wide window for races. This
      may lead to an inconsistent view e.g. when the caller decides to reload packed
      references somewhen between iterating the loose refs, which is unexpected.
      
      Fix the issue by eagerly copying the sorted cache. Note that right now, we are
      heavily dependent on ordering here: we first need to reload packed refs, then we
      have to load loose refs and only as a last step are we allowed to copy the
      cache. This is because loading loose refs has the side-effect of setting the
      `PACKED_SHADOWED` flag in the packed refs cache, which we require to avoid
      outputting packed refs that already exist as loose refs.
      Patrick Steinhardt committed
    • refdb_fs: refactor error handling in iterator creation · 32063d82
      Refactor the error handling in `refdb_fs_backend__iterator` to always return the
      correct error code returned by the failing function.
      Patrick Steinhardt committed
    • refdb_fs: fix potential race with ref repacking in `exists` callback · 8c773438
      When repacking references, git.git will first update the packed refs and only
      afterwards delete any existing loose references that have now been moved to the
      new packed refs file. Due to this, there is a potential for racing if one first
      reads the packfile (which has not been updated yet) and only then trying to read
      the loose reference (which has just been deleted). In this case, one will
      incorrectly fail to lookup the reference and it will be reported as missing.
      Naturally, this is exactly what we've been doing in `refdb_fs_backend__exists`.
      
      Fix the race by reversing the lookup: we will now first check if the loose
      reference exists and only afterwards refresh the packed file.
      Patrick Steinhardt committed
  2. 14 Feb, 2019 15 commits
  3. 13 Feb, 2019 2 commits
  4. 12 Feb, 2019 1 commit
  5. 02 Feb, 2019 2 commits
  6. 31 Jan, 2019 10 commits
  7. 30 Jan, 2019 2 commits
  8. 28 Jan, 2019 5 commits