|   | 78580ad3 | 2018-11-05T15:34:59 |  | apply: test modifying a file after renaming it
Ensure that we cannot modify a file after it's been renamed out of the
way.  If multiple deltas exist for a single path, ensure that we do not
attempt to modify a file after it's been renamed out of the way.
To support this, we must track the paths that have been removed or
renamed; add to a string map when we remove a path and remove from the
string map if we recreate a path.  Validate that we are not applying to
a path that is in this map, unless the delta is a rename, since git
supports renaming one file to two different places in two different
deltas.
Further, test that we cannot apply a modification delta to a path that
will be created in the future by a rename (a path that does not yet
exist.) | 
            
              |   | 605066ee | 2018-11-05T14:37:35 |  | apply: test renaming a file after modifying it
Multiple deltas can exist in a diff, and can be applied in-order.
If there exists a delta that modifies a file followed by a delta that
renames that file, then both will be captured.  The modification delta
will be applied and the resulting file will be staged with the original
filename.  The rename delta will be independently applied - to the
original file (not the modified file from the original delta) and staged
independently. | 
            
              |   | a3c1070c | 2018-11-04T14:07:22 |  | apply: test modify delta after rename delta
Ensure that we can apply a delta after renaming a file. | 
            
              |   | 56a2ae0c | 2018-11-04T12:18:01 |  | apply: test rename 2 to 1
Test that we can apply a patch that renames two different files to the
same target filename.  Git itself handles this scenario in a last-write
wins, such that the rename listed last is the one persisted in the
target.  Ensure that we do the same. | 
            
              |   | 52e27b84 | 2018-10-10T12:42:54 |  | reader: free is unused and unnecessary
None of the reader implementations actually allocate anything
themselves, so they don't need a free function.  Remove it. | 
            
              |   | 47cc5f85 | 2018-09-29T19:32:51 |  | apply: introduce a hunk callback
Introduce a callback to patch application that allows consumers to
cancel hunk application. | 
            
              |   | 235dc9b2 | 2018-11-04T12:05:46 |  | apply: test circular rename
Test a rename from A->B simultaneous with a rename from B->A. | 
            
              |   | 398d8bfe | 2018-07-16T17:19:08 |  | apply tests: tests a diff w/ many small changes | 
            
              |   | b8840db7 | 2018-07-10T16:18:45 |  | apply tests: test delta callback skip
Test that we can return a non-zero value from the apply delta
callback and it will skip the application of a given delta. | 
            
              |   | 07e71bfa | 2018-11-04T13:14:20 |  | apply: test multiple deltas to new file | 
            
              |   | 89b5a56e | 2018-11-04T11:58:20 |  | apply: test rename A -> B -> C scenarios
Test that we can rename some file from B->C and then rename some other
file from A->B.  Do this with both exact rename patches (eg `rename from
...` / `rename to ...`) and patches that remove the files and replace
them entirely. | 
            
              |   | db6b1164 | 2018-07-10T16:13:17 |  | apply tests: test delta callback errors
Test that we can return an error from the apply delta callback and the
error code is propagated back to the caller. | 
            
              |   | af33210b | 2018-07-10T16:10:03 |  | apply: introduce a delta callback
Introduce a callback to the application options that allow callers to
add a per-delta callback.  The callback can return an error code to stop
patch application, or can return a value to skip the application of a
particular delta. | 
            
              |   | 6fecf4d1 | 2018-11-04T11:47:46 |  | apply: handle exact renames
Deltas containing exact renames are special; they simple indicate that a
file was renamed without providing additional metadata (like the
filemode).  Teach the reader to provide the file mode and use the
preimage's filemode in the case that the delta does not provide one.) | 
            
              |   | bd682f3e | 2018-11-04T19:01:57 |  | apply: test that we can't rename a file after modifying it
Multiple deltas can exist in a diff, and can be applied in-order.
However if there exists a delta that renames a file, it must be first,
so that other deltas can reference the resulting target file.
git enforces this (`error: already exists in index`), so ensure that we
do, too. | 
            
              |   | df4258ad | 2018-11-04T13:01:03 |  | apply: handle multiple deltas to the same file
git allows a patch file to contain multiple deltas to the same file:
although it does not produce files in this format itself, this could
be the result of concatenating two different patch files that affected
the same file.
git apply behaves by applying this next delta to the existing postimage
of the file.  We should do the same.  If we have previously seen a file,
and produced a postimage for it, we will load that postimage and apply
the current delta to that.  If we have not, get the file from the
preimage. | 
            
              |   | 12f9ac17 | 2018-11-04T11:26:42 |  | apply: validate unchanged mode when applying both
When applying to both the index and the working directory, ensure that
the working directory's mode matches the index's mode.  It's not
sufficient to look only at the hashed object id to determine that the
file is unchanged, git also takes the mode into account. | 
            
              |   | b73a42f6 | 2018-11-04T10:48:23 |  | apply: test a patch with rename and modification
Create a test applying a patch with a rename and a modification of a
file. | 
            
              |   | c71e964a | 2018-11-04T12:21:57 |  | apply: test rename 1 to 2
Test that a patch can contain two deltas that appear to rename an
initial source file to two different destination paths.  Git creates
both target files with the initial source contents; ensure that we do,
too. | 
            
              |   | 620ac9c2 | 2017-04-11T14:41:57 |  | patch: add tests for aborting hunk callback | 
            
              |   | 72630572 | 2017-03-30T22:40:47 |  | patch: add support for partial patch application
Add hunk callback parameter to git_apply__patch to allow hunks to be skipped. | 
            
              |   | 37b25ac5 | 2018-07-08T16:12:58 |  | apply: move location to an argument, not the opts
Move the location option to an argument, out of the options structure.
This allows the options structure to be re-used for functions that don't
need to know the location, since it's implicit in their functionality.
For example, `git_apply_tree` should not take a location, but is
expected to take all the other options. | 
            
              |   | 2d27ddc0 | 2018-07-01T21:35:51 |  | apply: use an indexwriter
Place the entire `git_apply` operation inside an indexwriter, so that we
lock the index before we begin performing patch application.  This
ensures that there are no other processes modifying things in the
working directory. | 
            
              |   | eb76e985 | 2018-07-01T21:21:25 |  | apply tests: ensure mode changes occur
Test that a mode change is reflected in the working directory or index. | 
            
              |   | 5c63ce79 | 2018-07-01T11:10:03 |  | apply tests: test with CR/LF filtering
Ensure that we accurately CR/LF filter when reading from the working
directory.  If we did not, we would erroneously fail to apply the patch
because the index contents did not match the working directory contents. | 
            
              |   | 9be89bbd | 2018-07-01T11:08:26 |  | reader: apply working directory filters
When reading a file from the working directory, ensure that we apply any
necessary filters to the item.  This ensures that we get the
repository-normalized data as the preimage, and further ensures that we
can accurately compare the working directory contents to the index
contents for accurate safety validation in the `BOTH` case. | 
            
              |   | 813f0802 | 2018-07-01T15:14:36 |  | apply: validate workdir contents match index for BOTH
When applying to both the index and the working directory, ensure that
the index contents match the working directory.  This mirrors the
requirement in `git apply --index`.
This also means that - along with the prior commit that uses the working
directory contents as the checkout baseline - we no longer expect
conflicts during checkout.  So remove the special-case error handling
for checkout conflicts.  (Any checkout conflict now would be because the
file was actually modified between the start of patch application and
the checkout.) | 
            
              |   | 0f4b2f02 | 2018-07-01T15:13:50 |  | reader: optionally validate index matches workdir
When using a workdir reader, optionally validate that the index contents
match the working directory contents. | 
            
              |   | 3b674660 | 2018-07-01T13:46:59 |  | apply tests: ensure we can patch a modified file
Patch application need not be on an unmodified file; applying to an
already changed file is supported provided the patch still applies
cleanly.  Add tests that modifies the contents of a file then applies
the patch and ensures that the patch applies cleanly, and the original
changes are also kept. | 
            
              |   | 5b8d5a22 | 2018-07-01T13:42:53 |  | apply: use preimage as the checkout baseline
Use the preimage as the checkout's baseline.  This allows us to support
applying patches to files that are modified in the working directory
(those that differ from the HEAD and index).  Without this, files will
be reported as (checkout) conflicts.  With this, we expect the on-disk
data when we began the patch application (the "preimage") to be on-disk
during checkout.
We could have also simply used the `FORCE` flag to checkout to
accomplish a similar mechanism.  However, `FORCE` ignores all
differences, while providing a preimage ensures that we will only
overwrite the file contents that we actually read.
Modify the reader interface to provide the OID to support this. | 
            
              |   | dddfff77 | 2018-06-30T17:12:16 |  | apply: convert checkout conflicts to apply failures
When there's a checkout conflict during apply, that means that the
working directory was modified in a conflicting manner and the postimage
cannot be written.  During application, convert this to an application
failure for consistency across workdir/index/both applications. | 
            
              |   | 9db66c79 | 2018-06-29T12:50:38 |  | apply test: apply with non-conflicting changes
Ensure that we can apply to the working directory or the index when the
application target is modified, so long as there are not conflicting
changes to the items. | 
            
              |   | 771bd81e | 2018-06-29T12:40:16 |  | apply tests: ensure apply failures leave index unmodified | 
            
              |   | 5b66b667 | 2018-06-29T12:39:41 |  | apply: when preimage file is missing, return EAPPLYFAIL
The preimage file being missing entirely is simply a case of an
application failure; return the correct error value for the caller. | 
            
              |   | 4ff829e9 | 2018-06-30T17:20:03 |  | apply tests: test index+workdir application
Test application with `GIT_APPLY_LOCATION_BOTH`, which emulates
`git apply --index`, updating both the index and the working directory
with the postimage. | 
            
              |   | e0224121 | 2018-06-29T12:09:02 |  | apply: simplify checkout vs index application
Separate the concerns of applying via checkout and updating the
repository's index.  This results in simpler functionality and allows us
to not build the temporary collection of paths in the index case. | 
            
              |   | 2bd3cfea | 2018-06-29T11:43:55 |  | apply tests: modified wd items are ok when applying to index
When applying to the index (using `GIT_APPLY_LOCATION_INDEX`), ensure
that items modified in the working directory do not conflict with the
application. | 
            
              |   | d7090ee4 | 2018-06-28T17:26:24 |  | apply tests: ensure we can add and remove files from the index
Add a test that adds a new file, and another that removes a file when
applying using `GIT_APPLY_LOCATION_INDEX` to ensure that they work. | 
            
              |   | 20f8a6db | 2018-06-28T17:26:21 |  | apply: remove deleted paths from index
We update the index with the new_file side of the delta, but we need to
explicitly remove the old_file path in the case where an item was
deleted or renamed. | 
            
              |   | 9d81defa | 2018-06-28T16:26:08 |  | apply tests: GIT_APPLY_LOCATION_INDEX with parsed patches | 
            
              |   | eef34e4e | 2018-06-28T16:24:21 |  | apply tests: GIT_APPLY_LOCATION_INDEX with generated patches
Test a simple patch application with `GIT_APPLY_LOCATION_INDEX`, which
emulates `git apply --cached`. | 
            
              |   | c010c93b | 2018-06-27T16:50:07 |  | apply tests: move helpers into common area | 
            
              |   | 35d525b0 | 2018-06-26T09:19:12 |  | apply: test that failures don't dirty workdir
Ensure that when a patch application fails (due to a conflict in the
working directory, for example) that we do not half-apply the patch or
otherwise leave the working directory dirty.
This is rather obvious in our current apply implementation (we do a two
step process: one to create the post-image and one to check it out) but
this test is a safety net for future refactoring or improvements. | 
            
              |   | c3077ea0 | 2018-06-25T21:24:49 |  | apply: return a specific exit code on failure
Return `GIT_EAPPLYFAIL` on patch application failure so that users can
determine that patch application failed due to a malformed/conflicting
patch by looking at the error code. | 
            
              |   | 973bf0c8 | 2018-06-25T20:49:22 |  | apply: test a patch can be applied even with a modified index
Ensure that we can apply a patch to the working directory, even to files
that are modified in the index (as long as the working directory
contents match the preimage - such that the working directory is
unmodified from HEAD). | 
            
              |   | 553395dc | 2018-06-25T20:21:01 |  | apply: test that the index is not modified
Ensure that by default, when using GIT_APPLY_LOCATION_WORKDIR, that
patch application does not update the index, only the working directory. | 
            
              |   | 0eb63b9f | 2018-06-25T19:50:35 |  | apply tests: separate common patch hunks
Move the commonly-used patch hunks into a single constant location.
This allows us to avoid re-declaring them in each test, and allows
us to compose them to build a larger patch file that includes all
the hunks. | 
            
              |   | 702d4bec | 2018-06-26T15:26:37 |  | apply tests: use `git_iterator_foreach` for tests
Use the new `git_iterator_foreach` API to validate the workdir against
the expected workdir values instead of using the paired/multi iterator
comparison callback.  This allows us to use the `git_iterator_foreach`
to validate the index as well, instead of assuming that the index and
HEAD must always match. | 
            
              |   | d54aa9ae | 2018-06-26T15:25:30 |  | iterator: introduce `git_iterator_foreach`
Introduce a `git_iterator_foreach` helper function which invokes a
callback on all files for a given iterator. | 
            
              |   | 9c34c996 | 2018-06-25T17:03:14 |  | apply: handle file additions
Don't attempt to read the postimage file during a file addition, simply
use an empty buffer as the postimage.  Also, test that we can handle
file additions. | 
            
              |   | 3b5378c5 | 2018-06-25T16:27:06 |  | apply: handle file deletions
If the file was deleted in the postimage, do not attempt to update the
target.  Instead, ignore it and simply allow it to stay removed in our
computed postimage.  Also, test that we can handle file deletions. | 
            
              |   | af3287f8 | 2018-06-22T19:27:19 |  | apply: test `git_apply` with a parsed patch
Ensure that we can apply a simple patch to the working directory when we
have parsed it from a patch file. | 
            
              |   | ff296b71 | 2018-03-19T19:50:52 |  | apply: test `git_apply` application to a workdir
Introduce a standard test applying a diff to a working directory with no
complications. | 
            
              |   | f83bbe0a | 2018-03-19T19:50:45 |  | apply: introduce `git_apply`
Introduce `git_apply`, which will take a `git_diff` and apply it to the
working directory (akin to `git apply`), the index (akin to `git apply
--cached`), or both (akin to `git apply --index`). | 
            
              |   | 664cda6f | 2018-03-19T20:10:38 |  | apply: reimplement `git_apply_tree` with readers
The generic `git_reader` interface simplifies `git_apply_tree` somewhat.
Reimplement `git_apply_tree` with them. | 
            
              |   | d73043a2 | 2018-03-19T20:10:31 |  | reader: a generic way to read files from repos
Similar to the `git_iterator` interface, the `git_reader` interface will
allow us to read file contents from an arbitrary repository-backed data
source (trees, index, or working directory). | 
            
              |   | 02b1083a | 2018-01-28T23:25:07 |  | apply: introduce `git_apply_tree`
Introduce `git_apply_tree`, which will apply a `git_diff` to a given
`git_tree`, allowing an in-memory patch application for a repository. | 
            
              |   | 2b12dcf6 | 2018-03-19T19:45:11 |  | iterator: optionally hash filesystem iterators
Optionally hash the contents of files encountered in the filesystem or
working directory iterators.  This is not expected to be used in
production code paths, but may allow us to simplify some test contexts.
For working directory iterators, apply filters as appropriate, since we
have the context able to do it. | 
            
              |   | b5ae83bf | 2018-10-31T08:47:10 |  | Merge pull request #4860 from tiennou/ci/macos-leaks
CI: Fix macOS leak detection | 
            
              |   | 8c49b3bf | 2018-10-30T22:32:57 |  | tests: use CLAR_AT_EXIT to check for leaks on macOS | 
            
              |   | 0e69485e | 2018-10-23T20:34:47 |  | clar: provide a way to run some shell before exiting | 
            
              |   | 79558009 | 2018-10-26T15:40:16 |  | Merge pull request #4800 from libgit2/ethomson/badgification
README: more CI status badges | 
            
              |   | b7174dde | 2018-10-26T14:59:50 |  | Merge pull request #4867 from libgit2/ethomson/ci
ci: Fix some minor issues | 
            
              |   | f195c385 | 2018-10-26T14:10:13 |  | nightly: the path to yaml templates is relative
Don't prefix the path to the yaml templates - the nightly template
itself is already in the `azure-pipelines` directory.  Instead, just
use the relative path. | 
            
              |   | f22521ef | 2018-10-26T12:31:39 |  | ci: fail if requested test name is not found (unix)
POSIX: the CMakeLists.txt configures the test names; when we query
ctest for the test command-line to run, fail if the tests are not
found. | 
            
              |   | 05c51bb6 | 2018-10-26T06:35:57 |  | ci: fail if requested test name is not found (win32)
Win32: The CMakeLists.txt configures the test names; when we query
ctest for the test command-line to run, fail if the tests are not
found. | 
            
              |   | 623647af | 2018-10-26T12:33:59 |  | Merge pull request #4864 from pks-t/pks/object-parse-fixes
Object parse fixes | 
            
              |   | 814389d4 | 2018-10-25T23:40:19 |  | Merge pull request #4862 from libgit2/ethomson/win_ci
Windows CI: fail build on test failure | 
            
              |   | cd248c70 | 2018-10-25T23:25:09 |  | Merge pull request #4863 from libgit2/ethomson/ci_nightly
ci: run all the jobs during nightly builds | 
            
              |   | be5a2ae2 | 2018-10-25T23:19:42 |  | ci: run all the jobs during nightly builds
Instead of running the oddball builds, run all the builds (the ones
that we always run during PR validation and CI) during a nightly
build for increased coverage. | 
            
              |   | 0e26717a | 2018-10-25T14:26:28 |  | ci: fail on test failures
PowerShell can _read_ top-level variables in functions, but cannot _update_
top-level variables in functions unless they're explicitly prefixed with
`$global`. | 
            
              |   | 7655b2d8 | 2018-10-19T10:29:19 |  | commit: fix reading out of bounds when parsing encoding
The commit message encoding is currently being parsed by the
`git__prefixcmp` function. As this function does not accept a buffer
length, it will happily skip over a buffer's end if it is not `NUL`
terminated.
Fix the issue by using `git__prefixncmp` instead. Add a test that
verifies that we are unable to parse the encoding field if it's cut off
by the supplied buffer length. | 
            
              |   | c2e3d8ef | 2018-10-25T12:01:18 |  | tests: add tests that exercise commit parsing
We currently do not have any test suites dedicated to parsing commits
from their raw representations. Add one based on `git_object__from_raw`
to be able to test special cases more easily. | 
            
              |   | ee11d47e | 2018-10-19T09:47:50 |  | tag: fix out of bounds read when searching for tag message
When parsing tags, we skip all unknown fields that appear before the tag
message. This skipping is done by using a plain `strstr(buffer, "\n\n")`
to search for the two newlines that separate tag fields from tag
message. As it is not possible to supply a buffer length to `strstr`,
this call may skip over the buffer's end and thus result in an out of
bounds read. As `strstr` may return a pointer that is out of bounds, the
following computation of `buffer_end - buffer` will overflow and result
in an allocation of an invalid length.
Fix the issue by using `git__memmem` instead. Add a test that verifies
parsing the tag fails not due to the allocation failure but due to the
tag having no message. | 
            
              |   | 4c738e56 | 2018-10-19T09:44:14 |  | tests: add tests that exercise tag parsing
While the tests in object::tag::read exercises reading and parsing valid
tags from the ODB, they barely try to verify that the parser fails in a
sane way when parsing invalid tags. Create a new test suite
object::tag::parse that directly exercise the parser by using
`git_object__from_raw` and add various tests for valid and invalid tags. | 
            
              |   | 83e8a6b3 | 2018-10-18T16:08:46 |  | util: provide `git__memmem` function
Unfortunately, neither the `memmem` nor the `strnstr` functions are part
of any C standard but are merely extensions of C that are implemented by
e.g. glibc. Thus, there is no standardized way to search for a string in
a block of memory with a limited size, and using `strstr` is to be
considered unsafe in case where the buffer has not been sanitized. In
fact, there are some uses of `strstr` in exactly that unsafe way in our
codebase.
Provide a new function `git__memmem` that implements the `memmem`
semantics. That is in a given haystack of `n` bytes, search for the
occurrence of a byte sequence of `m` bytes and return a pointer to the
first occurrence. The implementation chosen is the "Not So Naive"
algorithm from [1]. It was chosen as the implementation is comparably
simple while still being reasonably efficient in most cases.
Preprocessing happens in constant time and space, searching has a time
complexity of O(n*m) with a slightly sub-linear average case.
[1]: http://www-igm.univ-mlv.fr/~lecroq/string/ | 
            
              |   | bea65980 | 2018-10-25T11:21:14 |  | Merge pull request #4851 from pks-t/pks/strtol-removal
strtol removal | 
            
              |   | 11945461 | 2018-10-25T11:17:52 |  | Merge pull request #4854 from libgit2/ethomson/buf_oom_test
 buf::oom tests: use custom allocator for oom failures | 
            
              |   | fa274f7f | 2018-10-23T22:34:45 |  | ci: redirect the malloc debugging output to /dev/null | 
            
              |   | 2e34efaa | 2018-10-21T13:10:06 |  | buf::oom tests: use custom allocator for oom failures
Create a custom allocator for the `buf::oom` tests that will fail with
out-of-memory errors in predictable ways.  We were previously trying to
guess the way that various allocators on various platforms would fail
in a way such that `malloc`/`realloc` would return `NULL` (instead of
aborting the application, or appearing suspicious to various
instrumentation or static code analysis tools like valgrind.)
Introduce a fake `malloc` and `realloc` that will return `NULL` on
allocations requesting more than 100 bytes.  Otherwise, we proxy to the
default allocator.  (It's important to use the _default_ allocator, not
just call `malloc`, since the default allocator on Windows CI builds may
be the debugging C runtime allocators which would not be compatible with
a standard `malloc`.) | 
            
              |   | 305e801a | 2018-10-21T09:52:32 |  | util: allow callers to reset custom allocators
Provide a utility to reset custom allocators back to their default.
This is particularly useful for testing. | 
            
              |   | 671b2446 | 2018-10-21T12:50:46 |  | Merge pull request #4804 from libgit2/ethomson/qemu-build
ci: arm docker builds | 
            
              |   | 7c557169 | 2018-10-21T10:34:38 |  | ci: use trusty-amd64 for openssl and mbedtls
We don't need two separate docker images for OpenSSL and mbedTLS.
They've been combined into a single image `trusty-amd64` that supports
both. | 
            
              |   | 415a8ae9 | 2018-09-13T13:27:07 |  | tests: don't run buf::oom on 32-bit systems
On a 32-bit Linux systems, the value large enough to make malloc
guarantee a failure is also large enough that valgrind considers it
"fishy".  Skip this test on those systems entirely. | 
            
              |   | 9cc4ba5c | 2018-09-13T16:12:41 |  | valgrind: extend the suppressions file
Newer dependencies means newer places to leak! | 
            
              |   | d82800e8 | 2018-10-21T09:31:42 |  | ci: use bionic for non-amd64 builds
Use Bionic so that we have a modern libssh2 (for communicating with
GitHub).  We've ported fixes to our Trusty-based amd64 images, but
maintaining patches for multiple platforms is heinous. | 
            
              |   | b244ea79 | 2018-10-21T09:24:08 |  | ci: introduce nightly x86 linux builds | 
            
              |   | f195395a | 2018-10-21T09:16:35 |  | ci: bind specifically to localhost for proxy
Bind the proxy specifically to 127.0.0.1 instead of all addresses.  This
is not strictly necessary for operations, but having a potentially open
proxy on a network is not a good idea. | 
            
              |   | 0e521abd | 2018-10-21T09:15:24 |  | ci: introduce nightly arm docker builds
Use multiarch arm32 and arm64 docker images to run Xenial-based images
for those platforms.  We can support all the tests on ARM32 and 64
_except_ the proxy-based tests.  Our proxy on ARM seems regrettably
unstable, either due to some shoddy dependencies (with native code?)
or the JREs themselves.
Run these platforms as part of our nightly builds; do not run them
during pull request or CI validation. | 
            
              |   | 28f05585 | 2018-10-21T09:20:10 |  | ci: reorganize naming for consistency | 
            
              |   | 4ec597dc | 2018-10-21T09:12:43 |  | ci: move configuration yaml to its own directory
As the number of each grow, separate the CI build scripts from
the YAML definitions. | 
            
              |   | 7c791f3d | 2018-10-20T20:25:51 |  | Merge pull request #4852 from libgit2/ethomson/unc_paths
Win32 path canonicalization refactoring | 
            
              |   | 6cc14ae3 | 2018-10-20T20:22:04 |  | Merge pull request #4840 from libgit2/cmn/validity-tree-from-unowned-index
Check object existence when creating a tree from an index | 
            
              |   | a2f9f94b | 2018-10-20T20:18:04 |  | Merge branch 'issue-4203' | 
            
              |   | 32b81661 | 2018-10-20T20:16:32 |  | merge: don't leak the index during reloads | 
            
              |   | c79e6081 | 2018-10-20T19:08:16 |  | checkout: fix test fixture missing objects
The testrepo test fixture has an index file that's damaged, missing an
object.  The index previously had an entry of `src/index.c` with id
3161df8cbf3a006b4ef85be6497a0ea6bde98541, but that object was missing in
the repository.  This commit adds an object to the repository and
updates the index to use that existing blob.
Similarly, the index has an entry for `readme` with an id of
97328ac7e3bd0bcd3900cb3e7a624d71dd0df888.  This can be restored from
other test repositories.
With these fixed, now the write tree from index tests can pass since they
validate object existence. | 
            
              |   | 2ad07ad5 | 2018-10-20T18:14:25 |  | Merge pull request #4841 from tiennou/ci/ninja-build
Ninja build | 
            
              |   | f77e6cc7 | 2018-10-19T17:10:01 |  | ci: make the Ubuntu/OpenSSL build explicit | 
            
              |   | 6a67e42d | 2018-10-08T19:33:27 |  | ci: use Ninja on macOS | 
            
              |   | 0fccf017 | 2018-10-19T15:48:46 |  | Merge pull request #4853 from libgit2/cmn/not-opaque
docs: fix transparent/opaque confusion in the conventions file |