342 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			342 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Plaintext
		
	
	
| Git 2.26 Release Notes
 | |
| ======================
 | |
| 
 | |
| Updates since v2.25
 | |
| -------------------
 | |
| 
 | |
| Backward compatibility notes
 | |
| 
 | |
|  * "git rebase" uses a different backend that is based on the 'merge'
 | |
|    machinery by default.  There are a few known differences in the
 | |
|    behaviour from the traditional machinery based on patch+apply.
 | |
| 
 | |
|    If your workflow is negatively affected by this change, please
 | |
|    report it to git@vger.kernel.org so that we can take a look into
 | |
|    it.  After doing so, you can set the 'rebase.backend' configuration
 | |
|    variable to 'apply', in order to use the old default behaviour in
 | |
|    the meantime.
 | |
| 
 | |
| 
 | |
| UI, Workflows & Features
 | |
| 
 | |
|  * Sample credential helper for using .netrc has been updated to work
 | |
|    out of the box.
 | |
| 
 | |
|  * gpg.minTrustLevel configuration variable has been introduced to
 | |
|    tell various signature verification codepaths the required minimum
 | |
|    trust level.
 | |
| 
 | |
|  * The command line completion (in contrib/) learned to complete
 | |
|    subcommands and arguments to "git worktree".
 | |
| 
 | |
|  * Disambiguation logic to tell revisions and pathspec apart has been
 | |
|    tweaked so that backslash-escaped glob special characters do not
 | |
|    count in the "wildcards are pathspec" rule.
 | |
| 
 | |
|  * One effect of specifying where the GIT_DIR is (either with the
 | |
|    environment variable, or with the "git --git-dir=<where> cmd"
 | |
|    option) is to disable the repository discovery.  This has been
 | |
|    placed a bit more stress in the documentation, as new users often
 | |
|    get confused.
 | |
| 
 | |
|  * Two help messages given when "git add" notices the user gave it
 | |
|    nothing to add have been updated to use advise() API.
 | |
| 
 | |
|  * A new version of fsmonitor-watchman hook has been introduced, to
 | |
|    avoid races.
 | |
| 
 | |
|  * "git config" learned to show in which "scope", in addition to in
 | |
|    which file, each config setting comes from.
 | |
| 
 | |
|  * The basic 7 colors learned the brighter counterparts
 | |
|    (e.g. "brightred").
 | |
| 
 | |
|  * "git sparse-checkout" learned a new "add" subcommand.
 | |
| 
 | |
|  * A configuration element used for credential subsystem can now use
 | |
|    wildcard pattern to specify for which set of URLs the entry
 | |
|    applies.
 | |
| 
 | |
|  * "git clone --recurse-submodules --single-branch" now uses the same
 | |
|    single-branch option when cloning the submodules.
 | |
| 
 | |
|  * "git rm" and "git stash" learns the new "--pathspec-from-file"
 | |
|    option.
 | |
| 
 | |
|  * "git am --show-current-patch" is a way to show the piece of e-mail
 | |
|    for the stopped step, which is not suitable to directly feed "git
 | |
|    apply" (it is designed to be a good "git am" input).  It learned a
 | |
|    new option to show only the patch part.
 | |
| 
 | |
|  * Handling of conflicting renames in merge-recursive have further
 | |
|    been made consistent with how existing codepaths try to mimic what
 | |
|    is done to add/add conflicts.
 | |
| 
 | |
| 
 | |
| Performance, Internal Implementation, Development Support etc.
 | |
| 
 | |
|  * Tell .editorconfig that in this project, *.txt files are indented
 | |
|    with tabs.
 | |
| 
 | |
|  * The test-lint machinery knew to check "VAR=VAL shell_function"
 | |
|    construct, but did not check "VAR= shell_function", which has been
 | |
|    corrected.
 | |
| 
 | |
|  * Replace "git config --bool" calls with "git config --type=bool" in
 | |
|    sample templates.
 | |
| 
 | |
|  * The effort to move "git-add--interactive" to C continues.
 | |
| 
 | |
|  * Improve error message generation for "git submodule add".
 | |
| 
 | |
|  * Preparation of test scripts for the day when the object names will
 | |
|    use SHA-256 continues.
 | |
| 
 | |
|  * Warn programmers about pretend_object_file() that allows the code
 | |
|    to tentatively use in-core objects.
 | |
| 
 | |
|  * The way "git pack-objects" reuses objects stored in existing pack
 | |
|    to generate its result has been improved.
 | |
| 
 | |
|  * The transport protocol version 2 becomes the default one.
 | |
| 
 | |
|  * Traditionally, we avoided threaded grep while searching in objects
 | |
|    (as opposed to files in the working tree) as accesses to the object
 | |
|    layer is not thread-safe.  This limitation is getting lifted.
 | |
| 
 | |
|  * "git rebase -i" (and friends) used to unnecessarily check out the
 | |
|    tip of the branch to be rebased, which has been corrected.
 | |
| 
 | |
|  * A low-level API function get_oid(), that accepts various ways to
 | |
|    name an object, used to issue end-user facing error messages
 | |
|    without l10n, which has been updated to be translatable.
 | |
| 
 | |
|  * Unneeded connectivity check is now disabled in a partial clone when
 | |
|    fetching into it.
 | |
| 
 | |
|  * Some rough edges in the sparse-checkout feature, especially around
 | |
|    the cone mode, have been cleaned up.
 | |
| 
 | |
|  * The diff-* plumbing family of subcommands now pay attention to the
 | |
|    diff.wsErrorHighlight configuration, which has been ignored before;
 | |
|    this allows "git add -p" to also show the whitespace problems to
 | |
|    the end user.
 | |
| 
 | |
|  * Some codepaths were given a repository instance as a parameter to
 | |
|    work in the repository, but passed the_repository instance to its
 | |
|    callees, which has been cleaned up (somewhat).
 | |
| 
 | |
|  * Memory footprint and performance of "git name-rev" has been
 | |
|    improved.
 | |
| 
 | |
|  * The object reachability bitmap machinery and the partial cloning
 | |
|    machinery were not prepared to work well together, because some
 | |
|    object-filtering criteria that partial clones use inherently rely
 | |
|    on object traversal, but the bitmap machinery is an optimization
 | |
|    to bypass that object traversal.  There however are some cases
 | |
|    where they can work together, and they were taught about them.
 | |
| 
 | |
|  * "git rebase" has learned to use the merge backend (i.e. the
 | |
|    machinery that drives "rebase -i") by default, while allowing
 | |
|    "--apply" option to use the "apply" backend (e.g. the moral
 | |
|    equivalent of "format-patch piped to am").  The rebase.backend
 | |
|    configuration variable can be set to customize.
 | |
| 
 | |
|  * Underlying machinery of "git bisect--helper" is being refactored
 | |
|    into pieces that are more easily reused.
 | |
| 
 | |
| 
 | |
| Fixes since v2.25
 | |
| -----------------
 | |
| 
 | |
|  * "git commit" gives output similar to "git status" when there is
 | |
|    nothing to commit, but without honoring the advise.statusHints
 | |
|    configuration variable, which has been corrected.
 | |
| 
 | |
|  * has_object_file() said "no" given an object registered to the
 | |
|    system via pretend_object_file(), making it inconsistent with
 | |
|    read_object_file(), causing lazy fetch to attempt fetching an
 | |
|    empty tree from promisor remotes.
 | |
| 
 | |
|  * Complete an update to tutorial that encourages "git switch" over
 | |
|    "git checkout" that was done only half-way.
 | |
| 
 | |
|  * C pedantry ;-) fix.
 | |
| 
 | |
|  * The code that tries to skip over the entries for the paths in a
 | |
|    single directory using the cache-tree was not careful enough
 | |
|    against corrupt index file.
 | |
| 
 | |
|  * Reduce unnecessary round-trip when running "ls-remote" over the
 | |
|    stateless RPC mechanism.
 | |
| 
 | |
|  * "git restore --staged" did not correctly update the cache-tree
 | |
|    structure, resulting in bogus trees to be written afterwards, which
 | |
|    has been corrected.
 | |
| 
 | |
|  * The code recently added to move to the entry beyond the ones in the
 | |
|    same directory in the index in the sparse-cone mode did not count
 | |
|    the number of entries to skip over incorrectly, which has been
 | |
|    corrected.
 | |
| 
 | |
|  * Rendering by "git log --graph" of ancestry lines leading to a merge
 | |
|    commit were made suboptimal to waste vertical space a bit with a
 | |
|    recent update, which has been corrected.
 | |
| 
 | |
|  * Work around test breakages caused by custom regex engine used in
 | |
|    libasan, when address sanitizer is used with more recent versions
 | |
|    of gcc and clang.
 | |
| 
 | |
|  * Minor bugfixes to "git add -i" that has recently been rewritten in C.
 | |
| 
 | |
|  * "git fetch --refmap=" option has got a better documentation.
 | |
| 
 | |
|  * "git checkout X" did not correctly fail when X is not a local
 | |
|    branch but could name more than one remote-tracking branches
 | |
|    (i.e. to be dwimmed as the starting point to create a corresponding
 | |
|    local branch), which has been corrected.
 | |
|    (merge fa74180d08 am/checkout-file-and-ref-ref-ambiguity later to maint).
 | |
| 
 | |
|  * Corner case bugs in "git clean" that stems from a (necessarily for
 | |
|    performance reasons) awkward calling convention in the directory
 | |
|    enumeration API has been corrected.
 | |
| 
 | |
|  * A fetch that is told to recursively fetch updates in submodules
 | |
|    inevitably produces reams of output, and it becomes hard to spot
 | |
|    error messages.  The command has been taught to enumerate
 | |
|    submodules that had errors at the end of the operation.
 | |
|    (merge 0222540827 es/fetch-show-failed-submodules-atend later to maint).
 | |
| 
 | |
|  * The "--recurse-submodules" option of various subcommands did not
 | |
|    work well when run in an alternate worktree, which has been
 | |
|    corrected.
 | |
| 
 | |
|  * Futureproofing a test not to depend on the current implementation
 | |
|    detail.
 | |
| 
 | |
|  * Running "git rm" on a submodule failed unnecessarily when
 | |
|    .gitmodules is only cache-dirty, which has been corrected.
 | |
| 
 | |
|  * C pedantry ;-) fix.
 | |
| 
 | |
|  * "git grep --no-index" should not get affected by the contents of
 | |
|    the .gitmodules file but when "--recurse-submodules" is given or
 | |
|    the "submodule.recurse" variable is set, it did.  Now these
 | |
|    settings are ignored in the "--no-index" mode.
 | |
| 
 | |
|  * Technical details of the bundle format has been documented.
 | |
| 
 | |
|  * Unhelpful warning messages during documentation build have been squelched.
 | |
| 
 | |
|  * "git rebase -i" identifies existing commits in its todo file with
 | |
|    their abbreviated object name, which could become ambiguous as it
 | |
|    goes to create new commits, and has a mechanism to avoid ambiguity
 | |
|    in the main part of its execution.  A few other cases however were
 | |
|    not covered by the protection against ambiguity, which has been
 | |
|    corrected.
 | |
| 
 | |
|  * Allow the rebase.missingCommitsCheck configuration to kick in when
 | |
|    "rebase --edit-todo" and "rebase --continue" restarts the procedure.
 | |
|    (merge 5a5445d878 ag/edit-todo-drop-check later to maint).
 | |
| 
 | |
|  * The way "git submodule status" reports an initialized but not yet
 | |
|    populated submodule has not been reimplemented correctly when a
 | |
|    part of the "git submodule" command was rewritten in C, which has
 | |
|    been corrected.
 | |
|    (merge f38c92452d pk/status-of-uncloned-submodule later to maint).
 | |
| 
 | |
|  * The code to automatically shrink the fan-out in the notes tree had
 | |
|    an off-by-one bug, which has been killed.
 | |
| 
 | |
|  * The index-pack code now diagnoses a bad input packstream that
 | |
|    records the same object twice when it is used as delta base; the
 | |
|    code used to declare a software bug when encountering such an
 | |
|    input, but it is an input error.
 | |
| 
 | |
| 
 | |
|  * The code to compute the commit-graph has been taught to use a more
 | |
|    robust way to tell if two object directories refer to the same
 | |
|    thing.
 | |
|    (merge a7df60cac8 tb/commit-graph-object-dir later to maint).
 | |
| 
 | |
|  * "git remote rename X Y" needs to adjust configuration variables
 | |
|    (e.g. branch.<name>.remote) whose value used to be X to Y.
 | |
|    branch.<name>.pushRemote is now also updated.
 | |
| 
 | |
|  * Update to doc-diff.
 | |
| 
 | |
|  * Doc markup fix.
 | |
| 
 | |
|  * "git check-ignore" did not work when the given path is explicitly
 | |
|    marked as not ignored with a negative entry in the .gitignore file.
 | |
| 
 | |
|  * The merge-recursive machinery failed to refresh the cache entry for
 | |
|    a merge result in a couple of places, resulting in an unnecessary
 | |
|    merge failure, which has been fixed.
 | |
| 
 | |
|  * Fix for a bug revealed by a recent change to make the protocol v2
 | |
|    the default.
 | |
| 
 | |
|  * In rare cases "git worktree add <path>" could think that <path>
 | |
|    was already a registered worktree even when it wasn't and refuse
 | |
|    to add the new worktree. This has been corrected.
 | |
|    (merge bb69b3b009 es/worktree-avoid-duplication-fix later to maint).
 | |
| 
 | |
|  * "git push" should stop from updating a branch that is checked out
 | |
|    when receive.denyCurrentBranch configuration is set, but it failed
 | |
|    to pay attention to checkouts in secondary worktrees.  This has
 | |
|    been corrected.
 | |
|    (merge 4d864895a2 hv/receive-denycurrent-everywhere later to maint).
 | |
| 
 | |
|  * "git rebase BASE BRANCH" rebased/updated the tip of BRANCH and
 | |
|    checked it out, even when the BRANCH is checked out in a different
 | |
|    worktree.  This has been corrected.
 | |
|    (merge b5cabb4a96 es/do-not-let-rebase-switch-to-protected-branch later to maint).
 | |
| 
 | |
|  * "git describe" in a repository with multiple root commits sometimes
 | |
|    gave up looking for the best tag to describe a given commit with
 | |
|    too early, which has been adjusted.
 | |
| 
 | |
|  * "git merge signed-tag" while lacking the public key started to say
 | |
|    "No signature", which was utterly wrong.  This regression has been
 | |
|    reverted.
 | |
| 
 | |
|  * MinGW's poll() emulation has been improved.
 | |
| 
 | |
|  * "git show" and others gave an object name in raw format in its
 | |
|    error output, which has been corrected to give it in hex.
 | |
| 
 | |
|  * "git fetch" over HTTP walker protocol did not show any progress
 | |
|    output.  We inherently do not know how much work remains, but still
 | |
|    we can show something not to bore users.
 | |
|    (merge 7655b4119d rs/show-progress-in-dumb-http-fetch later to maint).
 | |
| 
 | |
|  * Both "git ls-remote -h" and "git grep -h" give short usage help,
 | |
|    like any other Git subcommand, but it is not unreasonable to expect
 | |
|    that the former would behave the same as "git ls-remote --head"
 | |
|    (there is no other sensible behaviour for the latter).  The
 | |
|    documentation has been updated in an attempt to clarify this.
 | |
| 
 | |
|  * Other code cleanup, docfix, build fix, etc.
 | |
|    (merge d0d0a357a1 am/update-pathspec-f-f-tests later to maint).
 | |
|    (merge f94f7bd00d am/test-pathspec-f-f-error-cases later to maint).
 | |
|    (merge c513a958b6 ss/t6025-modernize later to maint).
 | |
|    (merge b441717256 dl/test-must-fail-fixes later to maint).
 | |
|    (merge d031049da3 mt/sparse-checkout-doc-update later to maint).
 | |
|    (merge 145136a95a jc/skip-prefix later to maint).
 | |
|    (merge 5290d45134 jk/alloc-cleanups later to maint).
 | |
|    (merge 7a9f8ca805 rs/parse-options-concat-dup later to maint).
 | |
|    (merge 517b60564e rs/strbuf-insertstr later to maint).
 | |
|    (merge f696a2b1c8 jk/mailinfo-cleanup later to maint).
 | |
|    (merge de26f02db1 js/test-avoid-pipe later to maint).
 | |
|    (merge a2dc43414c es/doc-mentoring later to maint).
 | |
|    (merge 02bbbe9df9 es/worktree-cleanup later to maint).
 | |
|    (merge 2ce6d075fa rs/micro-cleanups later to maint).
 | |
|    (merge 27f182b3fc rs/blame-typefix-for-fingerprint later to maint).
 | |
|    (merge 3c29e21eb0 ma/test-cleanup later to maint).
 | |
|    (merge 240fc04f81 ag/rebase-remove-redundant-code later to maint).
 | |
|    (merge d68ce906c7 rs/commit-graph-code-simplification later to maint).
 | |
|    (merge a51d9e8f07 rj/t1050-use-test-path-is-file later to maint).
 | |
|    (merge fd0bc17557 kk/complete-diff-color-moved later to maint).
 | |
|    (merge 65bf820d0e en/test-cleanup later to maint).
 |