Commit Briefs

20c6bdb6df Thomas Adam

plug a small memleak on error in got_pack_create()


b0d7d6cb5f Thomas Adam

avoid malloc/free for duplicate check in got_pathlists_insert()

ok op@


ff47022487 Thomas Adam

revert "Skip poll(2) if an imsgbuf has a non-empty read buffer"

imsg_read() will call recvmsg() on the file descriptor regardless of the read buffer's state, so we should ensure that data is ready. The read buffer is used by imsg_get(), not imsg_read(). We already call imsg_get() before imsg_read(), and call the latter only if imsg_get() returns zero.




06de99ad9d Thomas Adam

batch up tree entries in imsg instead of sending one imsg per tree entry

This speeds up loading of trees significantly. ok op@


78e7b7b857 Thomas Adam

parse tree entries into an array instead of a pathlist

Avoids some extra malloc/free in a performance-critical path. ok op@





8767bb9409 Thomas Adam

rework logic in got_privsep_recv_tree() to avoid an ugly 'goto'

no functional change


bafaf650cf Thomas Adam

got patch: switch from fseek() to fseeko(), use unary minus while here

ok op


88c260f4a8 Thomas Adam

got patch: fail when reading empty hunks



0edd68a505 Thomas Adam

portable: set next version


983d44d72c Thomas Adam

CHANGELOG for 0.70 (tags/0.70)

Update the CHANGELOG for the 0.70 release.


82f9484cc5 Thomas Adam

portable: include sha1.h portably

Don't directly include sha1.h as this isn't always in the same location across systems.


0c503cc75a Thomas Adam

got patch: resolve paths from the current working directory

this allow to apply patches from subdirectories of the work tree root. Prodded by naddy@, ok stsp@.


204b0a79ec Thomas Adam

bump version number


21a6bfd076 Thomas Adam

CHANGES for 0.70


d93dda9a3b Thomas Adam

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

with a fix from + ok op@


ae2b0251ce Thomas Adam

fix load_object_ids() such that packing tags works if zero commits are packed

reported by jrick and op



7d0d492086 Thomas Adam

run the search for deltas to reuse in got-read-pack

This significantly speeds up the deltification step of packing by avoiding imsg traffic. gotadmin no longer requests individual raw deltas from got-read-pack to check whether it can reuse them. Instead, got-read-pack obtains a list of objects we want to pack, and hands back the list of all deltas in its pack file which can be reused. Messages are now batched such that imsg buffers are filled as much as possible. Another advantage is that deltas we are not going to reuse will no longer be written to the delta cache file, saving disk space. Before this patch, any raw delta candidate was written to the delta cache file by got-read-pack, and the decision whether to reuse the delta happened afterwards in the gotadmin process. Code for reading individual raw deltas is now unused and could be removed at some point. ok op@


7afbdbadac Thomas Adam

avoid 'remove unused' loop by storing excluded objects in a separate set

ok op@