From d9d8f5591f5f7f5fd3a4ebaab31001c3cf5c993e Mon Sep 17 00:00:00 2001 From: Junio C Hamano Date: Wed, 8 Nov 2017 14:44:38 +0900 Subject: [PATCH] What's cooking (2017/11 #03) --- whats-cooking.txt | 782 ++++++++++++++++------------------------------ 1 file changed, 265 insertions(+), 517 deletions(-) diff --git a/whats-cooking.txt b/whats-cooking.txt index e332bf024e..3a158cdb8e 100644 --- a/whats-cooking.txt +++ b/whats-cooking.txt @@ -1,10 +1,10 @@ To: git@vger.kernel.org Bcc: lwn@lwn.net -Subject: What's cooking in git.git (Nov 2017, #02; Mon, 6) +Subject: What's cooking in git.git (Nov 2017, #03; Wed, 8) X-master-at: 7668cbc60578f99a4c048f8f8f38787930b8147b -X-next-at: f294e3d99a357e12ccf7ade78a150fe6de4f7826 +X-next-at: 9af6a3dea062db2d4b3807c453d2f678c7f12e9c -What's cooking in git.git (Nov 2017, #02; Mon, 6) +What's cooking in git.git (Nov 2017, #03; Wed, 8) -------------------------------------------------- Here are the topics that have been cooking. Commits prefixed with @@ -12,445 +12,43 @@ Here are the topics that have been cooking. Commits prefixed with '+' are in 'next'. The ones marked with '.' do not appear in any of the integration branches, but I am still holding onto them. -Early batches for the next cycle has been merged to 'master' and -'next' has become thin enough so that we can rewind it and rebuild -it as usual, optionally with a handful of topics kicked out of it. -That hasn't happened yet, but it will shortly. +The tip of 'next' has been rebuilt on top of v2.15, while kicking a +few topics back to 'pu'. You can find the changes described here in the integration branches of the repositories listed at http://git-blame.blogspot.com/p/git-public-repositories.html --------------------------------------------------- -[Graduated to "master"] - -* ao/check-resolve-ref-unsafe-result (2017-10-21) 1 commit - (merged to 'next' on 2017-10-26 at 84302ab59a) - + commit: check result of resolve_ref_unsafe - - "git commit", after making a commit, did not check for errors when - asking on what branch it made the commit, which has been correted. - - -* bc/object-id (2017-10-16) 25 commits - (merged to 'next' on 2017-10-18 at ef8aa2698d) - + refs/files-backend: convert static functions to object_id - + refs: convert read_raw_ref backends to struct object_id - + refs: convert peel_object to struct object_id - + refs: convert resolve_ref_unsafe to struct object_id - + worktree: convert struct worktree to object_id - + refs: convert resolve_gitlink_ref to struct object_id - + Convert remaining callers of resolve_gitlink_ref to object_id - + sha1_file: convert index_path and index_fd to struct object_id - + refs: convert reflog_expire parameter to struct object_id - + refs: convert read_ref_at to struct object_id - + refs: convert peel_ref to struct object_id - + builtin/pack-objects: convert to struct object_id - + pack-bitmap: convert traverse_bitmap_commit_list to object_id - + refs: convert dwim_log to struct object_id - + builtin/reflog: convert remaining unsigned char uses to object_id - + refs: convert dwim_ref and expand_ref to struct object_id - + refs: convert read_ref and read_ref_full to object_id - + refs: convert resolve_refdup and refs_resolve_refdup to struct object_id - + Convert check_connected to use struct object_id - + refs: update ref transactions to use struct object_id - + refs: prevent accidental NULL dereference in write_pseudoref - + refs: convert update_ref and refs_update_ref to use struct object_id - + refs: convert delete_ref and refs_delete_ref to struct object_id - + refs/files-backend: convert struct ref_to_prune to object_id - + walker: convert to struct object_id - (this branch is used by mh/tidy-ref-update-flags.) - - Conversion from uchar[20] to struct object_id continues. - - -* bw/grep-recurse-submodules (2017-11-02) 1 commit - (merged to 'next' on 2017-11-02 at 50bbebe9e3) - + grep: take the read-lock when adding a submodule - - A broken access to object databases in recent update to "git grep - --recurse-submodules" has been fixed. - - -* cn/diff-indent-no-longer-is-experimental (2017-11-02) 1 commit - (merged to 'next' on 2017-11-02 at d3fe3952a7) - + diff: --indent-heuristic is no longer experimental - - Doc update. - - -* dm/run-command-ignored-hook-advise (2017-10-10) 1 commit - (merged to 'next' on 2017-10-10 at 0827814922) - + run-command: add hint when a hook is ignored - - A hook script that is set unexecutable is simply ignored. Git - notifies when such a file is ignored, unless the message is - squelched via advice.ignoredHook configuration. - - -* ds/find-unique-abbrev-optim (2017-10-13) 4 commits - (merged to 'next' on 2017-10-16 at 7f4479ac52) - + sha1_name: minimize OID comparisons during disambiguation - + sha1_name: parse less while finding common prefix - + sha1_name: unroll len loop in find_unique_abbrev_r() - + p4211-line-log.sh: add log --online --raw --parents perf test - - Optimize the code to find shortest unique prefix of object names. - - -* ex/deprecate-empty-pathspec-as-match-all (2017-06-23) 2 commits - (merged to 'next' on 2017-08-14 at 24db08a6e8) - + pathspec: die on empty strings as pathspec - + t0027: do not use an empty string as a pathspec element - - The final step to make an empty string as a pathspec element - illegal. We started this by first deprecating and warning a - pathspec that has such an element in 2.11 (Nov 2016). - - -* gc/gitweb-filetest-acl (2017-10-24) 1 commit - (merged to 'next' on 2017-10-26 at 5b490f53bf) - + gitweb: use filetest to allow ACLs - - "gitweb" checks if a directory is searchable with Perl's "-x" - operator, which can be enhanced by using "filetest 'access'" - pragma, which now we do. - - -* hv/fetch-moved-submodules-on-demand (2017-10-17) 3 commits - (merged to 'next' on 2017-10-26 at c446ea3e9a) - + submodule: simplify decision tree whether to or not to fetch - + implement fetching of moved submodules - + fetch: add test to make sure we stay backwards compatible - - "git fetch --recurse-submodules" now knows that submodules can be - moved around in the superproject in addition to getting updated, - and finds the ones that need to be fetched accordingly. - - -* jc/check-ref-format-oor (2017-10-18) 3 commits - (merged to 'next' on 2017-10-18 at 8b17566c80) - + check-ref-format doc: --branch validates and expands - + check-ref-format --branch: strip refs/heads/ using skip_prefix - + check-ref-format --branch: do not expand @{...} outside repository - - "git check-ref-format --branch @{-1}" bit a "BUG()" when run - outside a repository for obvious reasons; clarify the documentation - and make sure we do not even try to expand the at-mark magic in - such a case, but still call the validation logic for branch names. - - -* jc/no-cmd-as-subroutine (2017-10-11) 2 commits - (merged to 'next' on 2017-10-16 at 5f4ee919ac) - + merge-ours: do not use cmd_*() as a subroutine - + describe: do not use cmd_*() as a subroutine - - Calling cmd_foo() as if it is a general purpose helper function is - a no-no. Correct two instances of such to set an example. - - -* jc/t5601-copy-workaround (2017-10-17) 1 commit - (merged to 'next' on 2017-10-18 at ea1e133968) - + t5601: rm the target file of cp that could still be executing - - A (possibly flakey) test fix. - - -* jk/diff-color-moved-fix (2017-10-21) 5 commits - (merged to 'next' on 2017-10-26 at eb580e4c8c) - + diff: handle NULs in get_string_hash() - + diff: fix whitespace-skipping with --color-moved - + t4015: test the output of "diff --color-moved -b" - + t4015: check "negative" case for "-w --color-moved" - + t4015: refactor --color-moved whitespace test - (this branch is used by sb/diff-color-moved-use-xdl-recmatch.) - - The experimental "color moved lines differently in diff output" - feature was buggy around "ignore whitespace changes" edges, whihch - has been corrected. - - -* jk/misc-resolve-ref-unsafe-fixes (2017-10-21) 4 commits - (merged to 'next' on 2017-10-26 at c327b2ec2f) - + worktree: handle broken symrefs in find_shared_symref() - + log: handle broken HEAD in decoration check - + remote: handle broken symrefs - + test-ref-store: avoid passing NULL to printf - - Some codepaths did not check for errors when asking what branch the - HEAD points at, which have been fixed. - - -* jk/rebase-i-exec-gitdir-fix (2017-11-02) 1 commit - (merged to 'next' on 2017-11-02 at 9a519c7150) - + sequencer: pass absolute GIT_DIR to exec commands - - A recent regression in "git rebase -i" that broke execution of git - commands from subdirectories via "exec" insn has been fixed. - - -* jk/revision-pruning-optim (2017-10-14) 1 commit - (merged to 'next' on 2017-10-16 at 2662baa21d) - + revision: quit pruning diff more quickly when possible - - Pathspec-limited revision traversal was taught not to keep finding - unneeded differences once it knows two trees are different inside - given pathspec. - - -* js/submodule-in-excluded (2017-10-26) 1 commit - (merged to 'next' on 2017-10-26 at 2a262e6a0b) - + status: do not get confused by submodules in excluded directories - - "git status --ignored -u" did not stop at a working tree of a - separate project that is embedded in an ignored directory and - listed files in that other project, instead of just showing the - directory itself as ignored. - - -* kd/auto-col-with-pager-fix (2017-10-24) 2 commits - (merged to 'next' on 2017-10-24 at ef3ff0f14b) - + column: do not include pager.c - (merged to 'next' on 2017-10-18 at fe89ff7e83) - + column: show auto columns when pager is active - - "auto" as a value for the columnar output configuration ought to - judge "is the output consumed by humans?" with the same criteria as - "auto" for coloured output configuration, i.e. either the standard - output stream is going to tty, or a pager is in use. We forgot the - latter, which has been fixed. - - -* ma/lockfile-fixes (2017-10-07) 12 commits - (merged to 'next' on 2017-10-16 at 19fae5c138) - + read_cache: roll back lock in `update_index_if_able()` - + read-cache: leave lock in right state in `write_locked_index()` - + read-cache: drop explicit `CLOSE_LOCK`-flag - + cache.h: document `write_locked_index()` - + apply: remove `newfd` from `struct apply_state` - + apply: move lockfile into `apply_state` - + cache-tree: simplify locking logic - + checkout-index: simplify locking logic - + tempfile: fix documentation on `delete_tempfile()` - + lockfile: fix documentation on `close_lock_file_gently()` - + treewide: prefer lockfiles on the stack - + sha1_file: do not leak `lock_file` - - An earlier update made it possible to use an on-stack in-core - lockfile structure (as opposed to having to deliberately leak an - on-heap one). Many codepaths have been updated to take advantage - of this new facility. - - -* mh/test-local-canary (2017-10-31) 1 commit - (merged to 'next' on 2017-11-02 at f34927f687) - + t0000: check whether the shell supports the "local" keyword - - We try to see if somebody runs our test suite with a shell that - does not support "local" like bash/dash does. - - -* mp/push-pushoption-config (2017-10-24) 1 commit - (merged to 'next' on 2017-10-26 at 2c72164d12) - + builtin/push.c: add push.pushOption config - - The "--push-option=" option to "git push" now defaults to a - list of strings configured via push.pushOption variable. - - -* pb/bisect-helper (2017-10-06) 6 commits - (merged to 'next' on 2017-10-13 at ffc9aefe63) - + bisect--helper: `is_expected_rev` & `check_expected_revs` shell function in C - + t6030: explicitly test for bisection cleanup - + bisect--helper: `bisect_clean_state` shell function in C - + bisect--helper: `write_terms` shell function in C - + bisect--helper: rewrite `check_term_format` shell function in C - + bisect--helper: use OPT_CMDMODE instead of OPT_BOOL - (this branch is used by pb/bisect-helper-2.) - - An early part of piece-by-piece rewrite of "git bisect". - - -* pc/submodule-helper (2017-10-07) 3 commits - (merged to 'next' on 2017-10-16 at 2b38de12cc) - + submodule: port submodule subcommand 'status' from shell to C - + submodule--helper: introduce for_each_listed_submodule() - + submodule--helper: introduce get_submodule_displaypath() - - GSoC. - - -* sb/diff-color-moved-use-xdl-recmatch (2017-10-26) 2 commits - (merged to 'next' on 2017-10-26 at 6711f24498) - + diff.c: get rid of duplicate implementation - + xdiff-interface: export comparing and hashing strings - (this branch uses jk/diff-color-moved-fix.) - - Instead of using custom line comparison and hashing functions to - implement "moved lines" coloring in the diff output, use the pair - of these functions from lower-layer xdiff/ code. - - -* tb/complete-checkout (2017-10-25) 1 commit - (merged to 'next' on 2017-10-26 at beeaf5b00c) - + completion: add remaining flags to checkout - - Command line completion (in contrib/) update. - - -* tg/deprecate-stash-save (2017-10-27) 3 commits - (merged to 'next' on 2017-10-27 at 73b1edb73b) - + stash: remove now superfluos help for "stash push" - + stash: mark "git stash save" deprecated in the man page - + stash: replace "git stash save" with "git stash push" in the documentation - - "git stash save" has been deprecated in favour of "git stash push". - - -* wk/pull-signoff (2017-10-13) 1 commit - (merged to 'next' on 2017-10-16 at 5e48f349d9) - + pull: pass --signoff/--no-signoff to "git merge" - - "git pull" has been taught to accept "--[no-]signoff" option and - pass it down to "git merge". - -------------------------------------------------- [New Topics] -* js/mingw-redirect-std-handles (2017-11-02) 3 commits - - mingw: document the standard handle redirection - - mingw: optionally redirect stderr/stdout via the same handle - - mingw: add experimental feature to redirect standard handles +* bw/rebase-i-ignored-submodule-fix (2017-11-07) 1 commit + - wt-status: actually ignore submodules when requested - MinGW updates. + "git rebase -i" recently started misbehaving when a submodule that + is configured with 'submodule..ignore' is dirty; this has + been corrected. Will merge to 'next'. + I've edited in the tweak brought up in the discussion. Please + eyeball to sanity check. -* ma/bisect-leakfix (2017-11-06) 4 commits - - bisect: fix memory leak when returning best element - - bisect: fix off-by-one error in `best_bisection_sorted()` - - bisect: fix memory leak in `find_bisection()` - - bisect: change calling-convention of `find_bisection()` +* ar/unconfuse-three-dots (2017-11-07) 3 commits + - Documentation: revisions: add note about 3dots usages as continuation indications + - Documentation: user-manual: limit potentially confusing usage of 3dots (and 2dots) + - checkout: describe_detached_head: remove 3dots after committish - Leak fixes. - - Will merge to 'next'. + Ancient part of codebase still shows dots after an abbreviated + object name just to show that it is not a full object name, but + these ellipses are confusing to people who newly discovered Git + who are used to seeing abbreviated object names and find them + confusing with the range syntax. -* ma/reduce-heads-leakfix (2017-11-06) 2 commits - - reduce_heads: fix memory leaks - - builtin/merge-base: UNLEAK commit lists - - Leak fixes. - - Will merge to 'next'. - - -* sg/travis-fixes (2017-11-02) 2 commits - - travis-ci: don't build Git for the static analysis job - - travis-ci: fix running P4 and Git LFS tests in Linux build jobs - - TravisCI build updates. - - Will merge to 'next'. - - -* sr/wrapper-quote-filenames (2017-11-06) 1 commit - - wrapper.c: consistently quote filenames in error messages - - Some error messages did not quote filenames shown in it, which have - been fixed. - - Will merge to 'next'. - - -* jh/fsck-promisors (2017-11-03) 9 commits - - gc: do not repack promisor packfiles - - sha1_file: support lazily fetching missing objects - - introduce fetch-object: fetch one promisor object - - index-pack: refactor writing of .keep files - - fsck: support promisor objects as CLI argument - - fsck: support referenced promisor objects - - fsck: support refs pointing to promisor objects - - fsck: introduce partialclone extension - - extension.partialclone: introduce partial clone extension - (this branch is used by jh/partial-clone; uses jh/object-filtering.) - - -* jh/object-filtering (2017-11-03) 6 commits - - pack-objects: add list-objects filtering - - rev-list: add list-objects filtering support - - list-objects: filter objects in traverse_commit_list - - oidset: add iterator methods to oidset - - oidmap: add oidmap iterator methods - - dir: allow exclusions from blob in addition to file - (this branch is used by jh/fsck-promisors and jh/partial-clone.) - - -* jh/partial-clone (2017-11-03) 14 commits - - index-pack: silently assume missing objects are promisor - - fetch-pack: restore save_commit_buffer after use - - unpack-trees: batch fetching of missing blobs - - t5500: more tests for partial clone and fetch - - t5601: test for partial clone - - t5500: add fetch-pack tests for partial clone - - fetch: add from_promisor and exclude-promisor-objects parameters - - fetch-pack: test support excluding large blobs - - pack-objects: test support for blob filtering - - remote-curl: add object filtering for partial clone - - fetch: add object filtering for partial fetch - - fetch: refactor calculation of remote list - - clone, fetch-pack, index-pack, transport: partial clone - - upload-pack: add object filtering for partial clone - (this branch uses jh/fsck-promisors and jh/object-filtering.) - - -* js/early-config (2017-11-03) 1 commit - - setup: avoid double slashes when looking for HEAD - - Correct start-up sequence so that a repository could hang - immediately under the root directory again (which was broken at - around Git 2.13). - - Will merge to 'next'. - - -* ks/mailmap (2017-11-03) 1 commit - - mailmap: use Kaartic Sivaraam's new address - - Will merge to 'next'. - - -* rs/imap-send-next-arg-fix (2017-11-03) 2 commits - - imap-send: handle missing response codes gracefully - - imap-send: handle NULL return of next_arg() - - Error checking in "git imap-send" for empty response has been - improved. - - Will merge to 'next'. - - -* dk/libsecret-unlock-to-load-fix (2017-11-04) 1 commit - - credential-libsecret: unlock locked secrets - - The credential helper for libsecret (in contrib/) has been improved - to allow possibly prompting the end user to unlock secrets that are - currently locked (otherwise the secrets may not be loaded). - - Will merge to 'next'. - - -* jm/relnotes-2.15-typofix (2017-11-06) 1 commit - - fix typos in 2.15.0 release notes - - Will merge to 'next'. - - -* sb/blame-config-doc (2017-11-06) 1 commit - - config: document blame configuration +* jt/submodule-tests-cleanup (2017-11-08) 1 commit + - Tests: clean up and document submodule helpers Will merge to 'next'. @@ -477,19 +75,6 @@ of the repositories listed at cf. <20171025163243.xmm7szrkwgblpgcc@aiede.mtv.corp.google.com> -* js/for-each-ref-remote-name-and-ref (2017-10-11) 3 commits - - for-each-ref: test :remotename and :remoteref - - for-each-ref: let upstream/push optionally report the remote ref name - - for-each-ref: let upstream/push optionally report the remote name - - The "--format=..." option "git for-each-ref" takes learned to show - the name of the 'remote' repository and the ref at the remote side - that is affected for 'upstream' and 'push' via "%(push:remotename)" - and friends. - - Needs a bit more work on the documentation part. - - * jc/merge-symlink-ours-theirs (2017-09-26) 1 commit - merge: teach -Xours/-Xtheirs to symbolic link merge @@ -591,13 +176,178 @@ of the repositories listed at -------------------------------------------------- [Cooking] +* js/for-each-ref-remote-name-and-ref (2017-11-08) 3 commits + - for-each-ref: test :remotename and :remoteref + - for-each-ref: let upstream/push report the remote ref name + - for-each-ref: let upstream/push optionally report the remote name + + The "--format=..." option "git for-each-ref" takes learned to show + the name of the 'remote' repository and the ref at the remote side + that is affected for 'upstream' and 'push' via "%(push:remotename)" + and friends. + + Will merge to 'next'. + + +* js/mingw-redirect-std-handles (2017-11-02) 3 commits + (merged to 'next' on 2017-11-07 at 9af6a3dea0) + + mingw: document the standard handle redirection + + mingw: optionally redirect stderr/stdout via the same handle + + mingw: add experimental feature to redirect standard handles + + MinGW updates. + + Will merge to 'master'. + + +* ma/bisect-leakfix (2017-11-06) 4 commits + - bisect: fix memory leak when returning best element + - bisect: fix off-by-one error in `best_bisection_sorted()` + - bisect: fix memory leak in `find_bisection()` + - bisect: change calling-convention of `find_bisection()` + + Leak fixes. + + Will merge to 'next'. + + +* ma/reduce-heads-leakfix (2017-11-08) 2 commits + - reduce_heads: fix memory leaks + - builtin/merge-base: free commit lists + + Leak fixes. + + Will merge to 'next'. + + +* sg/travis-fixes (2017-11-02) 2 commits + (merged to 'next' on 2017-11-07 at bbf39361b6) + + travis-ci: don't build Git for the static analysis job + + travis-ci: fix running P4 and Git LFS tests in Linux build jobs + + TravisCI build updates. + + Will merge to 'master'. + + +* sr/wrapper-quote-filenames (2017-11-06) 1 commit + - wrapper.c: consistently quote filenames in error messages + + Some error messages did not quote filenames shown in it, which have + been fixed. + + Will merge to 'next'. + + +* jh/fsck-promisors (2017-11-08) 9 commits + - gc: do not repack promisor packfiles + - sha1_file: support lazily fetching missing objects + - introduce fetch-object: fetch one promisor object + - index-pack: refactor writing of .keep files + - fsck: support promisor objects as CLI argument + - fsck: support referenced promisor objects + - fsck: support refs pointing to promisor objects + - fsck: introduce partialclone extension + - extension.partialclone: introduce partial clone extension + (this branch is used by jh/partial-clone; uses jh/object-filtering.) + + +* jh/object-filtering (2017-11-08) 6 commits + - pack-objects: add list-objects filtering + - rev-list: add list-objects filtering support + - list-objects: filter objects in traverse_commit_list + - oidset: add iterator methods to oidset + - oidmap: add oidmap iterator methods + - dir: allow exclusions from blob in addition to file + (this branch is used by jh/fsck-promisors and jh/partial-clone.) + + +* jh/partial-clone (2017-11-08) 15 commits + - fixup! upload-pack: add object filtering for partial clone + - index-pack: silently assume missing objects are promisor + - fetch-pack: restore save_commit_buffer after use + - unpack-trees: batch fetching of missing blobs + - t5500: more tests for partial clone and fetch + - t5601: test for partial clone + - t5500: add fetch-pack tests for partial clone + - fetch: add from_promisor and exclude-promisor-objects parameters + - fetch-pack: test support excluding large blobs + - pack-objects: test support for blob filtering + - remote-curl: add object filtering for partial clone + - fetch: add object filtering for partial fetch + - fetch: refactor calculation of remote list + - clone, fetch-pack, index-pack, transport: partial clone + - upload-pack: add object filtering for partial clone + (this branch uses jh/fsck-promisors and jh/object-filtering.) + + +* js/early-config (2017-11-03) 1 commit + (merged to 'next' on 2017-11-07 at 9477c7c8ea) + + setup: avoid double slashes when looking for HEAD + + Correct start-up sequence so that a repository could be placed + immediately under the root directory again (which was broken at + around Git 2.13). + + Will merge to 'master'. + + +* ks/mailmap (2017-11-03) 1 commit + (merged to 'next' on 2017-11-07 at 46975637c7) + + mailmap: use Kaartic Sivaraam's new address + + Will merge to 'master'. + + +* rs/imap-send-next-arg-fix (2017-11-03) 2 commits + (merged to 'next' on 2017-11-07 at f4df55fe5b) + + imap-send: handle missing response codes gracefully + + imap-send: handle NULL return of next_arg() + + Error checking in "git imap-send" for empty response has been + improved. + + Will merge to 'master'. + + +* dk/libsecret-unlock-to-load-fix (2017-11-04) 1 commit + (merged to 'next' on 2017-11-07 at 57d1d76c8c) + + credential-libsecret: unlock locked secrets + + The credential helper for libsecret (in contrib/) has been improved + to allow possibly prompting the end user to unlock secrets that are + currently locked (otherwise the secrets may not be loaded). + + Will merge to 'master'. + + +* jm/relnotes-2.15-typofix (2017-11-06) 1 commit + (merged to 'next' on 2017-11-07 at 60fc937b62) + + fix typos in 2.15.0 release notes + + Typofix. + + Will merge to 'master'. + + +* sb/blame-config-doc (2017-11-06) 1 commit + (merged to 'next' on 2017-11-07 at 0576cb452f) + + config: document blame configuration + + Description of blame.{showroot,blankboundary,showemail,date} + configuration variables have been added to "git config --help". + + Will merge to 'master'. + + * ad/5580-unc-tests-on-cygwin (2017-11-01) 1 commit - - t5580: add Cygwin support + (merged to 'next' on 2017-11-07 at 34fc479da2) + + t5580: add Cygwin support UNC paths are also relevant in Cygwin builds and they are now tested just like Mingw builds. - Will merge to 'next'. + Will merge to 'master'. * ao/merge-verbosity-getenv-just-once (2017-11-01) 1 commit @@ -608,8 +358,8 @@ of the repositories listed at Will merge to 'next'. -* bp/read-index-from-skip-verification (2017-11-01) 1 commit - - read_index_from(): speed index loading by skiping verification of the entry order +* bp/read-index-from-skip-verification (2017-11-08) 1 commit + - read_index_from(): speed index loading by skipping verification of the entry order Drop (perhaps overly cautious) sanity check before using the index read from the filesystem at runtime. @@ -618,13 +368,14 @@ of the repositories listed at * rs/hex-to-bytes-cleanup (2017-11-01) 3 commits - - sha1_file: use hex_to_bytes() - - http-push: use hex_to_bytes() - - notes: move hex_to_bytes() to hex.c and export it + (merged to 'next' on 2017-11-07 at fac14770e1) + + sha1_file: use hex_to_bytes() + + http-push: use hex_to_bytes() + + notes: move hex_to_bytes() to hex.c and export it Code cleanup. - Will merge to 'next'. + Will merge to 'master'. * rs/sequencer-rewrite-file-cleanup (2017-11-02) 3 commits @@ -650,27 +401,27 @@ of the repositories listed at : that refers to a given blob object. -* tb/add-renormalize (2017-10-31) 1 commit +* tb/add-renormalize (2017-11-07) 2 commits + - SQUASH??? - add: introduce "--renormalize" "git add --renormalize ." is a new and safer way to record the fact that you are correcting the end-of-line convention and other "convert_to_git()" glitches in the in-repository data. - Needs review. - * ab/mediawiki-name-truncation (2017-11-01) 1 commit - - remote-mediawiki: limit filenames to legal + (merged to 'next' on 2017-11-07 at b30233d585) + + remote-mediawiki: limit filenames to legal The remote-helper for talking to MediaWiki has been updated to truncate an overlong pagename so that ".mw" suffix can still be added. - Will merge to 'next'. + Will merge to 'master'. -* ab/mediawiki-namespace (2017-11-03) 7 commits +* ab/mediawiki-namespace (2017-11-08) 7 commits - remote-mediawiki: show progress while fetching namespaces - remote-mediawiki: process namespaces in order - remote-mediawiki: support fetching from (Main) namespace @@ -682,42 +433,43 @@ of the repositories listed at The remote-helper for talking to MediaWiki has been updated to work with mediawiki namespaces. - Are we expecting another round for v4? What is queued above came - as <20171102212518.1601-8-anarcat@debian.org> and marked v3. - cf. <87375w5qdw.fsf@curie.anarc.at> + Will merge to 'next'. * js/mingw-full-version-in-resources (2017-11-01) 1 commit - - mingw: include the full version information in the resources + (merged to 'next' on 2017-11-07 at 3a256b5ddc) + + mingw: include the full version information in the resources MinGW updates. - Will merge to 'next'. + Will merge to 'master'. * js/wincred-empty-cred (2017-11-01) 2 commits - - wincred: handle empty username/password correctly - - t0302: check helper can handle empty credentials + (merged to 'next' on 2017-11-07 at 43d3fcc30a) + + wincred: handle empty username/password correctly + + t0302: check helper can handle empty credentials MinGW updates. - Will merge to 'next'. + Will merge to 'master'. * bw/diff-opt-impl-to-bitfields (2017-11-01) 8 commits - - diff: make struct diff_flags members lowercase - - diff: remove DIFF_OPT_CLR macro - - diff: remove DIFF_OPT_SET macro - - diff: remove DIFF_OPT_TST macro - - diff: remove touched flags - - diff: add flag to indicate textconv was set via cmdline - - diff: convert flags to be stored in bitfields - - add, reset: use DIFF_OPT_SET macro to set a diff flag + (merged to 'next' on 2017-11-07 at 8be78206ba) + + diff: make struct diff_flags members lowercase + + diff: remove DIFF_OPT_CLR macro + + diff: remove DIFF_OPT_SET macro + + diff: remove DIFF_OPT_TST macro + + diff: remove touched flags + + diff: add flag to indicate textconv was set via cmdline + + diff: convert flags to be stored in bitfields + + add, reset: use DIFF_OPT_SET macro to set a diff flag A single-word "unsigned flags" in the diff options is being split into a structure with many bitfields. - Will merge to 'next'. + Will merge to 'master'. * mh/tidy-ref-update-flags (2017-11-06) 10 commits @@ -738,25 +490,27 @@ of the repositories listed at * ao/diff-populate-filespec-lstat-errorpath-fix (2017-10-29) 1 commit - - diff: fix lstat() error handling in diff_populate_filespec() + (merged to 'next' on 2017-11-07 at b03241e6e5) + + diff: fix lstat() error handling in diff_populate_filespec() After an error from lstat(), diff_populate_filespec() function sometimes still went ahead and used invalid data in struct stat, which has been fixed. - Will merge to 'next'. + Will merge to 'master'. * av/fsmonitor (2017-11-01) 4 commits - - fsmonitor: delay updating state until after split index is merged - - fsmonitor: document GIT_TRACE_FSMONITOR - - fsmonitor: don't bother pretty-printing JSON from watchman - - fsmonitor: set the PWD to the top of the working tree + (merged to 'next' on 2017-11-07 at a06178754d) + + fsmonitor: delay updating state until after split index is merged + + fsmonitor: document GIT_TRACE_FSMONITOR + + fsmonitor: don't bother pretty-printing JSON from watchman + + fsmonitor: set the PWD to the top of the working tree (this branch uses bp/fsmonitor.) Various fixes to bp/fsmonitor topic. - Will merge to 'next'. + Will merge to 'master'. * bc/submitting-patches-in-asciidoc (2017-10-30) 2 commits @@ -783,16 +537,13 @@ of the repositories listed at cf. <0102015f5e5ee171-f30f4868-886f-47a1-a4e4-b4936afc545d-000000@eu-west-1.amazonses.com> -* jc/ignore-cr-at-eol (2017-10-27) 2 commits +* jc/ignore-cr-at-eol (2017-11-08) 2 commits - diff: --ignore-cr-at-eol - xdiff: reassign xpparm_t.flags bits The "diff" family of commands learned to ignore differences in carriage return at the end of line. - Just a lunch-time hack. - Lacks tests, docs and proper log message. - * mh/avoid-rewriting-packed-refs (2017-10-30) 2 commits - files-backend: don't rewrite the `packed-refs` file unnecessarily @@ -805,30 +556,32 @@ of the repositories listed at Will merge to 'next'. -* cc/git-packet-pm (2017-10-31) 7 commits - - fixup! Git/Packet.pm: extract parts of t0021/rot13-filter.pl for reuse +* cc/git-packet-pm (2017-11-07) 8 commits - Git/Packet.pm: extract parts of t0021/rot13-filter.pl for reuse - t0021/rot13-filter: add capability functions + - t0021/rot13-filter: refactor checking final lf - t0021/rot13-filter: add packet_initialize() - t0021/rot13-filter: improve error message - t0021/rot13-filter: improve 'if .. elsif .. else' style - t0021/rot13-filter: refactor packet reading functions + - t0021/rot13-filter: fix list comparison Parts of a test to drive the long-running content filter interface has been split into its own module, hopefully to eventually become reusable. - Reroll posted but not picked up yet. - cf. <20171105213836.11717-1-chriscool@tuxfamily.org> + Will merge to 'next'. * jm/status-ignored-files-list (2017-10-31) 4 commits - (merged to 'next' on 2017-11-01 at fe51978a30) + (merged to 'next' on 2017-11-07 at 682c74a2cb) + status: test ignored modes + status: document options to show matching ignored files + status: report matching ignored and normal untracked + status: add option to show ignored files differently + Originally merged to 'next' on 2017-11-01 + The set of paths output from "git status --ignored" was tied closely with its "--untracked=" option, but now it can be controlled more flexibly. Most notably, a directory that is @@ -840,20 +593,19 @@ of the repositories listed at * jc/branch-name-sanity (2017-10-14) 3 commits - (merged to 'next' on 2017-10-16 at 174646d1c3) - + branch: forbid refs/heads/HEAD - + branch: split validate_new_branchname() into two - + branch: streamline "attr_only" handling in validate_new_branchname() + - branch: forbid refs/heads/HEAD + - branch: split validate_new_branchname() into two + - branch: streamline "attr_only" handling in validate_new_branchname() "git branch" and "git checkout -b" are now forbidden from creating a branch whose name is "HEAD". - Will kick back to 'pu'. + Reported to cause problems when renaming HEAD during a rebase. + cf. <49563f7c-354e-334e-03a6-c3a40884b6d0@gmail.com> * ot/mru-on-list (2017-10-01) 1 commit - (merged to 'next' on 2017-10-07 at e6ad4a16a2) - + mru: use double-linked list from list.h + - mru: use double-linked list from list.h The first step to getting rid of mru API and using the doubly-linked list API directly instead. @@ -875,11 +627,10 @@ of the repositories listed at * bp/fsmonitor (2017-10-05) 15 commits - (merged to 'next' on 2017-10-05 at 964a029d13) + (merged to 'next' on 2017-11-07 at b08d44ba60) + fsmonitor: preserve utf8 filenames in fsmonitor-watchman log + fsmonitor: read entirety of watchman output + fsmonitor: MINGW support for watchman integration - (merged to 'next' on 2017-10-02 at cf0c67979c) + fsmonitor: add a performance test + fsmonitor: add a sample integration script for Watchman + fsmonitor: add test cases for fsmonitor extension @@ -894,25 +645,26 @@ of the repositories listed at + bswap: add 64 bit endianness helper get_be64 (this branch is used by av/fsmonitor.) + Originally merged to 'next' on 2017-10-05 + We learned to talk to watchman to speed up "git status" and other operations that need to see which paths have been modified. - Waiting for av/fsmonitor topic. + Will merge to 'master'. * bw/protocol-v1 (2017-10-17) 11 commits - (merged to 'next' on 2017-10-18 at 835fe09e50) - + Documentation: document Extra Parameters - + ssh: introduce a 'simple' ssh variant - + i5700: add interop test for protocol transition - + http: tell server that the client understands v1 - + connect: tell server that the client understands v1 - + connect: teach client to recognize v1 server response - + upload-pack, receive-pack: introduce protocol version 1 - + daemon: recognize hidden request arguments - + protocol: introduce protocol extension mechanisms - + pkt-line: add packet_write function - + connect: in ref advertisement, shallows are last + - Documentation: document Extra Parameters + - ssh: introduce a 'simple' ssh variant + - i5700: add interop test for protocol transition + - http: tell server that the client understands v1 + - connect: tell server that the client understands v1 + - connect: teach client to recognize v1 server response + - upload-pack, receive-pack: introduce protocol version 1 + - daemon: recognize hidden request arguments + - protocol: introduce protocol extension mechanisms + - pkt-line: add packet_write function + - connect: in ref advertisement, shallows are last (this branch is used by jn/ssh-wrappers.) A new mechanism to upgrade the wire protocol in place is proposed @@ -936,26 +688,22 @@ of the repositories listed at * sb/submodule-recursive-checkout-detach-head (2017-07-28) 2 commits - (merged to 'next' on 2017-10-26 at 30994b4c76) - + Documentation/checkout: clarify submodule HEADs to be detached - + recursive submodules: detach HEAD from new state + - Documentation/checkout: clarify submodule HEADs to be detached + - recursive submodules: detach HEAD from new state "git checkout --recursive" may overwrite and rewind the history of the branch that happens to be checked out in submodule repositories, which might not be desirable. Detach the HEAD but still allow the recursive checkout to succeed in such a case. - Undecided. - This needs justification in a larger picture; it is unclear why - this is better than rejecting recursive checkout, for example. + Expecting a reroll. -------------------------------------------------- [Discarded] * jk/ui-color-always-to-auto-maint (2017-10-13) 2 commits - (merged to 'next' on 2017-10-13 at bb16e1edc8) - + color: document that "git -c color.*=always" is a bit special - + color: downgrade "always" to "auto" only for on-disk configuration + . color: document that "git -c color.*=always" is a bit special + . color: downgrade "always" to "auto" only for on-disk configuration It turns out that "git -c color.ui=always cmd" is relied on by many third-party tools as a way to force coloured output no matter what @@ -993,7 +741,7 @@ of the repositories listed at * jh/dir-add-exclude-from-blob (2017-10-27) 1 commit - - dir: allow exclusions from blob in addition to file + . dir: allow exclusions from blob in addition to file The code to read exclusion list from a blob, which is used when the .gitignore file is outside a sparse checkout area, has been