Commit Briefs

e2f45bc4f4 Thomas Adam

add a missing .Pp to got.1


a7e64c3f82 Thomas Adam

plug a memory leak in show_change(), line was leaked


2f7ada2061 Thomas Adam

add one-line output mode to got log with -s flag

-s for short. Moves log search to -S. Patch by Evan Silberman


3dfecf3ec1 Thomas Adam

revert object enumeration in got-read-pack for now; needs more work

This implementation marked commits and trees as enumerated before all trees which they depend on were enumerated. This behaviour leads to incomplete pack files when a tree is only partially packed and got-read-pack hits a missing tree entry as a result. The algorithm must be reworked such that packed leave nodes are marked enumerated first, then bubble-up. Found by op@


0c0d91c226 Thomas Adam

in enumeration_request(), use the correct index for tagged commit objects

Fixes an error where got-read-pack errors out with "bad object data" during 'got send' because we ended up handing a tag object to the commit object parser.


96b72a8e59 Thomas Adam

free id and path in load_packed_tree_ids() on error, else they would leak

pointed out by op@


c8fa56b383 Thomas Adam

fix wrong line wrap; pointed out by op@



132807502f Thomas Adam

implement object enumeration support in got-read-pack

ok op@


f289c82c68 Thomas Adam

got stage: implicitly unstage when staging the reverse of the staged diff

otherwise we end up with a staged empty edit for that file. ok stsp@



a5061f770a Thomas Adam

convert delta cache to a hash table

This approach uses more memory but is much faster. To offset the additional memory usage somewhat the cache now stores very small deltas only. However, overall memory usage goes up. Hopefully we will find a way to reduce this later. ok op@



4e2bdb0dad Thomas Adam

don't pass $ret to test_done on failure when it's known to be zero

Otherwise the test directory it's not left in place; ok tracey@


9394843506 Thomas Adam

properly swap cached struct pack array elements in got_repo_cache_pack()

Avoids clobbering open files for delta base/accumulation, leaking file descriptors, and triggering errors from close(2) during got_repo_close() as we try to close the same file descriptor more than once.


a0f32f336e Thomas Adam

move creation of tempfiles outside of lib/diff.c

ok tracey


265bd9c38d Thomas Adam

map delta cache file into memory if possible while writing a pack file

with a fix from + ok op@


89fe1c42b3 Thomas Adam

portable: fix-up sha1.h include

-portable doesn't need this directly.


296152d1ca Thomas Adam

tog: override SIGTERM and SIGINT handlers to avoid ncurses cleanup() handler

ok thomas


6cb2eb6e36 Thomas Adam

reduce GOT_PACK_CACHE_SIZE to 32, otherwise it uses too many open files

found by tracey


cf032c44a2 Thomas Adam

ensure that all open basefd/accumfd get closed in got_repo_close()

found by tracey


bfb5ee0b73 Thomas Adam

open temporary files needed for delta application in got_repo_open()

This prepares for callers of got_repo_open() that cannot afford to open files in /tmp, such as gotwebd. In a follow-up change, we could ask such callers to pass in the required amount of open temporary files. One consequence is that got_repo_open() now requires the "cpath" pledge promise. Add the "cpath" promise to affected callers and remove it once the repository has been opened. ok tracey




13eb256cde Thomas Adam

fix a bug in findwixt() which caused pack files with missing parent commits

The 'nskip' variable is supposed to reflect commits which are waiting on the queue and have the 'skip' color. Only increment 'nskip' when adding such commits to the queue. Problem observed with got send -T and a tag pointing to a deleted branch. Test to reproduce the bug written by op@.