What's cooking in git.git (Nov 2017, #04; Tue, 14) -------------------------------------------------- Here are the topics that have been cooking. Commits prefixed with '-' are only in 'pu' (proposed updates) while 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. 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"] * ad/5580-unc-tests-on-cygwin (2017-11-01) 1 commit (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. * ao/diff-populate-filespec-lstat-errorpath-fix (2017-10-29) 1 commit (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. * bw/diff-opt-impl-to-bitfields (2017-11-01) 8 commits (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. * 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). * 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. * jm/status-ignored-files-list (2017-10-31) 4 commits (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=<mode>" option, but now it can be controlled more flexibly. Most notably, a directory that is ignored because it is listed to be ignored in the ignore/exclude mechanism can be handled differently from a directory that ends up to be ignored only because all files in it are ignored. * 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). * js/mingw-full-version-in-resources (2017-11-01) 1 commit (merged to 'next' on 2017-11-07 at 3a256b5ddc) + mingw: include the full version information in the resources MinGW updates. * 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. * js/wincred-empty-cred (2017-11-01) 2 commits (merged to 'next' on 2017-11-07 at 43d3fcc30a) + wincred: handle empty username/password correctly + t0302: check helper can handle empty credentials MinGW updates. * ks/mailmap (2017-11-03) 1 commit (merged to 'next' on 2017-11-07 at 46975637c7) + mailmap: use Kaartic Sivaraam's new address * rs/hex-to-bytes-cleanup (2017-11-01) 3 commits (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. * 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". * 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. -------------------------------------------------- [New Topics] * ad/rebase-i-serie-typofix (2017-11-09) 1 commit (merged to 'next' on 2017-11-13 at 199e79b29e) + rebase -i: fix comment typo Will merge to 'master'. * ad/submitting-patches-title-decoration (2017-11-11) 1 commit - doc/SubmittingPatches: correct subject guidance Doc update around use of "format-patch --subject-prefix" etc. Will merge to 'next'. * jc/merge-base-fork-point-doc (2017-11-09) 1 commit - merge-base --fork-point doc: clarify the example and failure modes Clarify and enhance documentation for "merge-base --fork-point", as it was clear what it computed but not why/what for. * tz/fsf-address-update (2017-11-09) 3 commits (merged to 'next' on 2017-11-13 at 97965f70d9) + Merge branch 'tz/fsf-address-update' of ../git-gui into tz/fsf-address-update + Replace Free Software Foundation address in license notices + Replace Free Software Foundation address in license notices Will merge to 'master'. * bp/fastindex (2017-11-11) 5 commits - SQUASH??? - fastindex: add documentation for the fastindex extension - fastindex: add test tools and a test script - update-index: add fastindex support to update-index - fastindex: speed up index load through parallelization * pw/sequencer-in-process-commit (2017-11-11) 10 commits - SQUASH??? styles - sequencer: try to commit without forking 'git commit' - sequencer: load commit related config - sequencer: simplify adding Signed-off-by: trailer - sequencer: don't die in print_commit_summary() - commit: move print_commit_summary() to libgit - commit: move post-rewrite code to libgit - Add a function to update HEAD after creating a commit - commit: move empty message checks to libgit - t3404: check intermediate squash messages The sequencer infrastructure is shared across "git cherry-pick", "git rebase -i", etc., and has always spawned "git commit" when it needs to create a commit. It has been taught to do so internally, when able, by reusing the codepath "git commit" itself uses. * rs/apply-fuzzy-match-fix (2017-11-12) 1 commit - apply: avoid out-of-bounds access in fuzzy_matchlines() A fix for an ancient bug in "git apply --ignore-space-change" codepath. Will merge to 'next'. * sb/test-cherry-pick-submodule-getting-in-a-way (2017-11-12) 1 commit - t/3512: demonstrate unrelated submodule/file conflict as cherry-pick failure An additional test, in anticipation for a fix. Will merge to 'next'. It would be very preferrable if we can merge an actual fix together to 'next', though. * ab/pcre-v2 (2017-11-13) 1 commit (merged to 'next' on 2017-11-13 at 66bf57f071) + grep: fix NO_LIBPCRE1_JIT to fully disable JIT Building with NO_LIBPCRE1_JIT did not disable it, which has been fixed. Will merge to 'master'. * cb/t4201-robustify (2017-11-13) 1 commit (merged to 'next' on 2017-11-13 at b83957b8f2) + t4201: make use of abbreviation in the test more robust A test update. Will merge to 'master'. * jk/info-alternates-fix (2017-11-13) 1 commit (merged to 'next' on 2017-11-13 at ac84a7580a) + link_alt_odb_entries: make empty input a noop We used to add an empty alternate object database to the system that does not help anything; it has been corrected. Will merge to 'master'. * rd/bisect-view-is-visualize (2017-11-13) 1 commit (merged to 'next' on 2017-11-13 at a36423f4ba) + bisect: mention "view" as an alternative to "visualize" Doc and message updates to teach users "bisect view" is a synonym for "bisect visualize". Will merge to 'master'. * sb/bisect-run-empty (2017-11-13) 1 commit (merged to 'next' on 2017-11-13 at 90d20b8686) + bisect run: die if no command is given "git bisect run" that did not specify any command to run used to go ahead and treated all commits to be tested as 'good'. This has been corrected by making the command error out. Will merge to 'master'. * en/rename-progress (2017-11-14) 5 commits - sequencer: show rename progress during cherry picks - diff: remove silent clamp of renameLimit - SQUASH??? - progress: fix progress meters when dealing with lots of work - sequencer: warn when internal merge may be suboptimal due to renameLimit Historically, the diff machinery for rename detection had a hardcoded limit of 32k paths; this is being lifted to allow users trade cycles with a (possibly) easier to read result. Will squash in the type-fix and merge to 'next'. * tz/redirect-fix (2017-11-14) 2 commits - rebase: fix stderr redirect in apply_autostash() - t/lib-gpg: fix gpgconf stderr redirect to /dev/null A few scripts (both in production and tests) incorrectly redirected their error output. These have been corrected. Wait for the third one and then merge to 'next'. -------------------------------------------------- [Stalled] * jn/ssh-wrappers (2017-10-30) 6 commits - fixup! ssh: 'auto' variant to select between 'ssh' and 'simple' - ssh: 'simple' variant does not support --port - ssh: 'simple' variant does not support -4/-6 - ssh: 'auto' variant to select between 'ssh' and 'simple' - connect: split ssh command line options into separate function - connect: split git:// setup into a separate function (this branch uses bw/protocol-v1.) The ssh-variant 'simple' introduced earlier broke existing installations by not passing --port/-4/-6 and not diagnosing an attempt to pass these as an error. Instead, default to automatically detect how compatible the GIT_SSH/GIT_SSH_COMMAND is to OpenSSH convention and then error out an invocation to make it easier to diagnose connection errors. Expecting a reroll. cf. <20171025163243.xmm7szrkwgblpgcc@xxxxxxxxxxxxxxxxxxxxxxxxx> * jc/merge-symlink-ours-theirs (2017-09-26) 1 commit - merge: teach -Xours/-Xtheirs to symbolic link merge "git merge -Xours/-Xtheirs" learned to use our/their version when resolving a conflicting updates to a symbolic link. Needs review. * mg/merge-base-fork-point (2017-09-17) 3 commits - merge-base: find fork-point outside partial reflog - merge-base: return fork-point outside reflog - t6010: test actual test output "merge-base --fork-point $branch $commit" is used to guess on which commit among the commits that were once at the tip of the $branch the $commit was built on top of, and it learns these historical tips from the reflog of the $branch. When the true fork-point is lost due to pruning of old reflog entries, the command does not give any output, because it has no way to guess correctly and does not want to mislead the user with a wrong guess. The command has been updated to give the best but not known to be correct guess, based on a hope that a merge-base between $commit and a virtual merge across all the reflog entries that still are available for $branch may still be a closer to the true fork-point than the merge-base between $commit and the current tip of the $branch. This may have to be offered by an additional option, to allow the users that are prepared to see a potentially incorrect guess to opt into the feature, without affecting the current callers that may not be prepared to accept a guess that is not known to be correct. What's the doneness of this one? * cc/perf-run-config (2017-09-24) 9 commits - perf: store subsection results in "test-results/$GIT_PERF_SUBSECTION/" - perf/run: show name of rev being built - perf/run: add run_subsection() - perf/run: update get_var_from_env_or_config() for subsections - perf/run: add get_subsections() - perf/run: add calls to get_var_from_env_or_config() - perf/run: add GIT_PERF_DIRS_OR_REVS - perf/run: add get_var_from_env_or_config() - perf/run: add '--config' option to the 'run' script Needs review. * jk/drop-ancient-curl (2017-08-09) 5 commits - http: #error on too-old curl - curl: remove ifdef'd code never used with curl >=7.19.4 - http: drop support for curl < 7.19.4 - http: drop support for curl < 7.16.0 - http: drop support for curl < 7.11.1 Some code in http.c that has bitrot is being removed. Expecting a reroll. * mk/use-size-t-in-zlib (2017-08-10) 1 commit . zlib.c: use size_t for size The wrapper to call into zlib followed our long tradition to use "unsigned long" for sizes of regions in memory, which have been updated to use "size_t". Needs resurrecting by making sure the fix is good and still applies (or adjusted to today's codebase). * mg/status-in-progress-info (2017-05-10) 2 commits - status --short --inprogress: spell it as --in-progress - status: show in-progress info for short status "git status" learns an option to report various operations (e.g. "merging") that the user is in the middle of. cf. <xmqqmvakcdqw.fsf@xxxxxxxxxxxxxxxxxxxxxxxxxxx> * nd/worktree-move (2017-04-20) 6 commits - worktree remove: new command - worktree move: refuse to move worktrees with submodules - worktree move: accept destination as directory - worktree move: new command - worktree.c: add update_worktree_location() - worktree.c: add validate_worktree() "git worktree" learned move and remove subcommands. Expecting a reroll. cf. <20170420101024.7593-1-pclouds@xxxxxxxxx> cf. <20170421145916.mknekgqzhxffu7di@xxxxxxxxxxxxxxxxxxxxx> cf. <d0e81b1e-5869-299e-f462-4d43dc997bd1@xxxxxxxxxxxxxxxxxxxx> -------------------------------------------------- [Cooking] * bw/rebase-i-ignored-submodule-fix (2017-11-07) 1 commit (merged to 'next' on 2017-11-10 at a0a54103ed) + wt-status: actually ignore submodules when requested "git rebase -i" recently started misbehaving when a submodule that is configured with 'submodule.<name>.ignore' is dirty; this has been corrected. Will merge to 'master'. * 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 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. * jt/submodule-tests-cleanup (2017-11-08) 1 commit (merged to 'next' on 2017-11-10 at c6cbcdeaa4) + Tests: clean up and document submodule helpers Will merge to 'master'. * js/for-each-ref-remote-name-and-ref (2017-11-08) 3 commits (merged to 'next' on 2017-11-10 at 254af5d602) + 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 'master'. * ma/bisect-leakfix (2017-11-06) 4 commits (merged to 'next' on 2017-11-09 at c280d786f4) + 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 'master'. * ma/reduce-heads-leakfix (2017-11-08) 2 commits (merged to 'next' on 2017-11-10 at 9428953ec8) + reduce_heads: fix memory leaks + builtin/merge-base: free commit lists Leak fixes. Will merge to 'master'. * sr/wrapper-quote-filenames (2017-11-06) 1 commit (merged to 'next' on 2017-11-09 at a14ac8da60) + 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 'master'. * 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.) * 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'. * ao/merge-verbosity-getenv-just-once (2017-11-01) 1 commit (merged to 'next' on 2017-11-09 at e7cfb8dcec) + merge-recursive: check GIT_MERGE_VERBOSITY only once Code cleanup. Will merge to 'master'. * bp/read-index-from-skip-verification (2017-11-08) 1 commit (merged to 'next' on 2017-11-10 at 3c3e32f1ed) + 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. Will merge to 'master'. * rs/sequencer-rewrite-file-cleanup (2017-11-02) 3 commits (merged to 'next' on 2017-11-09 at 06f45be770) + sequencer.c: check return value of close() in rewrite_file() + sequencer: use O_TRUNC to truncate files + sequencer: factor out rewrite_file() Code cleanup. Will merge to 'master'. * sb/describe-blob (2017-11-13) 7 commits - builtin/describe.c: describe a blob - builtin/describe.c: factor out describe_commit - builtin/describe.c: print debug statements earlier - builtin/describe.c: rename `oid` to avoid variable shadowing - revision.h: introduce blob/tree walking in order of the commits - list-objects.c: factor out traverse_trees_and_blobs - t6120: fix typo in test name "git describe" was taught to dig trees deeper to find a <commit-ish>:<path> that refers to a given blob object. * 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. * ab/mediawiki-name-truncation (2017-11-01) 1 commit (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 'master'. * ab/mediawiki-namespace (2017-11-08) 7 commits (merged to 'next' on 2017-11-10 at 1cf9cfdfbc) + remote-mediawiki: show progress while fetching namespaces + remote-mediawiki: process namespaces in order + remote-mediawiki: support fetching from (Main) namespace + remote-mediawiki: skip virtual namespaces + remote-mediawiki: show known namespace choices on failure + remote-mediawiki: allow fetching namespaces with spaces + remote-mediawiki: add namespace support The remote-helper for talking to MediaWiki has been updated to work with mediawiki namespaces. Will merge to 'master'. * mh/tidy-ref-update-flags (2017-11-06) 10 commits (merged to 'next' on 2017-11-09 at 5231330c1c) + refs: update some more docs to use "oid" rather than "sha1" + write_packed_entry(): take `object_id` arguments + refs: rename constant `REF_ISPRUNING` to `REF_IS_PRUNING` + refs: rename constant `REF_NODEREF` to `REF_NO_DEREF` + refs: tidy up and adjust visibility of the `ref_update` flags + ref_transaction_add_update(): remove a check + ref_transaction_update(): die on disallowed flags + prune_ref(): call `ref_transaction_add_update()` directly + files_transaction_prepare(): don't leak flags to packed transaction + Merge branch 'bc/object-id' into base Code clean-up in refs API implementation. Will merge to 'master'. * av/fsmonitor (2017-11-13) 7 commits (merged to 'next' on 2017-11-13 at db56ad7eef) + fsmonitor: simplify determining the git worktree under Windows + fsmonitor: store fsmonitor bitmap before splitting index + fsmonitor: read from getcwd(), not the PWD environment variable (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. Waiting for follow-on fixes to settle. * bp/fsmonitor (2017-10-05) 15 commits (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 + fsmonitor: add a performance test + fsmonitor: add a sample integration script for Watchman + fsmonitor: add test cases for fsmonitor extension + split-index: disable the fsmonitor extension when running the split index test + fsmonitor: add a test tool to dump the index extension + update-index: add fsmonitor support to update-index + ls-files: Add support in ls-files to display the fsmonitor valid bit + fsmonitor: add documentation for the fsmonitor extension. + fsmonitor: teach git to optionally utilize a file system monitor to speed up detecting new or changed files. + update-index: add a new --force-write-index option + preload-index: add override to enable testing preload-index + 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 follow-on fixes to settle. * bc/submitting-patches-in-asciidoc (2017-11-13) 2 commits (merged to 'next' on 2017-11-13 at 70f65b981a) + Documentation: convert SubmittingPatches to AsciiDoc + Documentation: enable compat-mode for Asciidoctor The SubmittingPatches document has been converted to produce an HTML version via AsciiDoc/Asciidoctor. Will merge to 'master'. * pb/bisect-helper-2 (2017-10-28) 8 commits - t6030: make various test to pass GETTEXT_POISON tests - bisect--helper: `bisect_start` shell function partially in C - bisect--helper: `get_terms` & `bisect_terms` shell function in C - bisect--helper: `bisect_next_check` shell function in C - bisect--helper: `check_and_set_terms` shell function in C - wrapper: move is_empty_file() and rename it as is_empty_or_missing_file() - bisect--helper: `bisect_write` shell function in C - bisect--helper: `bisect_reset` shell function in C Expecting a reroll. cf. <0102015f5e5ee171-f30f4868-886f-47a1-a4e4-b4936afc545d-000000@xxxxxxxxxxxxxxxxxxxxxxx> * 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. * mh/avoid-rewriting-packed-refs (2017-10-30) 2 commits (merged to 'next' on 2017-11-09 at 272e27cc9a) + files-backend: don't rewrite the `packed-refs` file unnecessarily + t1409: check that `packed-refs` is not rewritten unnecessarily Recent update to the refs infrastructure implementation started rewriting packed-refs file more often than before; this has been optimized again for most trivial cases. Will merge to 'master'. * cc/git-packet-pm (2017-11-07) 8 commits (merged to 'next' on 2017-11-10 at b40bc2c0bb) + 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. Will merge to 'master'. * jc/branch-name-sanity (2017-10-14) 3 commits - 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". Reported to cause problems when renaming HEAD during a rebase. cf. <49563f7c-354e-334e-03a6-c3a40884b6d0@xxxxxxxxx> * ot/mru-on-list (2017-10-01) 1 commit - 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. Is there any remaining issues on this one? * jm/svn-pushmergeinfo-fix (2017-09-17) 1 commit - git-svn: fix svn.pushmergeinfo handling of svn+ssh usernames. "git svn dcommit" did not take into account the fact that a svn+ssh:// URL with a username@ (typically used for pushing) refers to the same SVN repository without the username@ and failed when svn.pushmergeinfo option is set. Needs a test, perhaps as a follow-up patch. Will merge to 'next'. * bw/protocol-v1 (2017-10-17) 11 commits - 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 and demonstrated that it works with the older versions of Git without harming them. Waiting for jn/ssh-wrappers topic. * bc/hash-algo (2017-11-13) 4 commits - Switch empty tree and blob lookups to use hash abstraction - Integrate hash algorithm support with repo setup - Add structure representing hash algorithm - setup: expose enumerated repo info An infrastructure to define what hash function is used in Git is introduced, and an effort to plumb that throughout various codepaths has been started. Looked more or less OK to me. Ready to merge to 'next'? Further comments? * sb/submodule-recursive-checkout-detach-head (2017-07-28) 2 commits - 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. Expecting a reroll. -------------------------------------------------- [Discarded] * jk/ui-color-always-to-auto-maint (2017-10-13) 2 commits . 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 the end-user configuration is, and a recent attempt to downgrade 'always' to 'auto' to fix the regression to "git add -p" broke it. This has been reverted from 'next'. * jt/partial-clone-lazy-fetch (2017-10-02) 18 commits . fetch-pack: restore save_commit_buffer after use . unpack-trees: batch fetching of missing blobs . clone: configure blobmaxbytes in created repos . clone: support excluding large blobs . fetch: support excluding large blobs . fetch: refactor calculation of remote list . fetch-pack: support excluding large blobs . pack-objects: support --blob-max-bytes . pack-objects: rename want_.* to ignore_.* . gc: do not repack promisor packfiles . rev-list: support termination at promisor objects . 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 A journey for "git clone" and "git fetch" to become "lazier" by depending more on its remote repository---this is the beginning of it. Superseded by three topics that end with jh/partial-clone. * jh/dir-add-exclude-from-blob (2017-10-27) 1 commit . 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 refactored so that other codepath can later use it to do the same outside the context of "sparse checkout". Now part of jh/object-filtering topic.