| Commit message (Collapse) | Author | Age | Files | Lines |
| |
|
| |
|
| |
|
|\
| |
| | |
Trivial memory leak fixes in test suite
|
| | |
|
|/ |
|
|\
| |
| | |
patch: minor documentation fix.
|
|/
|
|
| |
Fix @return description of git_patch_num_lines_in_hunk.
|
|\
| |
| | |
Squelch example warnings, enable CI
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
|/ |
|
|\ |
|
| | |
|
|\ \
| | |
| | | |
docs: GIT_OPT_ENABLE_STRICT_OBJECT_CREATION is enabled
|
| | |
| | |
| | |
| | |
| | | |
We changed the defaults on strict object creation - it is enabled by
default. Update the documentation to reflect that.
|
|\ \ \
| |/ /
|/| | |
Object parsing hardening
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | | |
When parsing a commit, we will treat all bytes left after parsing
the headers as the commit message. When no bytes are left, we
leave the commit's message uninitialized. While uncommon to have
a commit without message, this is the right behavior as Git
unfortunately allows for empty commit messages.
Given that this scenario is so uncommon, most programs acting on
the commit message will never check if the message is actually
set, which may lead to errors. To work around the error and not
lay the burden of checking for empty commit messages to the
developer, initialize the commit message with an empty string
when no commit message is given.
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | | |
When parsing tree entries from raw object data, we do not verify
that the tree entry actually has a filename as well as a valid
object ID. Fix this by asserting that the filename length is
non-zero as well as asserting that there are at least
`GIT_OID_RAWSZ` bytes left when parsing the OID.
|
|\ \ \
| | | |
| | | | |
Fix the existence check for `regcomp_l`.
|
|/ / /
| | |
| | |
| | |
| | |
| | |
| | | |
`xlocale.h` only defines `regcomp_l` if `regex.h` was included as well.
Also change the test cases to actually test `p_regcomp` works with
a multibyte locale.
|
|\ \ \
| | | |
| | | | |
Improve revision walk preparation logic
|
| | | |
| | | |
| | | |
| | | |
| | | |
| | | | |
When we read from the list which `limit_list()` gives us, we need to check that
the commit is still interesting, as it might have become uninteresting after it
was added to the list.
|
| | | |
| | | |
| | | |
| | | |
| | | |
| | | | |
`git-rebase--merge` does not ask for time sorting, but uses the default. We now
produce the same default time-ordered output as git, so make us of that since
it's not always the same output as our time sorting.
|
| | | |
| | | |
| | | |
| | | |
| | | |
| | | | |
It changed from implementation-defined to git's default sorting, as there are
systems (e.g. rebase) which depend on this order. Also specify more explicitly
how you can get git's "date-order".
|
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | | |
After `limit_list()` we already have the list in time-sorted order, which is
what we want in the "default" case. Enqueueing into the "unsorted" list would
just reverse it, and the topological sort will do its own sorting if it needs
to.
|
| | | | |
|
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | | |
We've now moved to code that's closer to git and produces the output
during the preparation phase, so we no longer process the commits as
part of generating the output.
This makes a chunk of code redundant, as we're simply short-circuiting
it by detecting we've processed the commits alrady.
|
| | | |
| | | |
| | | |
| | | |
| | | | |
Change the condition for returning 0 more in line with that we write
elsewhere in the library.
|
| | | |
| | | |
| | | |
| | | |
| | | | |
This returns the integer-cast truth value comparing the dates. What we
want instead of a (-1, 0, 1) output depending on how they compare.
|
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | | |
After porting over the commit hiding and selection we were still left
with mistmaching output due to the topologial sort.
This ports the topological sorting code to make us match with our
equivalent of `--date-order` and `--topo-order` against the output
from `rev-list`.
|
| | | |
| | | |
| | | |
| | | | |
In this case, we simply behave like a vector.
|
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | | |
This is a convenience function to reverse the contents of a vector and a pqueue
in-place.
The pqueue function is useful in the case where we're treating it as a
LIFO queue.
|
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | | |
We had some home-grown logic to figure out which objects to show during
the revision walk, but it was rather inefficient, looking over the same
list multiple times to figure out when we had run out of interesting
commits. We now use the lists in a smarter way.
We also introduce the slop mechanism to determine when to stpo
looking. When we run out of interesting objects, we continue preparing
the walk for another 5 rounds in order to make it less likely that we
miss objects in situations with complex graphs.
|
| | | |
| | | |
| | | |
| | | |
| | | |
| | | | |
Introduce some tests that show some commits, while hiding some commits
that have a timestamp older than the common ancestors of these two
commits.
|
|\ \ \ \
| |/ / /
|/| | | |
Make sure we use the `C` locale for `regcomp` on macOS.
|
|/ / / |
|
|\ \ \
| | | |
| | | | |
Travis Mac SSH key issues
|