1. 15 Feb, 2019 1 commit
    • maps: use uniform lifecycle management functions · 351eeff3
      Currently, the lifecycle functions for maps (allocation, deallocation, resize)
      are not named in a uniform way and do not have a uniform function signature.
      Rename the functions to fix that, and stick to libgit2's naming scheme of saying
      `git_foo_new`. This results in the following new interface for allocation:
      
      - `int git_<t>map_new(git_<t>map **out)` to allocate a new map, returning an
        error code if we ran out of memory
      
      - `void git_<t>map_free(git_<t>map *map)` to free a map
      
      - `void git_<t>map_clear(git<t>map *map)` to remove all entries from a map
      
      This commit also fixes all existing callers.
      Patrick Steinhardt committed
  2. 01 Dec, 2018 1 commit
  3. 10 Jun, 2018 1 commit
    • pack: rename `git_packfile_stream_free` · c8ee5270
      The function `git_packfile_stream_free` frees all state of the packfile
      stream without freeing the structure itself. This naming makes it hard
      to spot whether it will try to free the pointer itself or not, causing
      potential future errors. Due to this reason, we have decided to name a
      function freeing state without freeing the actual struture a "dispose"
      function.
      
      Rename `git_packfile_stream_free` to `git_packfile_stream_dispose` as a
      first example following this rule.
      Patrick Steinhardt committed
  4. 03 Jul, 2017 1 commit
    • Make sure to always include "common.h" first · 0c7f49dd
      Next to including several files, our "common.h" header also declares
      various macros which are then used throughout the project. As such, we
      have to make sure to always include this file first in all
      implementation files. Otherwise, we might encounter problems or even
      silent behavioural differences due to macros or defines not being
      defined as they should be. So in fact, our header and implementation
      files should make sure to always include "common.h" first.
      
      This commit does so by establishing a common include pattern. Header
      files inside of "src" will now always include "common.h" as its first
      other file, separated by a newline from all the other includes to make
      it stand out as special. There are two cases for the implementation
      files. If they do have a matching header file, they will always include
      this one first, leading to "common.h" being transitively included as
      first file. If they do not have a matching header file, they instead
      include "common.h" as first file themselves.
      
      This fixes the outlined problems and will become our standard practice
      for header and source files inside of the "src/" from now on.
      Patrick Steinhardt committed
  5. 21 Jan, 2017 1 commit
  6. 04 Aug, 2016 1 commit
  7. 13 Jan, 2016 1 commit
  8. 11 Mar, 2015 1 commit
  9. 15 Feb, 2015 1 commit
  10. 23 Jun, 2014 1 commit
    • Share packs across repository instances · b3b66c57
      Opening the same repository multiple times will currently open the same
      file multiple times, as well as map the same region of the file multiple
      times. This is not necessary, as the packfile data is immutable.
      
      Instead of opening and closing packfiles directly, introduce an
      indirection and allocate packfiles globally. This does mean locking on
      each packfile open, but we already use this lock for the global mwindow
      list so it doesn't introduce a new contention point.
      Carlos Martín Nieto committed
  11. 13 May, 2014 1 commit
  12. 09 May, 2014 2 commits
    • pack: use a cache for delta bases when unpacking · a332e91c
      Bring back the use of the delta base cache for unpacking objects. When
      generating the delta chain, we stop when we find a delta base in the
      pack's cache and use that as the starting point.
      Carlos Martín Nieto committed
    • pack: unpack using a loop · 2acdf4b8
      We currently make use of recursive function calls to unpack an object,
      resolving the deltas as we come back down the chain. This means that we
      have unbounded stack growth as we look up objects in a pack.
      
      This is now done in two steps: first we figure out what the dependency
      chain is by looking up the delta bases until we reach a non-delta
      object, pushing the information we need onto a stack and then we pop
      from that stack and apply the deltas until there are no more left.
      
      This version of the code does not make use of the delta base cache so it
      is slower than what's in the mainline. A later commit will reintroduce
      it.
      Carlos Martín Nieto committed
  13. 23 Jan, 2014 1 commit
  14. 01 Nov, 2013 2 commits
  15. 04 Oct, 2013 1 commit
  16. 22 Apr, 2013 3 commits
    • Consolidate packfile allocation further · 5d2d21e5
      Rename git_packfile_check to git_packfile_alloc since it is now
      being used more in that capacity.  Fix the various places that use
      it.  Consolidate some repeated code in odb_pack.c related to the
      allocation of a new pack_backend.
      Russell Belfer committed
    • Further threading fixes · 53607868
      This builds on the earlier thread safety work to make it so that
      setting the odb, index, refdb, or config for a repository is done
      in a threadsafe manner with minimized locking time.  This is done
      by adding a lock to the repository object and using it to guard
      the assignment of the above listed pointers.  The lock is only
      held to assign the pointer value.
      
      This also contains some minor fixes to the other work with pack
      files to reduce the time that locks are being held to and fix an
      apparently memory leak.
      Russell Belfer committed
    • Add mutex around mapping and unmapping pack files · 24c70804
      When I was writing threading tests for the new cache, the main
      error I kept running into was a pack file having it's content
      unmapped underneath the running thread.  This adds a lock around
      the routines that map and unmap the pack data so that threads can
      effectively reload the data when they need it.
      
      This also required reworking the error handling paths in a couple
      places in the code which I tried to make consistent.
      Russell Belfer committed
  17. 03 Mar, 2013 1 commit
    • indexer: use a hashtable for keeping track of offsets · 0e040c03
      These offsets are needed for REF_DELTA objects, which encode which
      object they use as a base, but not where it lies in the packfile, so
      we need a list.
      
      These objects are mostly from older packfiles, before OFS_DELTA was
      widely spread. The time spent in indexing these packfiles is greatly
      reduced, though remains above what git is able to do.
      Carlos Martín Nieto committed
  18. 12 Jan, 2013 1 commit
  19. 11 Jan, 2013 6 commits
  20. 08 Jan, 2013 1 commit
  21. 02 Dec, 2012 1 commit
    • pack: add git_packfile_resolve_header · 44f9f547
      To paraphrase @peff:
      
      You can get both size and type from a packed object reasonably cheaply.
      If you have:
      
      * An object that is not a delta; both type and size are available in the
        packfile header.
      * An object that is a delta. The packfile type will be OBJ_*_DELTA, and
        you have to resolve back to the base to find the real type. That means
        potentially a lot of packfile index lookups, but each one is
        relatively cheap. For the size, you inflate the first few bytes of the
        delta, whose header will tell you the resulting size of applying the
        delta to the base.
      
      For simplicity, we just decompress the whole delta for now.
      David Michael Barr committed
  22. 30 Nov, 2012 1 commit
  23. 27 Nov, 2012 1 commit
  24. 14 Sep, 2012 1 commit
  25. 24 Jul, 2012 1 commit
  26. 03 Jul, 2012 1 commit
  27. 13 Apr, 2012 1 commit
  28. 13 Mar, 2012 1 commit
    • Migrate ODB files to new error handling · e1de726c
      This migrates odb.c, odb_loose.c, odb_pack.c and pack.c to
      the new style of error handling.  Also got the unix and win32
      versions of map.c.  There are some minor changes to other
      files but no others were completely converted.
      
      This also contains an update to filebuf so that a zeroed out
      filebuf will not think that the fd (== 0) is actually open
      (and inadvertently call close() on fd 0 if cleaned up).
      
      Lastly, this was built and tested on win32 and contains a
      bunch of fixes for the win32 build which was pretty broken.
      Russell Belfer committed
  29. 13 Feb, 2012 1 commit
  30. 14 Oct, 2011 1 commit
    • *: correct and codify various file permissions · 01ad7b3a
      The following files now have 0444 permissions:
      
      - loose objects
      - pack indexes
      - pack files
      - packs downloaded by fetch
      - packs downloaded by the HTTP transport
      
      And the following files now have 0666 permissions:
      
      - config files
      - repository indexes
      - reflogs
      - refs
      
      This brings libgit2 more in line with Git.
      
      Note that git_filebuf_commit() and git_filebuf_commit_at() have both
      gained a new mode parameter.
      
      The latter change fixes an important issue where filebufs created with
      GIT_FILEBUF_TEMPORARY received 0600 permissions (due to mkstemp(3)
      usage). Now we chmod() the file before renaming it into place.
      
      Tests have been added to confirm that new commit, tag, and tree
      objects are created with the right permissions. I don't have access to
      Windows, so for now I've guarded the tests with "#ifndef GIT_WIN32".
      Brodie Rao committed
  31. 19 Sep, 2011 1 commit
    • Tabify everything · 87d9869f
      There were quite a few places were spaces were being used instead of
      tabs. Try to catch them all. This should hopefully not break anything.
      Except for `git blame`. Oh well.
      Vicent Marti committed