| Git 2.23 Release Notes |
| ====================== |
| |
| Updates since v2.22 |
| ------------------- |
| |
| Backward compatibility note |
| |
| * The "--base" option of "format-patch" computed the patch-ids for |
| prerequisite patches in an unstable way, which has been updated to |
| compute in a way that is compatible with "git patch-id --stable". |
| |
| * The "git log" command by default behaves as if the --mailmap option |
| was given. |
| |
| |
| UI, Workflows & Features |
| |
| * The "git fast-export/import" pair has been taught to handle commits |
| with log messages in encoding other than UTF-8 better. |
| |
| * In recent versions of Git, per-worktree refs are exposed in |
| refs/worktrees/<wtname>/ hierarchy, which means that worktree names |
| must be a valid refname component. The code now sanitizes the names |
| given to worktrees, to make sure these refs are well-formed. |
| |
| * "git merge" learned "--quit" option that cleans up the in-progress |
| merge while leaving the working tree and the index still in a mess. |
| |
| * "git format-patch" learns a configuration to set the default for |
| its --notes=<ref> option. |
| |
| * The code to show args with potential typo that cannot be |
| interpreted as a commit-ish has been improved. |
| |
| * "git clone --recurse-submodules" learned to set up the submodules |
| to ignore commit object names recorded in the superproject gitlink |
| and instead use the commits that happen to be at the tip of the |
| remote-tracking branches from the get-go, by passing the new |
| "--remote-submodules" option. |
| |
| * The pattern "git diff/grep" use to extract funcname and words |
| boundary for Matlab has been extend to cover Octave, which is more |
| or less equivalent. |
| |
| * "git help git" was hard to discover (well, at least for some |
| people). |
| |
| * The pattern "git diff/grep" use to extract funcname and words |
| boundary for Rust has been added. |
| |
| * "git status" can be told a non-standard default value for the |
| "--[no-]ahead-behind" option with a new configuration variable |
| status.aheadBehind. |
| |
| * "git fetch" and "git pull" reports when a fetch results in |
| non-fast-forward updates to let the user notice unusual situation. |
| The commands learned "--no-show-forced-updates" option to disable |
| this safety feature. |
| |
| * Two new commands "git switch" and "git restore" are introduced to |
| split "checking out a branch to work on advancing its history" and |
| "checking out paths out of the index and/or a tree-ish to work on |
| advancing the current history" out of the single "git checkout" |
| command. |
| |
| * "git branch --list" learned to always output the detached HEAD as |
| the first item (when the HEAD is detached, of course), regardless |
| of the locale. |
| |
| * The conditional inclusion mechanism learned to base the choice on |
| the branch the HEAD currently is on. |
| |
| * "git rev-list --objects" learned the "--no-object-names" option to |
| squelch the path to the object that is used as a grouping hint for |
| pack-objects. |
| |
| * A new tag.gpgSign configuration variable turns "git tag -a" into |
| "git tag -s". |
| |
| * "git multi-pack-index" learned expire and repack subcommands. |
| |
| * "git blame" learned to "ignore" commits in the history, whose |
| effects (as well as their presence) get ignored. |
| |
| * "git cherry-pick/revert" learned a new "--skip" action. |
| |
| * The tips of refs from the alternate object store can be used as |
| starting point for reachability computation now. |
| |
| * Extra blank lines in "git status" output have been reduced. |
| |
| * The commits in a repository can be described by multiple |
| commit-graph files now, which allows the commit-graph files to be |
| updated incrementally. |
| |
| * "git range-diff" output has been tweaked for easier identification |
| of which part of what file the patch shown is about. |
| |
| |
| Performance, Internal Implementation, Development Support etc. |
| |
| * Update supporting parts of "git rebase" to remove code that should |
| no longer be used. |
| |
| * Developer support to emulate unsatisfied prerequisites in tests to |
| ensure that the remainder of the tests still succeeds when tests |
| with prerequisites are skipped. |
| |
| * "git update-server-info" learned not to rewrite the file with the |
| same contents. |
| |
| * The way of specifying the path to find dynamic libraries at runtime |
| has been simplified. The old default to pass -R/path/to/dir has been |
| replaced with the new default to pass -Wl,-rpath,/path/to/dir, |
| which is the more recent GCC uses. Those who need to build with an |
| old GCC can still use "CC_LD_DYNPATH=-R" |
| |
| * Prepare use of reachability index in topological walker that works |
| on a range (A..B). |
| |
| * A new tutorial targeting specifically aspiring git-core |
| developers has been added. |
| |
| * Auto-detect how to tell HP-UX aCC where to use dynamically linked |
| libraries from at runtime. |
| |
| * "git mergetool" and its tests now spawn fewer subprocesses. |
| |
| * Dev support update to help tracing out tests. |
| |
| * Support to build with MSVC has been updated. |
| |
| * "git fetch" that grabs from a group of remotes learned to run the |
| auto-gc only once at the very end. |
| |
| * A handful of Windows build patches have been upstreamed. |
| |
| * The code to read state files used by the sequencer machinery for |
| "git status" has been made more robust against a corrupt or stale |
| state files. |
| |
| * "git for-each-ref" with multiple patterns have been optimized. |
| |
| * The tree-walk API learned to pass an in-core repository |
| instance throughout more codepaths. |
| |
| * When one step in multi step cherry-pick or revert is reset or |
| committed, the command line prompt script failed to notice the |
| current status, which has been improved. |
| |
| * Many GIT_TEST_* environment variables control various aspects of |
| how our tests are run, but a few followed "non-empty is true, empty |
| or unset is false" while others followed the usual "there are a few |
| ways to spell true, like yes, on, etc., and also ways to spell |
| false, like no, off, etc." convention. |
| |
| * Adjust the dir-iterator API and apply it to the local clone |
| optimization codepath. |
| |
| * We have been trying out a few language features outside c89; the |
| coding guidelines document did not talk about them and instead had |
| a blanket ban against them. |
| |
| * A test helper has been introduced to optimize preparation of test |
| repositories with many simple commits, and a handful of test |
| scripts have been updated to use it. |
| |
| |
| Fixes since v2.22 |
| ----------------- |
| |
| * A relative pathname given to "git init --template=<path> <repo>" |
| ought to be relative to the directory "git init" gets invoked in, |
| but it instead was made relative to the repository, which has been |
| corrected. |
| |
| * "git worktree add" used to fail when another worktree connected to |
| the same repository was corrupt, which has been corrected. |
| |
| * The ownership rule for the file descriptor to fast-import remote |
| backend was mixed up, leading to an unrelated file descriptor getting |
| closed, which has been fixed. |
| |
| * A "merge -c" instruction during "git rebase --rebase-merges" should |
| give the user a chance to edit the log message, even when there is |
| otherwise no need to create a new merge and replace the existing |
| one (i.e. fast-forward instead), but did not. Which has been |
| corrected. |
| |
| * Code cleanup and futureproof. |
| |
| * More parameter validation. |
| |
| * "git update-server-info" used to leave stale packfiles in its |
| output, which has been corrected. |
| |
| * The server side support for "git fetch" used to show incorrect |
| value for the HEAD symbolic ref when the namespace feature is in |
| use, which has been corrected. |
| |
| * "git am -i --resolved" segfaulted after trying to see a commit as |
| if it were a tree, which has been corrected. |
| |
| * "git bundle verify" needs to see if prerequisite objects exist in |
| the receiving repository, but the command did not check if we are |
| in a repository upfront, which has been corrected. |
| |
| * "git merge --squash" is designed to update the working tree and the |
| index without creating the commit, and this cannot be countermanded |
| by adding the "--commit" option; the command now refuses to work |
| when both options are given. |
| |
| * The data collected by fsmonitor was not properly written back to |
| the on-disk index file, breaking t7519 tests occasionally, which |
| has been corrected. |
| |
| * Update to Unicode 12.1 width table. |
| |
| * The command line to invoke a "git cat-file" command from inside |
| "git p4" was not properly quoted to protect a caret and running a |
| broken command on Windows, which has been corrected. |
| |
| * "git request-pull" learned to warn when the ref we ask them to pull |
| from in the local repository and in the published repository are |
| different. |
| |
| * When creating a partial clone, the object filtering criteria is |
| recorded for the origin of the clone, but this incorrectly used a |
| hardcoded name "origin" to name that remote; it has been corrected |
| to honor the "--origin <name>" option. |
| |
| * "git fetch" into a lazy clone forgot to fetch base objects that are |
| necessary to complete delta in a thin packfile, which has been |
| corrected. |
| |
| * The filter_data used in the list-objects-filter (which manages a |
| lazily sparse clone repository) did not use the dynamic array API |
| correctly---'nr' is supposed to point at one past the last element |
| of the array in use. This has been corrected. |
| |
| * The description about slashes in gitignore patterns (used to |
| indicate things like "anchored to this level only" and "only |
| matches directories") has been revamped. |
| |
| * The URL decoding code has been updated to avoid going past the end |
| of the string while parsing %-<hex>-<hex> sequence. |
| |
| * The list of for-each like macros used by clang-format has been |
| updated. |
| |
| * "git branch --list" learned to show branches that are checked out |
| in other worktrees connected to the same repository prefixed with |
| '+', similar to the way the currently checked out branch is shown |
| with '*' in front. |
| (merge 6e9381469e nb/branch-show-other-worktrees-head later to maint). |
| |
| * Code restructuring during 2.20 period broke fetching tags via |
| "import" based transports. |
| |
| * The commit-graph file is now part of the "files that the runtime |
| may keep open file descriptors on, all of which would need to be |
| closed when done with the object store", and the file descriptor to |
| an existing commit-graph file now is closed before "gc" finalizes a |
| new instance to replace it. |
| |
| * "git checkout -p" needs to selectively apply a patch in reverse, |
| which did not work well. |
| |
| * Code clean-up to avoid signed integer wraparounds during binary search. |
| |
| * "git interpret-trailers" always treated '#' as the comment |
| character, regardless of core.commentChar setting, which has been |
| corrected. |
| |
| * "git stash show 23" used to work, but no more after getting |
| rewritten in C; this regression has been corrected. |
| |
| * "git rebase --abort" used to leave refs/rewritten/ when concluding |
| "git rebase -r", which has been corrected. |
| |
| * An incorrect list of options was cached after command line |
| completion failed (e.g. trying to complete a command that requires |
| a repository outside one), which has been corrected. |
| |
| * The code to parse scaled numbers out of configuration files has |
| been made more robust and also easier to follow. |
| |
| * The codepath to compute delta islands used to spew progress output |
| without giving the callers any way to squelch it, which has been |
| fixed. |
| |
| * Protocol capabilities that go over wire should never be translated, |
| but it was incorrectly marked for translation, which has been |
| corrected. The output of protocol capabilities for debugging has |
| been tweaked a bit. |
| |
| * Use "Erase in Line" CSI sequence that is already used in the editor |
| support to clear cruft in the progress output. |
| |
| * "git submodule foreach" did not protect command line options passed |
| to the command to be run in each submodule correctly, when the |
| "--recursive" option was in use. |
| |
| * The configuration variable rebase.rescheduleFailedExec should be |
| effective only while running an interactive rebase and should not |
| affect anything when running a non-interactive one, which was not |
| the case. This has been corrected. |
| |
| * The "git clone" documentation refers to command line options in its |
| description in the short form; they have been replaced with long |
| forms to make them more recognisable. |
| |
| * Generation of pack bitmaps are now disabled when .keep files exist, |
| as these are mutually exclusive features. |
| (merge 7328482253 ew/repack-with-bitmaps-by-default later to maint). |
| |
| * "git rm" to resolve a conflicted path leaked an internal message |
| "needs merge" before actually removing the path, which was |
| confusing. This has been corrected. |
| |
| * "git stash --keep-index" did not work correctly on paths that have |
| been removed, which has been fixed. |
| (merge b932f6a5e8 tg/stash-keep-index-with-removed-paths later to maint). |
| |
| * Window 7 update ;-) |
| |
| * A codepath that reads from GPG for signed object verification read |
| past the end of allocated buffer, which has been fixed. |
| |
| * "git clean" silently skipped a path when it cannot lstat() it; now |
| it gives a warning. |
| |
| * "git push --atomic" that goes over the transport-helper (namely, |
| the smart http transport) failed to prevent refs to be pushed when |
| it can locally tell that one of the ref update will fail without |
| having to consult the other end, which has been corrected. |
| |
| * The internal diff machinery can be made to read out of bounds while |
| looking for --function-context line in a corner case, which has been |
| corrected. |
| (merge b777f3fd61 jk/xdiff-clamp-funcname-context-index later to maint). |
| |
| * Other code cleanup, docfix, build fix, etc. |
| (merge fbec05c210 cc/test-oidmap later to maint). |
| (merge 7a06fb038c jk/no-system-includes-in-dot-c later to maint). |
| (merge 81ed2b405c cb/xdiff-no-system-includes-in-dot-c later to maint). |
| (merge d61e6ce1dd sg/fsck-config-in-doc later to maint). |