1. 12 Feb, 2023 12 commits
  2. 09 Feb, 2023 1 commit
  3. 02 Feb, 2023 1 commit
  4. 24 Jan, 2023 2 commits
  5. 20 Jan, 2023 1 commit
  6. 05 Jan, 2023 1 commit
    • Use `git_clone__submodule` to avoid file checks in workdir · ae7a0a63
      `git_clone` checks for existence of (non-empty) directories that would clash with what is about to be cloned.
      
      This is problematic when cloning submodules since they make sense in the context of a parent module, so they should not use the current working dir.
      
      Since in `git_submodule_update` we clone the submodule only when it is not yet initialized we do not need to perform directory checks.
      Aleš Bizjak committed
  7. 25 Nov, 2022 2 commits
  8. 23 Nov, 2022 1 commit
  9. 19 Nov, 2022 1 commit
  10. 10 Nov, 2022 1 commit
  11. 04 Nov, 2022 1 commit
  12. 03 Nov, 2022 4 commits
    • commit-graph: only verify csum on git_commit_graph_open(). · 2c4eb83e
      It is expensive to compute the sha1 of the entire commit-graph file each
      time we open it. Git only does this if it is re-writing the file.
      
      This patch will only verify the checksum when calling the external API
      git_commit_graph_open(), which explicitly says it opens and verifies
      the commit graph in the documentation.
      
      For internal library calls, we call git_commit_graph_get_file(), which
      mmaps the commit-graph file in read-only mode. Therefore it is safe to
      skip the validation check there.
      
      Tests were added to check that the validation works in the happy path,
      and prevents us from opening the file when validation fails.
      
      (Note from Derrick Stolee: This patch was applied internally at GitHub
      after we recognized the performance impact it had during an upgrade of
      libgit2. The original author left the company before we remembered to
      send it upstream.)
      
      Signed-off-by: Derrick Stolee <derrickstolee@github.com>
      Colin Stolley committed
    • Missing dispose · a8b18f15
      Julian Mesa committed
    • Fix leak in git_tag_create_from_buffer · c7e8de17
      If the tag already exists and we are not forcing overwrite we need to free ref_name buffer before return the "tag already exists" error.
      Julian Mesa committed
  13. 02 Nov, 2022 1 commit
  14. 20 Oct, 2022 1 commit
    • http: Update httpclient options when reusing an existing connection. · f8683b7a
      Httpclient internally stores a copy of the certificate_check callback and
      payload. When connecting via HTTPS, and if the server sends back
      "Connection: close" after the first request, the following request would
      attempt to re-use the httpclient and call the (now outdated) callback. In
      particular for pygit2 this is a problem, since callbacks / payloads are only
      valid for the duration of a libgit2 call, leading to a ffi.from_handle()
      error and crashing the Python interpreter.
      Sebastian Lackner committed
  15. 01 Oct, 2022 1 commit
  16. 19 Sep, 2022 3 commits
    • cmake: provide empty experimental.h for non-cmake users · c1172468
      Not everybody builds libgit2 using cmake; provide an `experimental.h`
      with no experiments configured for those that do not. To support this,
      we also now create compile definitions for experimental functionality,
      to supplant that empty `experimental.h`. cmake will continue to generate
      the proper `experimental.h` file for use with `make install`.
      Edward Thomson committed
    • clone: narrow success tests on HEAD-less remotes · c928d96e
      Only allow the remote default branch checking to fail when the remote
      default branch doesn't exist (`git_remote__default_branch` returns
      `GIT_ENOTFOUND`). If there was any other type of error - for example, an
      allocation failure - we should not swallow that and continue to fail.
      
      This allows us to support the case when a remote has not advertised a
      HEAD -- this is possible, for example, when the remote has constrained
      the caller to a particular namespace. But other remote failures remain
      as failures.
      Edward Thomson committed
  17. 31 Aug, 2022 1 commit
  18. 14 Aug, 2022 1 commit
  19. 10 Aug, 2022 1 commit
  20. 08 Aug, 2022 1 commit
  21. 30 Jul, 2022 1 commit
    • Don't fail the whole clone if you can't find a default branch · bf80cb63
      In commit 6bb35878 ("clone: set refs/remotes/origin/HEAD to default
      branch when branch is specified, attempt 2") libgit2 was changed to set
      the default remote branch when one was copied.
      
      But it makes update_head_to_branch() return an error if the origin
      doesn't even *have* a HEAD in the first place, since
      git_remote_default_branch() will fail.
      
      That's entirely wrong, and means that you cannot do "git_clone()" of a
      particular branch on a remote repository when that remote doesn't have a
      default branch at all.
      
      So don't set the error code.
      
      Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
      Linus Torvalds committed
  22. 22 Jul, 2022 1 commit