|   | 4b752015 | 2022-06-30T21:35:28 |  | switch 'tog diff' and 'tog blame' to Myers diff for speed
Make the choice of diff algorithm configurable by diff API users.
The got and gotweb programs keep using Patience diffs which are
prettier than Myers. But tog should be as fast as possible since
it is being used interactively. If performance of Patience diff
gets improved later we can consider switching tog back over to it.
ok tracey jamsek | 
            
              |   | 49d4a017 | 2022-06-30T10:43:37 |  | move more opentemp out of diffreg.c
ok tracey | 
            
              |   | f9d37699 | 2022-06-28T20:33:41 |  | move got_opentempfd() out of lib/diff.c again
ok tracey | 
            
              |   | eb81bc23 | 2022-06-28T13:27:12 |  | move got_opentempfd out of open_blob. ok stsp@ | 
            
              |   | 336075a4 | 2022-06-25T09:22:02 |  | build with -Wmissing-prototypes
ok stsp@ | 
            
              |   | 9fdde394 | 2022-06-04T14:13:46 |  | 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@ | 
            
              |   | b72706c3 | 2022-06-01T05:08:20 |  | move creation of tempfiles outside of lib/diff.c
ok tracey | 
            
              |   | 4bcdc895 | 2022-05-17T17:35:17 |  | refactor got_patch / got_worktree_patch_complete
let got_patch own fileindex_path and call got_worktree_patch_complete
only if got_wokrtree_patch_prepare hasn't failed.
suggested by stsp@ | 
            
              |   | f2dd7807 | 2022-05-17T13:28:02 |  | got patch: avoid open/sync/close the fileindex over and over again
Instead of flushing the fileindex after every patch in the patchfile
just reuse the same fileindex and sync it only at the end of the patch
operation.  This speeds up 'got patch' on large repositories by quite a
lot. | 
            
              |   | a05fb460 | 2022-04-23T07:54:56 |  | don't pass relative paths to get_file_status | 
            
              |   | a44927cc | 2022-04-07T12:57:31 |  | stop relying on commit cache for good performance of got_object_id_by_path()
Instead of internally opening and closing the same commit object over and
over again, require callers to pass an open commit object in. Avoids an
inherent dependency on the commit object cache for reasonable performance.
ok op@ | 
            
              |   | 78f5ac24 | 2022-03-19T15:06:37 |  | move got_patch file status checking in worktree.c
check_file_status used got_worktree_status to check if the file was in
an allowed state, but it's wrong since the callback is not invoked on
unchanged files.
While here also fix a relate bug: unlink(newpath) is in the wrong spot
and ends up removing files even when it shouldn't, so move it early in
the got_worktree_schedule_* error handling.
Finally, update the appropriate test case.  It was passing before
because got_worktree_schedule_add returned GOT_ERR_FILE_STATUS, not
because check_file_status failed.
ok stsp@ | 
            
              |   | a84c0d30 | 2022-03-12T21:30:23 |  | fix 'got status' with an obstructed file given as argument; found by Omar | 
            
              |   | 916237f3 | 2022-02-11T22:42:50 |  | fix 'got diff' on files which match an ignore pattern; found by Omar Polo | 
            
              |   | 9b4603c0 | 2022-01-31T16:27:14 |  | improve 'got add' error message if file does not exist; reported by Timo Myyrä
ok tracey | 
            
              |   | 692bdcc4 | 2022-01-25T22:48:26 |  | make 'got rm' report an "unexpected status" error for unversioned files
ok millert@ | 
            
              |   | 4e12cd97 | 2022-01-25T22:48:26 |  | make 'got rm' behave like rm(1) for paths found missing on disk
ok millert@ | 
            
              |   | 969ea98d | 2022-01-24T08:04:11 |  | remove non-reachable 'return NULL' statement from report_single_file_status() | 
            
              |   | 72840534 | 2022-01-19T12:04:58 |  | compress delta data from delta_cache directly into pack file | 
            
              |   | c0df5966 | 2021-12-31T09:33:01 |  | wrap overlong lines | 
            
              |   | e7ae0baf | 2021-12-31T09:11:22 |  | add O_CLOEXEC (close-on-exec) to openat(2) calls
suggested by millert
ok thomas_adam | 
            
              |   | 8bd0cdad | 2021-12-31T09:11:21 |  | add O_CLOEXEC (close-on-exec) flag to open(2) calls
suggested by millert
ok thomas_adam | 
            
              |   | 00fe21f2 | 2021-12-31T09:11:21 |  | add "e" (close-on-exec) flag to fopen(3) calls
suggested by millert
ok thomas_adam | 
            
              |   | 0e039681 | 2021-11-15T17:00:36 |  | preverse binary files during updates and merges | 
            
              |   | 7d69d862 | 2021-11-15T15:18:40 |  | let gotadmin find the repository automatically if invoked in a work tree
Move a small amount of code from worktree.c to a new file worktree_open.c,
which contains everything required to open and close a work tree and inspect
some of its basic parameters. This can be used by gotadmin.
ok tracey | 
            
              |   | 62da3196 | 2021-10-01T13:58:31 |  | skip ignored directories during 'got status' disk crawl | 
            
              |   | 0ff8d236 | 2021-09-28T06:59:08 |  | show commit progress output when 'got merge -c' is used
Otherwise no progress output is shown at all with this command.
Commit progress output will also display any additional changes
which resulted from conflict resolution.
ok millert@ | 
            
              |   | 5c02d2a5 | 2021-09-26T17:40:10 |  | for portability, handle errno variations upon open(2) failure with O_NOFOLLOW
Problem pointed out by naddy for FreeBSD -portable.
Discussed with millert, thomas adam, and naddy. | 
            
              |   | 5267b9e4 | 2021-09-26T11:41:40 |  | allow bad symlinks to survive a merge
Commands which perform merges will now install bad symlinks as symlinks
in the work tree, instead of creating them as regular files. This means
bad symlinks committed with 'got commit -S' (or Git) will be preserved.
The decision to introduce a bad symlink is done at commit-time and
merges should not forcefully reverse this decision.
The cherrypick and backout commands require a manual commit step, and
a merge result with bad symlinks will require use of 'got commit -S'.
Additional testing by thomas adam | 
            
              |   | f6764181 | 2021-09-24T21:52:59 |  | fix 'got update' of an added + obstructed file
When 'got update' tried to add a new file to the work tree and this
file was obstructed by, say, a directory on disk, the update failed:
  $ got update
  ?  new
  got: new: Is a directory
  $
And the work tree was not updated.
With this commit this situation is properly detected as an obstruction
and the update succeeds:
  $ got update
  ~  new
  Updated to refs/heads/master: c1f85b4938dc4c668a88f13df2b98a520fc077cc
  File paths obstructed by a non-regular file: 1
  $
Extend a corresponding test case to cover this issue.
ok tracey | 
            
              |   | 793fcac3 | 2021-09-24T20:14:09 |  | plug memory leak in got_worktree_merge_in_progress(); spotted by tracey | 
            
              |   | f259c4c1 | 2021-09-24T19:55:02 |  | add a 'got merge' command for creating merge commits
Additional testing by Thomas Adam.
ok tracey | 
            
              |   | abc59930 | 2021-09-05T19:41:03 |  | indentation fixes | 
            
              |   | 69de9dd4 | 2021-09-03T09:02:06 |  | limit checks for merge conflicts to files affected by the merge
Performance problems reported by naddy | 
            
              |   | 5546d466 | 2021-09-02T19:39:14 |  | plug a memory leak in check_merge_ok() | 
            
              |   | 243a13f5 | 2021-09-02T19:13:50 |  | fix bogus error when 'got cherrypick' merges changes into a locally added file
reported by + ok naddy | 
            
              |   | 6c13b005 | 2021-09-02T13:57:34 |  | Update comment regarding the merged_paths list used by rebase and histedit
with insight I obtained while trying to make this idea work, and failing... | 
            
              |   | dae2a678 | 2021-09-01T20:31:46 |  | backout 7280143edc2d689b1f57d5a46d376e48cdae64a2; not needed after all | 
            
              |   | 0e33f8e0 | 2021-09-01T14:34:33 |  | disable ignore lists during status walks used by rebase and histedit
Fixes rebase of gotwebd branch which added a new directory which is
also matched by .gitignore rules on the branch. | 
            
              |   | 7280143e | 2021-09-01T11:56:31 |  | refactor collect_commitables() to make it easier to call from elsewhere later | 
            
              |   | ff56836b | 2021-07-08T10:30:10 |  | Make 'got add' always require the -I option in order to add ignored files. | 
            
              |   | 2c41dce7 | 2021-06-27T15:30:08 |  | allow obstructed files skipped by 'got update' to be updated again | 
            
              |   | a769b60b | 2021-06-27T09:22:52 |  | fix a bug where files skipped by 'got update' could not be updated again
ok semarie@ | 
            
              |   | dbdddfee | 2021-06-23T20:48:35 |  | switch from SIMPLEQ to equivalent STAILQ macros
The singly-linked tail queue macros were added to OpenBSD 6.9 and
are more widely available on other systems.
ok stsp | 
            
              |   | f6343036 | 2021-06-22T20:00:44 |  | new -I option for 'got status' to show files which match an ignore pattern | 
            
              |   | 1c4cdd89 | 2021-06-20T21:07:54 |  | fix bogus 'permission denied' error when a file at work tree root is removed
ok naddy | 
            
              |   | fdf3c2d3 | 2021-06-17T09:01:05 |  | use Patience diff for merging during cherrypick/backout/histedit/rebase
This has been shown to prevent mis-merges in some cases. It's probably
not a final solution. We should look at what Git's "recursive merge"
is doing and implement something similar.
Keep using Myers during update/unstage. The advantage of Myers is that
it produces smaller conflict chunks, and there are no known cases of
mis-merges which affect update/unstage. | 
            
              |   | 1d0f4054 | 2021-06-17T08:56:43 |  | check for close(2) error in got_repo_close() and propagate errors up
ok tracey | 
            
              |   | 54d5be07 | 2021-06-03T13:12:58 |  | fix unrelated changes being merged by got cherrypick/backout/rebase/histedit
This was a long-standing and very annoying bug.
The two xfail tests in the cherrypick test suite are passing now. | 
            
              |   | 1af628f4 | 2021-06-03T12:38:42 |  | switch merge_file_cb() to using merge_file() instead of merge_blob() | 
            
              |   | eec2f5a9 | 2021-06-03T12:14:35 |  | decouple merge_file() parameters for 2nd derived version and merge target file | 
            
              |   | dc082d4a | 2021-06-03T11:57:58 |  | in merge_file(), remove allocation of a base_path which is unused | 
            
              |   | 07bb0f93 | 2021-06-02T09:26:42 |  | move merge_file()'s f_deriv parameter next to the f_orig parameter | 
            
              |   | db590691 | 2021-06-02T09:24:51 |  | make merge_file() accept FILEs instead of paths for orig and deriv inputs | 
            
              |   | 67a66647 | 2021-05-31T09:20:56 |  | refactor merge_file() such that it no longer requires a blob object parameter | 
            
              |   | c6e8a826 | 2021-04-05T17:55:12 |  | do not update symlinks which are already up-to-date
This fixes spurious 'U' notifications for symlinks during 'got update'
that occurred even when the work tree was fully up-to-date.
Observed on a work tree of the FreeBSD src repo and reproduced in our
test suite by adding a no-op update at the end of a test which deals
with updating symlinks. | 
            
              |   | 0f58026f | 2021-04-05T17:51:07 |  | add a missing STATUS_EXISTS notification in update_blob() | 
            
              |   | 4cc1f028 | 2021-03-23T15:01:29 |  | fix use of an uninitialized stat buffer during work tree status crawl
found by naddy
ok naddy jrick | 
            
              |   | e600f124 | 2021-03-21T19:09:35 |  | ensure that old commits remain referenced after rebase and histedit
Create automatic "backup" references which ensure that objects from
the pre-rebase or pre-histedit state remain in the repository.
A new -l option for 'got rebase' and 'got histedit' lists old commits.
This makes it easier to recover from botched rebase or histedit operations.
Removal of such objects currently requires got ref -d and git-gc.
This will be made more convenient in the future.
testing and ok jrick | 
            
              |   | 6e210706 | 2021-01-22T23:49:46 |  | implicitly mark all files in work tree as up-to-date after 'got integrate'
Avoids having to run 'got update' for no good reason after 'got integrate'.
The same change was made recently for both rebase and histedit in
commit a615e0e7796ea1103a6e0d4b5dbb6134597886660 and we forgot about histedit. | 
            
              |   | 60e40e95 | 2021-01-22T21:53:05 |  | close file handles before freeing other things in got_worktree_close()
The work tree's path needs to be valid while constructing error messages. | 
            
              |   | e7abd6b6 | 2021-01-22T21:47:37 |  | fix missing close(2) error check in got_worktree_close() | 
            
              |   | 08578a35 | 2021-01-22T11:05:05 |  | make close(2) failure checks consistent; check 'close() == -1' everywhere
ok millert, naddy | 
            
              |   | 56b63ca4 | 2021-01-22T11:04:47 |  | make fclose(3) failure checks consistent; check 'fclose() == EOF' everywhere
ok millert, naddy | 
            
              |   | a6b21eef | 2021-01-21T19:10:08 |  | add missing braces around multi-line if-statement in got_worktree_close() | 
            
              |   | a06ff56f | 2021-01-21T18:33:50 |  | fix a use after free()
ok jrick stsp | 
            
              |   | 9bdd68dd | 2021-01-02T20:46:01 |  | replace fparseln(3) with getline(3), for better portability
ok stsp | 
            
              |   | a615e0e7 | 2020-12-16T00:08:58 |  | implicitly mark all files in work tree as up-to-date after rebase/histedit
This should always be correct, since rebase and histedit start out with a
clean and single-base-commit worktree, and end up committing all changes
across the entire work tree when they are successful.
tested by jrick and myself | 
            
              |   | 437adc9d | 2020-12-10T08:29:04 |  | add fd field to got_worktree, modify got_fileindex_entry_update to use fds
These changes are intended to make got more compatible
with FreeBSD's Capsicum.
ok stsp | 
            
              |   | 64453f7e | 2020-11-21T13:35:00 |  | handle binary files in got/tog diff commands; add -a options to force text | 
            
              |   | fe621944 | 2020-11-10T22:54:37 |  | merge new diff implementation from the git.gameoftrees.org diff.git repository
This new diff implementation was started by Neels Hofmeyr during the u2k20
hackathon and now replaces diffreg.c code lifted from the OpenBSD base system.
The integration of this code into Got was done by me.
Got now uses the patience diff algorithm by default.
The diff.git repository will remain the primary repository for the diff code,
which already compiles and runs on other operating systems such as Linux.
Any fixes and improvements for files inherited from the diff.git repository
should be written against that repository and synced to got.git afterwards. | 
            
              |   | f6d8c0ac | 2020-11-09T16:04:18 |  | fix replacing symlinks with files
And add a test case which verifies that the inverse also works,
i.e. a symlink being replaced with a regular file.
problem reported and fix tested by jrick | 
            
              |   | 63df146d | 2020-11-09T16:03:35 |  | fix missing unlink(tmppath) in error cases of install_blob() | 
            
              |   | 2ac8aa02 | 2020-11-09T16:02:12 |  | clear staged file type in file index entries whenever staged status is cleared | 
            
              |   | 727173c3 | 2020-11-06T00:20:05 |  | initialize sb.st_mode after stat(2) failure in got_worktree_resolve_path() | 
            
              |   | 01740607 | 2020-11-04T20:18:53 |  | avoid got_repo_map_path() in 'got blame'
'got blame' does not need access to the work tree. So far the work tree
was completely hidden with unveil(). We must now expose the work tree
while resolving the path, so unveil() calls are shuffled around slightly.
Failing realpath() calls would mess with path resolution otherwise.
There's a bug in got_worktree_resolve_path() where it failed to canonicalize
a path constructed from a user-specified path that does not exist on disk.
Note that this path falls into strncmp() a few lines down. I am fixing this
by adding canonicalization. Generally, joining paths with asprintf() and
comparing paths with strncmp() is fragile. A more general solution might be
needed but I am leaving that for another day.
ok naddy | 
            
              |   | 3818e3c4 | 2020-11-01T16:28:46 |  | convert all remaining instances of chmod(2) to fchmod(2)
ok stsp | 
            
              |   | 62d463ca | 2020-10-20T22:43:59 |  | indentation fixes | 
            
              |   | 2513f20a | 2020-10-20T21:09:01 |  | plug memory leaks in error paths; found by naddy | 
            
              |   | 20a2ad1c | 2020-10-20T21:09:01 |  | use got_path_dirname() in schedule_for_deletion(); avoids const dirname(3)
ok naddy | 
            
              |   | fddefe3b | 2020-10-20T21:09:01 |  | use got_path_dirname() in remove_ondisk_file(); avoids const dirname(3)
ok naddy | 
            
              |   | f5375317 | 2020-10-20T21:09:01 |  | use got_path_dirname() in install_blob() to avoid const dirname(3)
ok naddy | 
            
              |   | f4994adc | 2020-10-20T21:09:01 |  | use got_path_dirname() in install_symlink() to avoid const dirname(3)
ok naddy | 
            
              |   | ce031e9e | 2020-10-20T21:09:01 |  | use got_path_dirname() in is_bad_symlink_target()
ok naddy | 
            
              |   | ed6b5030 | 2020-10-20T21:09:01 |  | use got_path_dirname() in merge_blob() instead of assuming const dirname(3)
ok naddy | 
            
              |   | 3524bbf9 | 2020-10-20T21:09:01 |  | make merge_file() use got_path_dirname() instead of assuming const dirname(3)
ok naddy | 
            
              |   | aedea96d | 2020-10-20T21:09:01 |  | adapt got_open_worktree to non-const dirname(3)
ok naddy | 
            
              |   | d34b633e | 2020-10-19T23:14:59 |  | use got_path_basename() in match_deleted_or_modified_ct()
ok millert | 
            
              |   | 102b254e | 2020-10-19T23:14:59 |  | switch to got_path_basename() in alloc_added_blob_tree_entry()
ok millert | 
            
              |   | 1233e6b6 | 2020-10-19T23:14:59 |  | switch to got_path_basename in revert_file
ok millert | 
            
              |   | 4a26d3f8 | 2020-10-07T22:37:48 |  | fix a bug where 'got status' showed an unchanged empty file as changed | 
            
              |   | 0a22ca1a | 2020-09-23T22:31:00 |  | make 'got histedit' collapse folded add+delete operations into a no-op
If a merged commit wants to delete a locally added file, and this locally
added file matches the content which was deleted in the commit being merged,
we can go ahead with the deletion because there is no risk of data loss.
fixes the histedit problem reported by jrick on freenode | 
            
              |   | 50b0790e | 2020-09-11T17:04:57 |  | add per-worktree got.conf(5) file in the .got directory; ok millert | 
            
              |   | 0823ffc2 | 2020-09-10T20:44:40 |  | use modern POSIX timestamp fields in struct stat
ok stsp | 
            
              |   | 766841c2 | 2020-08-13T19:12:57 |  | add -s option to 'got remove' which deletes files in a particular status
This makes it easy to deal with files that were deleted from disk by external
tooling which modified the work tree. Such files are left in missing (!)
status and can now be marked for deletion in bulk via 'got rm -s\! -R .'
For consistency, modified (M) files can now be removed with 'got rm -s M'
which implies 'got rm -f'.
Prompted by feedback from krw@ | 
            
              |   | f2b0a8b0 | 2020-07-31T12:54:34 |  | fix committing file additions from a work tree with a path prefix
New files were added under the wrong tree in the repository if the work
tree has a path prefix. Fix this problem and catch it in the existing
commit_with_path_prefix regression test. | 
            
              |   | 69d57f3d | 2020-07-31T11:19:29 |  | fix spurious 'got cherrypick' error with a path prefix and an empty tree
If the work tree's path prefix does not exist in the first of the two
trees, then 'got cherrypick' failed with "no such entry found in tree".
But this is a legitimate situation, as shown in the new test added here.
The first tree could be the empty tree, for example, which should result
in 'got cherrypick' adding all files from the second tree instead of
complaining about a non-existent path-prefix directory in the first tree. | 
            
              |   | b66cd6f3 | 2020-07-31T10:33:34 |  | display more context info in "no such entry found in tree" error messages | 
            
              |   | b2118c49 | 2020-07-28T20:17:19 |  | Add a 'got info' command which displays work tree meta-data.
Remove the alias 'got in' for 'got init'.
The 'in' alias was too close to either 'init' or 'info'.
ok tracey, millert | 
            
              |   | 283102fc | 2020-07-23T14:22:41 |  | remove the symlink conflict header feature; it causes noise for little benefit |