|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| | Move to the `git_error` name in error-related functions, deprecating the
`giterr` functions.  This means, for example, that `giterr_last` is now
`git_error_last`.  The old names are retained for compatibility.
This only updates the public API; internal API and function usage
remains unchanged. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Since we now always build the library with cdecl calling conventions,
our callbacks should be decorated as such so that users will not be able
to provide callbacks defined with other calling conventions.
The `GIT_CALLBACK` macro will inject the `__cdecl` attribute as
appropriate. | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Having the setting be different from calling its actions was not a great
idea and made for the sake of the wrong convenience.
Instead of that, accept either fetch options, push options or the
callbacks when dealing with the remote. The fetch options are currently
only the callbacks, but more options will be moved from setters and
getters on the remote to the options.
This does mean passing the same struct along the different functions but
the typical use-case will only call git_remote_fetch() or
git_remote_push() and so won't notice much difference. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | The signature for the reflog is not something which changes
dynamically. Almost all uses will be NULL, since we want for the
repository's default identity to be used, making it noise.
In order to allow for changing the identity, we instead provide
git_repository_set_ident() and git_repository_ident() which allow a user
to override the choice of signature. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | This makes them show up in the reference, even if the text itself isn't
the most descriptive.
These have been found with
    grep -Przon '\n\ntypedef struct.*?\{' -- include
    grep -Przon '\n\ntypedef enum.*?\{' -- include | 
| | 
| 
| 
| 
| 
| | As git_clone now has callbacks to configure the details of the
repository and remote, remove the lower-level functions from the public
API, as they lack some of the logic from git_clone proper. | 
| | 
| 
| 
| 
| 
| | Analogously to the remote creation callback, provide a way for the user
of git_clone() to create the repository with whichever options they
desire via callback. | 
| | 
| 
| 
| 
| | git_remote_set_transport now takes a transport factory rather than a transport
git_clone_options now allows the caller to specify a remote creation callback | 
| | 
| 
| 
| 
| | Add docs for git_clone_local_t and move the docs for the
git_clone_options to each field. | 
| | 
| 
| 
| 
| 
| 
| 
| | If requested, git_clone_local_into() will try to link the object files
instead of copying them.
This only works on non-Windows (since it doesn't have this) when both
are on the same filesystem (which are unix semantics). | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| | When git is given such a path, it will perform a "local clone",
bypassing the git-aware protocol and simply copying over all objects
that exist in the source.
Copy this behaviour when given a local path. | 
| | 
| 
| 
| 
| | Use an unsigned int for the version and add a helper macro so the
code is simplified (and so the error message is a common string). | 
| | |  | 
| | 
| 
| 
| | The basic structure of each function is courtesy of arrbee. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| | Clone callbacks can return non-zero values to cancel the clone.
This adds some tests to verify that this actually works and updates
the documentation to be clearer that this can happen and that the
return value will be propagated back by the clone function. | 
| | 
| 
| 
| | There's no need for this to be a pointer to somewhere else. | 
| | 
| 
| 
| | Make the difference more explicit. | 
| | 
| 
| 
| 
| | This is a small thing that by itself doesn't quite justify making the
user use clone_into. | 
| | 
| 
| 
| 
| | The removal of many options which lead to the direct usage of the
user's checkout options means we should make sure they remain const. | 
| | 
| 
| 
| 
| | This used to be done via transport flags, which was removed in a
previous commit. | 
| | 
| 
| 
| 
| 
| | The basic clone function is there to make it easy to create a "normal"
clone. Remove a bunch of options that are about changing the remote's
configuration. | 
| | 
| 
| 
| 
| | Downloading all tags is part of what makes it a clone instead of
simply a fetch. | 
| | 
| 
| 
| 
| | This allows you to set up the repository and remote as you which to
have them before performing the clone operation. | 
| | 
| 
| 
| 
| | Move this one as well, letting us have a single way of setting the
callbacks for the remote, and removing fields from the clone options. | 
| | 
| 
| 
| 
| 
| | The text progress and update_tips callbacks are already part of the
struct, which was meant to unify the callback setup, but the download
one was left out. | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| | Conflicts:
	src/branch.c
	tests-clar/refs/branches/create.c | 
| | 
| 
| 
| 
| 
| 
| | git_indexer_stats and friends -> git_transfer_progress*
Also made git_transfer_progress members more sanely
named. | 
| | |  | 
| | 
| 
| 
| | Also implemented in the git2 example. | 
| | |  | 
| | |  |