Commit Briefs

5007bd0d88 Thomas Adam

portable: linux: add libmd (ta/libmd-fixes)

On some systems libmd isn't explicitly implied, so detect this via pkg-config at configure time. Problem reported by @stsp


9aa08a9a8d Thomas Adam

zap stale tog regress make target spotted by stsp@


51b7e1c33f Thomas Adam

tog: plug tog_view structure leak on open_*_view() error

ok stsp@


3682a04dfa Thomas Adam

remove outdated information from README


1d98034bec Thomas Adam

release tog_io regress mock term resources in main()

ok stsp@


ffa5bcf7b7 Thomas Adam

update regress test info in README


557d336579 Thomas Adam

make tog regress run with pledge active

ok jamsek


8641a33271 Thomas Adam

when aborting rebase/histedit/merge, unlink files added by merged changes

Otherwise we leave unversioned files behind in the work tree which may interfere with new attempts to rebase or merge the changes again. Problem found by + ok naddy@


4d0b6596a3 Thomas Adam

got: flush stdout before printing the error in main()

Since standard error is unbuffered, it could happen that the error string is printed immediately while the output from the subcommand is stuck in a buffer and written later. So flush() standard output before printing the error message. Problem reported by naddy@, ok stsp@


6f97aa8325 Thomas Adam

style nits from op@, thanks!


f883642501 Thomas Adam

make 'got revert' and 'got rm' work on non-existent directories

problem found by robert@ ok jamsek, op


25a102ed18 Thomas Adam

fix rebase/histedit -a leaving some files on the temporary branch

The commands 'got rebase -a' and 'got histedit -a' were checking out files from the wrong commit. Make them check files out from the commit we are switching the work tree to, as intended. Avoids spurious merge conflicts when the work tree is later used for another rebase operation. It also makes 'got update' right after 'rebase -a' a no-op, as it should be. Problem found by naddy@ while rebasing jca's llvm15 branch ok op, jamsek earlier version


b36a977475 Thomas Adam

update the base commit ID of unmodified files if the blob ID matches

This avoids having to run 'got update' after operations which run checkout_files() and where a file happens to have the same blob ID but its base commit differs from the commit we are updating to. Found while investigating a bug report by naddy@ ok op, jamsek (earlier version)


b85a34968b Thomas Adam

tog: implement automated test harness

Add framework for scripting tog tests by capturing screen dumps to compare with expected output. Includes some preliminary log view tests but lots more tests are needed to cover diff, blame, tree, ref, and help views. ok stsp@


d95864cd5d Thomas Adam

make gotd/gitwrapper start up even if a repository is missing on disk

This should result in more useful behaviour when gitwrapper runs and repositories listed in gotd.conf do not yet exist or do no longer exist.


f9542c24c5 Thomas Adam

fix spurious empty packfile error from gotd when rewinding a branch

ok op@


e9e7947043 Thomas Adam

consistently close the struct repository on every cmd_*()

Spotted while looking for leaks using Otto' malloc() new leaks detection. Harmless in practice since we just forgot to call got_repo_close() when terminating in some cmd_*() functions, but still a leak. ok stsp@


991857c7d6 Thomas Adam

free fileindex entry upon add_entry() failure

Very unlikely (an occurrence of it would mean that got produced an invalid fileindex) and harmless anyway since we would just terminate, but a leak is still a leak. ok stsp@


3f0853b845 Thomas Adam

grammar fix for parse.y error message


57b6056a5b Thomas Adam

reject overlapping protected branch vs. tag namespaces

ok op@


ffc797f3cc Thomas Adam

gotd.conf: free STRINGS in all code paths

ok stsp@


f041f55f27 Thomas Adam

update TODO list


a4435ef028 Thomas Adam

gotd.conf: fix memleak in `protect' error path and disallow dups too

ok stsp@


6d7eb4f7d1 Thomas Adam

add support for protecting references against 'got send -f' to gotd

ok op@


1e73031b5b Thomas Adam

unfold line