|   | 98be5a11 | 2021-08-30T17:55:47 |  | Merge branch 'cgraph-write' into main | 
            
              |   | 34fa6311 | 2021-08-30T17:55:13 |  | commit graph: formatting fixes | 
            
              |   | b16a36e1 | 2021-08-29T22:53:49 |  | Merge pull request #6011 from libgit2/ethomson/filter_apply
filter: filter drivers stop taking git_buf as user input | 
            
              |   | 7d9ebdc8 | 2021-08-29T18:50:49 |  | Merge remote-tracking branch 'origin/main' into cgraph-write | 
            
              |   | 5bcef522 | 2021-08-27T17:06:50 |  | filter: deprecate apply function | 
            
              |   | a9a7bfb5 | 2021-05-12T22:13:12 |  | filter: add docs for `git_filter_stream_fn` | 
            
              |   | ea285904 | 2020-02-18T00:02:13 |  | midx: Introduce git_odb_write_multi_pack_index()
This change introduces git_odb_write_multi_pack_index(), which creates a
`multi-pack-index` file from all the `.pack` files that have been loaded
in the ODB.
Fixes: #5399 | 
            
              |   | 9d117e38 | 2020-02-17T21:28:13 |  | midx: Add a way to write multi-pack-index files
This change adds the git_midx_writer_* functions to allow to
write and create `multi-pack-index` files from `.idx`/`.pack` files.
Part of: #5399 | 
            
              |   | 63f08e42 | 2021-08-26T05:29:34 |  | Make the defaultable fields defaultable
Also, add `git_commit_graph_writer_options_init`! | 
            
              |   | 83862c83 | 2020-02-17T21:28:13 |  | commit-graph: Add a way to write commit-graph files
This change adds the git_commit_graph_writer_* functions to allow to
write and create `commit-graph` files from `.idx`/`.pack` files or
`git_revwalk`s.
Part of: #5757 | 
            
              |   | fff209c4 | 2020-02-17T21:28:13 |  | midx: Add a way to write multi-pack-index files
This change adds the git_midx_writer_* functions to allow to
write and create `multi-pack-index` files from `.idx`/`.pack` files.
Part of: #5399 | 
            
              |   | 2370e491 | 2021-07-26T16:27:54 |  | Merge pull request #5765 from lhchavez/cgraph-revwalks
commit-graph: Use the commit-graph in revwalks | 
            
              |   | 3e178547 | 2021-05-27T16:26:38 |  | docs: fix some missing includes that cause Docurium to error out | 
            
              |   | 25b75cd9 | 2021-03-10T07:06:15 |  | commit-graph: Create `git_commit_graph` as an abstraction for the file
This change does a medium-size refactor of the git_commit_graph_file and
the interaction with the ODB. Now instead of the ODB owning a direct
reference to the git_commit_graph_file, there will be an intermediate
git_commit_graph. The main advantage of that is that now end users can
explicitly set a git_commit_graph that is eagerly checked for errors,
while still being able to lazily use the commit-graph in a regular ODB,
if the file is present. | 
            
              |   | 3bbbe95a | 2020-03-26T09:41:09 |  | refdb_backend: improve callback documentation
The callbacks are currently sparsely documented, making it really hard
to implement a new backend without taking a look at the existing
refdb_fs backend. Add documentation to make this task hopefully easier
to achieve. | 
            
              |   | aa4cd778 | 2020-01-30T10:40:44 |  | Merge pull request #5336 from libgit2/ethomson/credtype
cred: change enum to git_credential_t and GIT_CREDENTIAL_* | 
            
              |   | 3f54ba8b | 2020-01-18T13:51:40 |  | credential: change git_cred to git_credential
We avoid abbreviations where possible; rename git_cred to
git_credential.
In addition, we have standardized on a trailing `_t` for enum types,
instead of using "type" in the name.  So `git_credtype_t` has become
`git_credential_t` and its members have become `GIT_CREDENTIAL` instead
of `GIT_CREDTYPE`.
Finally, the source and header files have been renamed to `credential`
instead of `cred`.
Keep previous name and values as deprecated, and include the new header
files from the previous ones. | 
            
              |   | 82050fa1 | 2020-01-18T17:53:26 |  | mempack functions: return an int
Stop returning a void for functions, future-proofing them to allow them
to fail. | 
            
              |   | a3126a72 | 2020-01-18T17:50:38 |  | repository functions: return an int
Stop returning a void for functions, future-proofing them to allow them
to fail. | 
            
              |   | cb43274a | 2020-01-18T17:42:52 |  | index functions: return an int
Stop returning a void for functions, future-proofing them to allow them
to fail. | 
            
              |   | 1bddbd02 | 2020-01-15T10:30:00 |  | merge: Return non-const git_repository from git_merge_driver_source_repo accessor. | 
            
              |   | fefefd1d | 2019-06-23T16:42:14 |  | odb: use `git_object_size_t` for object size
Instead of using a signed type (`off_t`) use a new `git_object_size_t`
for the sizes of objects. | 
            
              |   | 70325370 | 2019-09-27T11:16:02 |  | Merge pull request #5106 from tiennou/fix/ref-api-fixes
git_refdb API fixes | 
            
              |   | 8bf0f7eb | 2019-09-09T13:00:27 |  | cred: separate public interface from low-level details | 
            
              |   | 8db9fd3b | 2019-02-02T19:00:41 |  | refdb: documentation | 
            
              |   | b6625a3b | 2019-06-27T10:12:16 |  | Merge pull request #5128 from tiennou/fix/docs
More documentation | 
            
              |   | 33448b45 | 2019-06-19T19:46:12 |  | docs: More of it | 
            
              |   | 501c51b2 | 2019-06-26T14:49:50 |  | repo: commondir resolution can sometimes fallback to the repodir
For example, https://git-scm.com/docs/gitrepository-layout says:
    info
    Additional information about the repository is recorded in this directory.
    This directory is ignored if $GIT_COMMON_DIR is set
    and "$GIT_COMMON_DIR/info" will be used instead.
So when looking for `info/attributes`, we need to check the commondir first,
or fallback to "our" `info/attributes`. | 
            
              |   | 9f723c97 | 2019-06-26T14:49:37 |  | docs: fixups | 
            
              |   | 459ac856 | 2019-02-23T18:42:53 |  | odb: provide a free function for custom backends
Custom backends can allocate memory when reading objects and providing
them to libgit2.  However, if an error occurs in the custom backend
after the memory has been allocated for the custom object but before
it's returned to libgit2, the custom backend has no way to free that
memory and it must be leaked.
Provide a free function that corresponds to the alloc function so that
custom backends have an opportunity to free memory before they return an
error. | 
            
              |   | 790aae77 | 2019-02-23T18:40:43 |  | odb: rename git_odb_backend_malloc for consistency
The `git_odb_backend_malloc` name is a system function that is provided
for custom ODB backends and allows them to allocate memory for an ODB
object in the read callback.  This is important so that libgit2 can
later free the memory used by an ODB object that was read from the
custom backend.
However, the name _suggests_ that it actually allocates a
`git_odb_backend`.  It does not; rename it to make it clear that it
actually allocates backend _data_. | 
            
              |   | a1ef995d | 2019-02-21T10:33:30 |  | indexer: use git_indexer_progress throughout
Update internal usage of `git_transfer_progress` to
`git_indexer_progreses`. | 
            
              |   | e6c6d3bb | 2019-02-17T22:31:37 |  | Remove `git_time_monotonic`
`git_time_monotonic` was added so that non-native bindings like rugged
could get high-resolution timing for benchmarking.  However, this is
outside the scope of libgit2 *and* rugged decided not to use this
function in the first place.
Google suggests that absolutely _nobody_ is using this function and we
don't want to be in the benchmarking business.  Remove the function. | 
            
              |   | 9fd9126e | 2019-01-30T21:19:18 |  | docs: minor changes | 
            
              |   | f6412c26 | 2019-01-15T13:35:41 |  | transport: enhance documentation | 
            
              |   | 53d13fb3 | 2019-01-23T09:42:55 |  | deprecation: deprecated stream registration in if guard
`git_stream_register_tls` is now deprecated; mark it in an if guard with
the deprecation.
This should not be included in `deprecated.h` since it is an uncommonly
used `sys` header file. | 
            
              |   | 22d2062d | 2019-01-09T18:25:10 |  | Introduce GIT_CALLBACK macro to enforce cdecl
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. | 
            
              |   | 19faf7c5 | 2018-11-14T23:35:48 |  | object_type: update public API to use git_object_t
git_object_t is the future; update the public API to use it.  This will
also ensure that we can build our tests which make use of the old API
without modification (and without compiler warnings). | 
            
              |   | 02bb39f4 | 2018-11-22T08:49:09 |  | stream registration: take an enum type
Accept an enum (`git_stream_t`) during custom stream registration that
indicates whether the registration structure should be used for standard
(non-TLS) streams or TLS streams. | 
            
              |   | df2cc108 | 2018-11-18T10:29:07 |  | stream: provide generic registration API
Update the new stream registration API to be `git_stream_register`
which takes a registration structure and a TLS boolean.  This allows
callers to register non-TLS streams as well as TLS streams.
Provide `git_stream_register_tls` that takes just the init callback for
backward compatibliity. | 
            
              |   | 43b592ac | 2018-10-25T08:49:01 |  | tls: introduce a wrap function
Introduce `git_tls_stream_wrap` which will take an existing `stream`
with an already connected socket and begin speaking TLS on top of it.
This is useful if you've built a connection to a proxy server and you
wish to begin CONNECT over it to tunnel a TLS connection.
Also update the pluggable TLS stream layer so that it can accept a
registration structure that provides an `init` and `wrap` function,
instead of a single initialization function. | 
            
              |   | 8ee10098 | 2018-11-06T13:10:30 |  | transport: see if cert/cred callbacks exist before calling them
Custom transports may want to ask libgit2 to invoke a configured
credential or certificate callback; however they likely do not know if a
callback was actually configured.  Return a sentinal value
(GIT_PASSTHROUGH) if there is no callback configured instead of crashing. | 
            
              |   | 05e54e00 | 2018-10-15T13:54:17 |  | path: export the dotgit-checking functions
These checks are preformed by libgit2 on checkout, but they're also useful for
performing checks in applications which do not involve checkout.
Expose them under `sys/` as it's still fairly in the weeds even for this
library. | 
            
              |   | 74b7ddbf | 2018-03-16T10:14:50 |  | settings: allow swapping out memory allocator
Tie in the newly created infrastructure for swapping out memory
allocators into our settings code. A user can now simply use the new
option "GIT_OPT_SET_ALLOCATOR" with `git_libgit2_opts`, passing in an
already initialized allocator structure as vararg. | 
            
              |   | 9865cd16 | 2018-03-20T14:23:49 |  | alloc: make memory allocators use function pointers
Currently, our memory allocators are being redirected to the correct
implementation at compile time by simply using macros. In order to make
them swappable at runtime, this commit reshuffles that by instead making
use of a global "git_allocator" structure, whose pointers are set up to
reference the allocator functions. Like this, it becomes easy to swap
out allocators by simply setting these function pointers.
In order to initialize a "git_allocator", our provided allocators
"stdalloc" and "crtdbg" both provide an init function. This is being
called to initialize a passed in allocator struct and set up its members
correctly.
No support is yet included to enable users of libgit2 to switch out the
memory allocator at a global level. | 
            
              |   | 177dcfc7 | 2018-05-18T15:16:53 |  | path: hide the dotgit file functions
These can't go into the public API yet as we don't want to introduce API or ABI
changes in a security release. | 
            
              |   | 0aa65f8d | 2018-05-16T15:56:04 |  | path: add functions to detect .gitconfig and .gitattributes | 
            
              |   | 25e8a293 | 2018-03-22T23:27:31 |  | docs: correct defgroup | 
            
              |   | 29afb257 | 2018-03-22T23:27:30 |  | docs: fix incorrect codeblock on output | 
            
              |   | 96576372 | 2018-03-22T23:27:21 |  | docs: fix more missing includes | 
            
              |   | 97f9a5f0 | 2017-12-17T01:12:49 |  | odb: provide length and type with streaming read
The streaming read functionality should provide the length and the type
of the object, like the normal read functionality does. | 
            
              |   | d23ce187 | 2018-01-22T11:55:28 |  | odb: export mempack backend
Fixes #4492, #4496. | 
            
              |   | 529e873c | 2017-05-23T11:51:00 |  | config: pass repository when opening config files
Our current configuration logic is completely oblivious of any
repository, but only cares for actual file paths. Unfortunately, we are
forced to break this assumption by the introduction of conditional
includes, which are evaluated in the context of a repository. Right now,
only one conditional exists with "gitdir:" -- it will only include the
configuration if the current repository's git directory matches the
value passed to "gitdir:".
To support these conditionals, we have to break our API and make the
repository available when opening a configuration file. This commit
extends the `open` call of configuration backends to include another
repository and adjusts existing code to have it available. This includes
the user-visible functions `git_config_add_file_ondisk` and
`git_config_add_backend`. | 
            
              |   | 37841317 | 2017-07-31T00:38:28 |  | Remove unused 'sys/remote.h' header | 
            
              |   | a78441bc | 2017-06-13T11:05:40 |  | Adding git_filter_init for initializing `git_filter` struct + unit test | 
            
              |   | 7f7dabda | 2017-06-12T13:40:47 |  | adding GIT_FILTER_VERSION to GIT_FILTER_INIT as part of convention | 
            
              |   | 5c760960 | 2017-04-17T13:03:03 |  | transport: provide a getter for the proxy options
As with the callbacks, third-party implementations of smart subtransports cannot
reach into the opaque struct and thus cannot know what options the user set.
Add a getter for these options to copy the proxy options into something external
implementors can use. | 
            
              |   | bb342159 | 2017-03-15T11:46:15 |  | merge_driver: fix const-correctness for source getters | 
            
              |   | 4d99c4cf | 2016-11-23T18:32:48 |  | Allow for caching of submodules.
Added `git_repository_submodule_cache_all` to initialze a cache of
submodules on the repository so that operations looking up N
submodules are O(N) and not O(N^2).  Added a
`git_repository_submodule_cache_clear` function to remove the cache.
Also optimized the function that loads all submodules as it was itself
O(N^2) w.r.t the number of submodules, having to loop through the
`.gitmodules` file once per submodule.  I changed it to process the
`.gitmodules` file once, into a map.
Signed-off-by: David Turner <dturner@twosigma.com> | 
            
              |   | 2749ff46 | 2016-09-13T15:52:43 |  | time: Export `git_time_monotonic` | 
            
              |   | 8f09a98e | 2016-07-14T16:23:24 |  | odb: freshen existing objects when writing
When writing an object, we calculate its OID and see if it exists in the
object database.  If it does, we need to freshen the file that contains
it. | 
            
              |   | 60d717c6 | 2015-10-02T10:10:13 |  | proxy: add a payload field for the proxy options
I don't quite recall what we do in the other places where we use this,
but we should pass this payload to the callbacks. | 
            
              |   | b373e9a6 | 2015-09-21T22:38:50 |  | net: use proxy options struct in the stream config | 
            
              |   | 07bd3e57 | 2015-05-07T12:57:56 |  | proxy: ask the user for credentials if necessary | 
            
              |   | 6d8b2cdb | 2016-02-28T09:34:11 |  | merge driver: remove `check` callback
Since the `apply` callback can defer, the `check` callback is not
necessary.  Removing the `check` callback further makes the `payload`
unnecessary along with the `cleanup` callback. | 
            
              |   | 3f7d3df1 | 2016-02-27T16:57:12 |  | merge driver: improve inline documentation | 
            
              |   | 3f04219f | 2015-12-23T10:23:08 |  | merge driver: introduce custom merge drivers
Consumers can now register custom merged drivers with
`git_merge_driver_register`.  This allows consumers to support the
merge drivers, as configured in `.gitattributes`.  Consumers will be
asked to perform the file-level merge when a custom driver is
configured. | 
            
              |   | 0f1e2d20 | 2016-02-23T11:23:26 |  | index: fix contradicting comparison
The overflow check in `read_reuc` tries to verify if the
`git__strtol32` parses an integer bigger than UINT_MAX. The `tmp`
variable is casted to an unsigned int for this and then checked
for being greater than UINT_MAX, which obviously can never be
true.
Fix this by instead fixing the `mode` field's size in `struct
git_index_reuc_entry` to `uint32_t`. We can now parse the int
with `git__strtol64`, which can never return a value bigger than
`UINT32_MAX`, and additionally checking if the returned value is
smaller than zero.
We do not need to handle overflows explicitly here, as
`git__strtol64` returns an error when the returned value would
overflow. | 
            
              |   | 82abd40d | 2016-02-07T13:35:16 |  | filter: clean up documentation around custom filters | 
            
              |   | 7fafde63 | 2015-10-13T11:25:41 |  | stream: allow registering a user-provided TLS constructor
This allows the application to use their own TLS stream, regardless of
the capabilities of libgit2 itself. | 
            
              |   | bf28da47 | 2015-10-30T14:12:19 |  | Fix build for custom transport users
We should explicitly include the declaration of git_strarray
from "include/git2/sys/transport.h" | 
            
              |   | d3b29fb9 | 2015-10-01T00:50:37 |  | refdb and odb backends must provide `free` function
As refdb and odb backends can be allocated by client code, libgit2
can’t know whether an alternative memory allocator was used, and thus
should not try to call `git__free` on those objects.
Instead, odb and refdb backend implementations must always provide
their own `free` functions to ensure memory gets freed correctly. | 
            
              |   | 4f2b6093 | 2015-09-08T13:53:41 |  | Tell the git_transport about the custom_headers | 
            
              |   | 47ed7e5a | 2015-08-18T20:55:59 |  | transport: provide a way to get the callbacks
libgit2 implementations of smart subtransports can simply reach through
the structure, but external implementors cannot.
Add these two functions as a way for the smart subtransports to get the
callbacks as set by the user. | 
            
              |   | b1667039 | 2015-06-01T19:17:03 |  | config: implement basic transactional support
When a configuration file is locked, any updates made to it will be done
to the in-memory copy of the file. This allows for multiple updates to
happen while we hold the lock, preventing races during complex
config-file manipulation. | 
            
              |   | c400bac4 | 2015-08-01T15:38:04 |  | Merge pull request #3332 from phatblat/ben/doc-warnings
Resolve documentation warnings | 
            
              |   | 08afd227 | 2015-07-27T18:32:55 |  | Fix remaining documentation warnings | 
            
              |   | f90fbb8d | 2015-07-27T17:42:08 |  | Use correct Doxygen trailing comment syntax | 
            
              |   | 41808d04 | 2015-07-27T14:46:50 |  | Fix @param names in doc comments | 
            
              |   | 01d0c02d | 2015-07-12T19:08:06 |  | refdb: delete a ref's reflog upon deletion
Removing a reflog upon ref deletion is something which only some
backends might wish to do. Backends which are database-backed may wish
to archive a reflog, log-based ones may not need to do anything. | 
            
              |   | 63924435 | 2015-07-01T09:40:11 |  | filters: custom filters with wildcard attributes
Allow custom filters with wildcard attributes, so that clients
can support some random `filter=foo` in a .gitattributes and look
up the corresponding smudge/clean commands in the configuration file. | 
            
              |   | 1376e784 | 2015-06-07T14:42:13 |  | stream: add support for setting a proxy
If the stream claims to support this feature, we can let the transport
set the proxy.
We also set HTTPPROXYTUNNEL option so curl can create a tunnel through
the proxy which lets us create our own TLS session (if needed). | 
            
              |   | a6f2ceaf | 2015-05-13T12:11:55 |  | Merge pull request #3118 from libgit2/cmn/stream-size
odb: make the writestream's size a git_off_t | 
            
              |   | 058b753c | 2015-04-22T15:45:21 |  | remote: move the transport ctor to the callbacks
Instead of having it set in a different place from every other callback,
put it the main structure. This removes some state from the remote and
makes it behave more like clone, where the constructors are passed via
the options. | 
            
              |   | 8f0104ec | 2015-04-21T22:10:36 |  | Remove the callbacks struct from the remote
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. | 
            
              |   | 77b339f7 | 2015-05-12T13:06:33 |  | odb: make the writestream's size a git_off_t
Restricting files to size_t is a silly limitation. The loose backend
writes to a file directly, so there is no issue in using 63 bits for the
size.
We still assume that the header is going to fit in 64 bytes, which does
mean quite a bit smaller files due to the run-length encoding, but it's
still a much larger size than you would want Git to handle. | 
            
              |   | 142e5379 | 2015-03-17T12:49:33 |  | Add a custom param to git_smart_subtransport_definition
The smart transport has already take the payload param. For the
sub transport a payload param is useful for the implementer. | 
            
              |   | 9a97f49e | 2014-12-21T15:31:03 |  | config: borrow refcounted references
This changes the get_entry() method to return a refcounted version of
the config entry, which you have to free when you're done.
This allows us to avoid freeing the memory in which the entry is stored
on a refresh, which may happen at any time for a live config.
For this reason, get_string() has been forbidden on live configs and a
new function get_string_buf() has been added, which stores the string in
a git_buf which the user then owns.
The functions which parse the string value takea advantage of the
borrowing to parse safely and then release the entry. | 
            
              |   | 795eaccd | 2015-02-19T11:09:54 |  | git_filter_opt_t -> git_filter_flag_t
For consistency with the rest of the library, where an opt is an
options *structure*. | 
            
              |   | b75f15aa | 2015-02-18T09:25:32 |  | git_writestream: from git_filter_stream | 
            
              |   | fbdc9db3 | 2015-01-22T16:10:06 |  | filters: introduce streaming filters
Add structures and preliminary functions to take a buffer, file or
blob and write the contents in chunks through an arbitrary number
of chained filters, finally writing into a user-provided function
accept the contents. | 
            
              |   | a36486ef | 2015-02-11T10:31:54 |  | Fixed error when including git2/include/sys/stream.h | 
            
              |   | f483720c | 2015-01-26T11:25:16 |  | Merge pull request #2839 from swisspol/typo
Fixed typo in git_repository_reinit_filesystem() documentation | 
            
              |   | 86815dca | 2015-01-23T16:04:23 |  | Make sure sys/repository.h includes the required headers
It was missing "common.h" and "types.h" like other system headers.
This generated compilation errors if including it directly. | 
            
              |   | 22b6a923 | 2015-01-23T15:59:54 |  | Fixed typo in git_repository_reinit_filesystem() documentation | 
            
              |   | 85880693 | 2015-01-14T10:19:28 |  | Merge branch 'pr/2740' | 
            
              |   | 36fc5497 | 2014-12-02T05:11:12 |  | Added GIT_HASHSIG_ALLOW_SMALL_FILES to allow computing signatures for small files
The implementation of the hashsig API disallows computing a signature on
small files containing only a few lines. This new flag disables this
behavior.
git_diff_find_similar() sets this flag by default which means that rename
/ copy detection of small files will now work. This in turn affects the
behavior of the git_status and git_blame APIs which will now detect rename
of small files assuming the right options are passed. | 
            
              |   | d76e9df9 | 2015-01-02T15:56:03 |  | Include git2/common.h in sys/openssl.h. | 
            
              |   | 2fe8157e | 2014-12-22T18:42:03 |  | index: reuc and name entrycounts should be size_t
For the REUC and NAME entries, we use size_t internally, and we take
size_t for the get_byindex() functions, but the entrycount() functions
strangely cast to an unsigned int instead. | 
            
              |   | d147900e | 2014-12-20T21:24:45 |  | Merge pull request #2759 from libgit2/cmn/openssl-sys
Make OpenSSL locking warnings more severe |