|   | 5c5d88bf | 2022-07-03T21:59:10 |  | remove duplicate test_parseargs call
spotted by op@ | 
            
              |   | a82759bb | 2022-07-03T21:57:37 |  | fix echo/printf order and actually run the test | 
            
              |   | 2c0a0d66 | 2022-07-03T21:46:09 |  | whitespace fix | 
            
              |   | 91d845ad | 2022-07-03T21:44:01 |  | fix tag signing when the key file does not exist
This should fail without creating any tag.  Before, ssh-keygen(1)
would print an error to stderr, but got would create an unsigned tag.
ok op@ | 
            
              |   | 26e6f38e | 2022-07-03T11:32:59 |  | rename got.conf(5) mirror-references to mirror_references for consistency
Existing configuration files will keep working for now since the old name
with dashes is still recognized by the config parser. | 
            
              |   | f1bf60d1 | 2022-07-03T11:27:02 |  | rename got.conf(5) fetch-all-branches to fetch_all_branches for consistency
Existing configuration files will keep working for now since the old name
with dashes is still recognized by the config parser. | 
            
              |   | 4d5ee956 | 2022-07-02T21:27:21 |  | create and verify tags signed by SSH keys
This adds a new -s flag to 'got tag' that specifies the signer
identity (for example, a key file) of the tagger.  The tag object will
include a signature that validates each of the tag object headers and
the tag message.
Verifying these signed tags requires maintaining an allowed signers
file which maps signer identities (i.e. the email address of the
tagger) to SSH public keys.  See ssh-keygen(1) for more details of the
allowed signers file.  After creating this file and providing the path
to it in got.conf(5) using the allowed_signers option, tags may be
verified using with 'got tag -V tag_name'.  The return code will be
non-zero if a signature fails to verify.
ok stsp@ | 
            
              |   | a92a2042 | 2022-07-02T21:16:13 |  | got patch: handle mangled whitespaces
This makes 'got patch' try to ignore whitespaces when trying to match a
hunk.
Discused with and ok stsp@ | 
            
              |   | 5dffb1a1 | 2022-07-02T21:08:31 |  | got patch: don't loose the x bit when merging with diff3
This fixes a regression introduced with the diff3 merge: files merged
this way have their permissions resetted after patch.
The issue is due the fact that patch_file looks at a temporary files
and not at the original "old file".
Reported by and ok stsp@ | 
            
              |   | f5b0315f | 2022-07-02T19:31:41 |  | aesthetic: rename regress to test_patch_rm_file
drop the "simple" part, there's no "complex" way of removing files. | 
            
              |   | ed2ff8b9 | 2022-07-02T19:30:36 |  | augment test_patch_add_line
Try to create a file with more than one line, it would have catched an
issue with my wip diff for ignore whitespaces in got patch.
While here rename the function to drop "simple". | 
            
              |   | acf749fc | 2022-07-02T13:56:21 |  | refactor the patch parser
Introduce a patch_start routine that finds the next "diff" header (if
there is one); the idea is to persist some state (commit id and wether
it's a "git diff") while processing the content of the diff.  It's
needed because in the case of 'got diff' some information like the
commit id are only present once at the beginning.
As a consequence, the patch parser becomes slightly more robust
(concatenating diffs produced by different means shouldn't confuse it
anymore) and drops the support for "old" got diffs, the ones previous
the introduction of the "commit -/+" header.
ok tracey@ | 
            
              |   | 8c4a6db8 | 2022-06-29T14:58:58 |  | make it possible to show just one tag with 'got tag -l'
suggested by jrick
ok jrick jamsek | 
            
              |   | db0dfdd7 | 2022-06-27T18:47:02 |  | got patch: handle git-style diffs for the 3-way merge too
tweak and ok stsp@ | 
            
              |   | 58e31a80 | 2022-06-27T18:47:02 |  | build with -Wwrite-strings
Throwing this into the mix for a while, we can always get rid of it
again if it becomes annoying.  No objections from stsp@ | 
            
              |   | 8469d821 | 2022-06-25T09:25:07 |  | always show commit or tree IDs in diff header, in order to help 'got patch'
The idea is that got patch can simply look for a line such as:
  commit - abcde1234567...
to find the merge base commit ID to show in diff3 conflict markers.
got log -p now displays commit IDs in its diff header, instead ofl
tree or blob IDs.
ok op@ | 
            
              |   | 336075a4 | 2022-06-25T09:22:02 |  | build with -Wmissing-prototypes
ok stsp@ | 
            
              |   | 9802c41c | 2022-06-21T16:52:34 |  | got patch: use status G for merged files (and document it)
Suggested by stsp@.  This makes possible to tell if 'got patch' used a
merge-base from the repository for the 3-way merge or did a simple
search/replace operation.
While here update the tests to look for the 'G' status and the manpage,
which was also missing the documentation for the 'C' status in got
patch.
ok stsp@ | 
            
              |   | dbc68eed | 2022-06-21T16:52:34 |  | got patch: ignore blobs not found
since diffs are often enclosed in other formats (e.g. emails) we might
parse something and think it's a blob id when it's not.  This should
already happens, but apply_patch is looking for the wrong error due to a
leftover from previous attempts.  Reported by stsp@
while here tweak the test_patch_merge_unknown_blob to also try with a
dummy commit id, as now got-read-patch requires it in order to consider
a blob id.
ok stsp@ | 
            
              |   | d8b5af43 | 2022-06-19T11:51:33 |  | use the commitid in the patch diff3 conflict header
suggested by and ok stsp@ | 
            
              |   | 55e9459f | 2022-06-19T11:51:32 |  | got patch: use diff3 to merge the changes
Parse the "blob -" metadata in diffs produced by 'got diff' and use the
original file for patching.  Then, use the diff3 with the current
version of the file to merge the differences.
This solves many failures automagically or at least turns them into a
conflict.
ok/improvements stsp@ | 
            
              |   | 783ffc01 | 2022-06-13T09:37:38 |  | adjust expected test output after got log -s changes
ok op@ | 
            
              |   | c1c775eb | 2022-06-08T09:16:08 |  | add one-line output mode to got log with -s flag
-s for short. Moves log search to -S.
Patch by Evan Silberman | 
            
              |   | 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@ | 
            
              |   | 84246752 | 2022-06-03T20:26:49 |  | set `ret' in a few places where it was forgotten; ok tracey@ | 
            
              |   | a19f439c | 2022-06-03T20:26:48 |  | 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@ | 
            
              |   | ce2bf7b7 | 2022-05-29T17:51:33 |  | 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@. | 
            
              |   | d6a28ffe | 2022-05-20T21:21:42 |  | use random seeds for murmurhash2
change the three hardcoded seeds to fresh ones generated on demand via
arc4random.  Suggested/fixed by and ok stsp@ | 
            
              |   | be33dff7 | 2022-05-13T15:28:04 |  | got patch: fail when reading empty hunks | 
            
              |   | cab5dc8b | 2022-05-10T11:22:34 |  | hook cmdline send tests up for 'make regress', this was forgotten | 
            
              |   | 4379a9aa | 2022-05-02T08:38:43 |  | got patch: handle git-style rename diffs
extend the support for git-style diffs to include the "pure rename"
case, i.e. when a file is renamed without any edits.
ok stsp@ | 
            
              |   | bad961bf | 2022-04-23T10:39:47 |  | got patch: allow to reverse a patch
add a flag to got_patch to reverse a patch before applying and the -R
flag for `got patch'.
ok stsp@ | 
            
              |   | 15e1bda6 | 2022-04-23T10:26:47 |  | test `got patch' vs path-prefixes, relative paths and strip
reminded by and 'looks fine' to stsp@ | 
            
              |   | f1d6cebb | 2022-04-23T09:33:14 |  | typos | 
            
              |   | ed3bff83 | 2022-04-23T07:56:18 |  | 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@. | 
            
              |   | 3313bcd8 | 2022-04-19T16:57:25 |  | delete trailing whitespaces | 
            
              |   | c036d108 | 2022-04-15T18:14:01 |  | redirect jot(1) output instead of looping over it; ok tb@ | 
            
              |   | 20e420c8 | 2022-04-11T13:33:54 |  | add a -q (quiet) option to 'gotadmin pack' | 
            
              |   | 29e0594f | 2022-04-09T17:34:51 |  | make gotadmin pack -x option work with tag arguments | 
            
              |   | 67ba6161 | 2022-04-08T09:14:02 |  | leave work tree in a usable state after 'got rebase' fails path-prefix checks
reported by naddy | 
            
              |   | 9d6cabd5 | 2022-04-07T09:28:59 |  | got patch: allow to strip path components
Move some bits from the libexec helper to the main process so we know if
the patch was generated by git or not and finally document the automatic
stripping of a/ and b/ prefixes added by git-diff(1).
ok stsp@ | 
            
              |   | 49c543a6 | 2022-03-31T20:41:38 |  | use test(1) -eq and -ne to compare integers, and reduce quoting
This brings the rest of the regression test scripts in line with
patch.sh. | 
            
              |   | b3c57ab2 | 2022-03-22T11:20:46 |  | got patch: handle "\ No newline at end of file" | 
            
              |   | 7a30b5cb | 2022-03-20T08:54:45 |  | got patch: prefer new name if not /dev/null and not a git-style diff
This fixes a common issue when for e.g. generating patches with
	$ diff -u foo.orig foo
where 'got patch' failed because 'foo.orig' has an 'unexpected status'.
prodded by naddy, ok stsp | 
            
              |   | 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@ | 
            
              |   | d58ddaf3 | 2022-03-17T20:02:40 |  | const-ify tables
ok thomas_adam millert | 
            
              |   | 60aa1fa0 | 2022-03-17T16:38:43 |  | augment patch progress callback with hunks info; recover from errors
Augment got_patch_progress_cb by providing the hunks that were applied
with offset (or that failed) and the recoverable error encountered
during the operation (bad status, missing file, ...)
got_patch now proceeds when a file fails to be patched and exits with
GOT_ERR_PATCH_FAILED if no other errors are encountered.
While here, also add a test for the 'hunk applied with offset' case and
shrink test_patch_dont_apply and illegal_status by taking advantage that
'got patch' doesn't stop at the first error.  (And add some other cases
to illegal_status too.)
discussed with and ok stsp@ | 
            
              |   | 95d68340 | 2022-03-16T18:23:03 |  | got patch: create missing directories when adding files
ok stsp@ | 
            
              |   | 2be5e1a2 | 2022-03-16T18:23:03 |  | got patch: keep permissions after patching a file
ok stsp@ | 
            
              |   | b8af7c06 | 2022-03-15T10:45:02 |  | print additional progress information while packing
ok op@ | 
            
              |   | 899fcfdf | 2022-03-13T20:31:44 |  | add a dry-run/nop mode for got patch
with lots of help from stsp for the manpage bits! | 
            
              |   | 5b67f96e | 2022-03-13T15:36:59 |  | got patch: require exact match when removing files | 
            
              |   | dbda770b | 2022-03-13T15:36:56 |  | check file status before applying the patch
Don't allow `got patch' to delete files that are not known, or add files
that are already known and to edit files that are known, not obstructed
and without conflicts. | 
            
              |   | a84c0d30 | 2022-03-12T21:30:23 |  | fix 'got status' with an obstructed file given as argument; found by Omar | 
            
              |   | 6e96b326 | 2022-03-12T16:02:51 |  | refactor apply_patch to support renaming files
add two helper functions (schedule_add, schedule_del) and move the guts
of apply_patch into a new function `patch_file'.  This simplifies
apply_patch and makes easier to figure out what happens.
Then, drop GOT_ERR_PATCH_PATHS_DIFFER since we allow the to rename
files. | 
            
              |   | 81a19701 | 2022-03-10T20:28:20 |  | ref.sh: fix pastos and report the actual command that was run | 
            
              |   | bfbccd0a | 2022-03-08T12:22:36 |  | use test(1) -eq and -ne to compare integers; ok tb | 
            
              |   | fd79e2e0 | 2022-03-08T12:22:36 |  | typos | 
            
              |   | e9ce266e | 2022-03-07T22:26:08 |  | add `got patch' command for applying unified diffs | 
            
              |   | 3a12860c | 2022-03-07T19:25:46 |  | make the URI parser tolerate trailing slashes at the end of the input URI
ok naddy | 
            
              |   | bdc78ba6 | 2022-02-16T16:32:54 |  | display GMT offset in cat command
ok stsp | 
            
              |   | 32b5305f | 2022-02-12T09:34:03 |  | new test: `got diff' on files matched by an ignore pattern | 
            
              |   | 2b474c25 | 2022-02-11T22:45:00 |  | use murmurhash instead of sha1 for deltification blocks; suggested by ori | 
            
              |   | 1d918cf9 | 2022-02-06T14:56:36 |  | improve error message due to malformed `author' in got.conf
tweak and ok stsp@ | 
            
              |   | 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@ | 
            
              |   | 72840534 | 2022-01-19T12:04:58 |  | compress delta data from delta_cache directly into pack file | 
            
              |   | 64a8571e | 2022-01-07T23:32:27 |  | map raw object files into memory while packing if possible | 
            
              |   | a8a244dd | 2022-01-03T11:50:14 |  | simpler fix equivalent to the previous commit | 
            
              |   | 5988bab1 | 2022-01-03T11:48:22 |  | make test_cherrypick_root_commit pass with GOT_TEST_PACK=1 | 
            
              |   | c861864b | 2022-01-03T11:34:34 |  | 'got stage' tests rely on unreferenced loose objects; disable GOT_TEST_PACK=1 | 
            
              |   | 6fa5c67c | 2022-01-03T11:16:56 |  | remove loose objects if running tests with GOT_TEST_PACK | 
            
              |   | 0a26275f | 2022-01-03T11:11:06 |  | use 'gotadmin pack' instead of 'git repack' if testing with GOT_TEST_PACK | 
            
              |   | 10b394ac | 2021-11-23T12:52:59 |  | regress: make merge.sh more POSIXy
Don't use '==' for equality matching in sh, as this won't work across
all shells.
ok @naddy | 
            
              |   | 566e0ee7 | 2021-11-22T22:32:25 |  | regress: make test operands POSIX compliant
Since the interpreter for the regress shell scripts are using /bin/sh
this will usually imply some level of POSIX compliance (that isn't
bash-specific, for instance).
Some systems use dash as their sh shell and as such is stricter POSIX
compliance.  To help -portable, make the shell test checks use a single
'=' for equality, rather than '=='. | 
            
              |   | 0e039681 | 2021-11-15T17:00:36 |  | preverse binary files during updates and merges | 
            
              |   | 3d42b266 | 2021-11-03T21:42:33 |  | switch branches during noop rebases
Always update to the specified branch even if the branch is already
rebased (no commits needed to be rebased, and the branch does not need
a fast forward).  With the old behavior of erroring and staying on the
current branch, I sometimes found myself ignoring the error message,
treating it as information and assuming the branch update, and later
on committing on top of origin/main instead of the main branch.
feedback and ok stsp | 
            
              |   | 92410079 | 2021-10-16T14:50:03 |  | fix regression where 'got send -T' failed if same tag already exists on server
Problem reported and fix tested by Omar Polo. | 
            
              |   | b4e0802f | 2021-10-14T18:52:27 |  | FreeBSD's ed(1) does not accept "0i"; use the equivalent "1i" instead | 
            
              |   | 8f2ca62d | 2021-10-13T10:34:06 |  | do not skip ignored directories in 'got status' if they contain tracked files
Fixes regression introduced by commit 41f061b2f459318f3738f59d7676efccc4beb344
where tracked files inside an ignored directory were reported as missing. | 
            
              |   | b343c297 | 2021-10-11T18:54:11 |  | use a bloom filter to avoid pointless pack index searches | 
            
              |   | 10a623df | 2021-10-11T18:38:33 |  | sort and de-duplicate work tree path command line arguments
This is important in cases like 'got diff file.txt file.txt' which
should only show the diff for file.txt once.
suggested by kn@ | 
            
              |   | f10244c0 | 2021-10-11T18:25:11 |  | fix merging of files which contain a dot on a line by itself
Annoying bug which we inherited from OpenRCS which inherited
it from OpenBSD's diff3 program.
ok tracey millert | 
            
              |   | 67b631c9 | 2021-10-10T15:22:14 |  | implement 'got diff -c' for diffing commits with optional filtering by path
Need for filtering by path sugggested by kn@
ok naddy@ | 
            
              |   | 138e4f47 | 2021-10-09T19:47:15 |  | display the requested object type when an object could not be found
ok millert@ | 
            
              |   | c1e86b1d | 2021-10-08T11:53:05 |  | add an xfail test for a bug in merging content with a dot on a line by itself | 
            
              |   | 09209b8a | 2021-10-08T08:34:39 |  | add test for merge result when lines are inserted at the top of a file
Based on a patch by Omar Polo | 
            
              |   | e7ffb0b0 | 2021-10-07T21:13:05 |  | add support for multiple path arguments to 'got diff'
positive feedback from Omar and kn
ok kn | 
            
              |   | 41f061b2 | 2021-10-05T14:06:02 |  | ignore unversioned files while aborting rebase, histedit, merge or operations
ok jrick | 
            
              |   | b93c7142 | 2021-10-01T06:22:27 |  | add histedit -e option which runs the 'edit' script command for every commit
ok jrick | 
            
              |   | 78caff98 | 2021-09-30T08:24:01 |  | explicitly set the default branch name after 'git init' in regress tests
We need to do this because newer versions of Git support an arbitrary default
branch name which can be set by users. We don't want tests to fail when this
option is used.
pointed out by Thomas Adam | 
            
              |   | 1fa49072 | 2021-09-28T21:30:53 |  | interrupt 'got rebase' upon missing/unversioned/not-deleted files | 
            
              |   | c1b05723 | 2021-09-28T20:56:05 |  | make 'got merge' interrupt the merge upon undeleted and unversioned files | 
            
              |   | 35ca1db7 | 2021-09-28T20:56:04 |  | print additional stats about things that went wrong during a merge | 
            
              |   | 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@ | 
            
              |   | 088449d3 | 2021-09-26T17:51:38 |  | implement 'got merge -n' which interrupts before creating a merge commit | 
            
              |   | 4e91ef15 | 2021-09-26T17:51:35 |  | make it possible to merge vendor branches with 'got merge' | 
            
              |   | 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 | 
            
              |   | 1acd48bc | 2021-09-24T20:47:39 |  | stop caring about obstructed versioned files in 'got merge'
Tyring to write a test to cover this case I found that obstructed files
are (correctly) detected as local modifications in the work tree. Thus
they trigger the pre-condition check for local modications and 'got merge'
will not even start to do any work in the presence of obstructed files. |