| Git v2.39 Release Notes |
| ======================= |
| |
| UI, Workflows & Features |
| ------------------------ |
| |
| * "git grep" learned to expand the sparse-index more lazily and on |
| demand in a sparse checkout. |
| |
| * By default, use of fsmonitor on a repository on networked |
| filesystem is disabled. Add knobs to make it workable on macOS. |
| |
| * After checking out a "branch" that is a symbolic-ref that points at |
| another branch, "git symbolic-ref HEAD" reports the underlying |
| branch, not the symbolic-ref the user gave checkout as argument. |
| The command learned the "--no-recurse" option to stop after |
| dereferencing a symbolic-ref only once. |
| |
| * "git branch --edit-description @{-1}" is now a way to edit branch |
| description of the branch you were on before switching to the |
| current branch. |
| |
| * "git merge-tree --stdin" is a new way to request a series of merges |
| and report the merge results. |
| |
| * "git shortlog" learned to group by the "format" string. |
| |
| * A new "--include-whitespace" option is added to "git patch-id", and |
| existing bugs in the internal patch-id logic that did not match |
| what "git patch-id" produces have been corrected. |
| |
| * Enable gc.cruftpacks by default for those who opt into |
| feature.experimental setting. |
| |
| * "git repack" learns to send cruft objects out of the way into |
| packfiles outside the repository. |
| |
| * 'scalar reconfigure -a' is taught to automatically remove |
| scalar.repo entires which no longer exist. |
| |
| * Redact headers from cURL's h2h3 module in GIT_CURL_VERBOSE and |
| others. |
| |
| * 'git maintenance register' is taught to write configuration to an |
| arbitrary path, and 'git for-each-repo' is taught to expand tilde |
| characters in paths. |
| |
| * When creating new notes, the template used to get a stray empty |
| newline, which has been removed. |
| |
| * "git receive-pack" used to use all the local refs as the boundary for |
| checking connectivity of the data "git push" sent, but now it uses |
| only the refs that it advertised to the pusher. In a repository with |
| the .hideRefs configuration, this reduces the resources needed to |
| perform the check. |
| |
| * With '--recurse-submodules=on-demand', all submodules are |
| recursively pushed. |
| |
| |
| Performance, Internal Implementation, Development Support etc. |
| -------------------------------------------------------------- |
| |
| * With a bit of header twiddling, use the native regexp library on |
| macOS instead of the compat/ one. |
| |
| * Prepare for GNU [ef]grep that throw warning of their uses. |
| |
| * Sources related to fuzz testing have been moved down to their own |
| directory. |
| |
| * Most credential helpers ignored unknown entries in a credential |
| description, but a few died upon seeing them. The latter were |
| taught to ignore them, too |
| |
| * "scalar unregister" in a repository that is already been |
| unregistered reported an error. |
| |
| * Remove error detection from a function that fetches from promisor |
| remotes, and make it die when such a fetch fails to bring all the |
| requested objects, to give an early failure to various operations. |
| |
| * Update CodingGuidelines to clarify what features to use and avoid |
| in C99. |
| |
| * Avoid false-positive from LSan whose assumption may be broken with |
| higher optimization levels. |
| |
| * Enable address and undefined sanitizer tasks at GitHub Actions CI. |
| |
| * More UNUSED annotation to help using -Wunused option with the |
| compiler. |
| (merge 4b992f0a24 jk/unused-anno-more later to maint). |
| |
| * Rewrite a deep recursion in the skipping negotiator to use a loop |
| with on-heap prio queue to avoid stack wastage. |
| |
| * Add documentation for message IDs in fsck error messages. |
| |
| * Define the logical elements of a "bundle list", data structure to |
| store them in-core, format to transfer them, and code to parse |
| them. |
| |
| * The role the security mailing list plays in an embargoed release |
| has been documented. |
| |
| * Two new facilities, "timer" and "counter", are introduced to the |
| trace2 API. |
| |
| * Code simplification by using strvec_pushf() instead of building an |
| argument in a separate strbuf. |
| |
| * Make sure generated dependency file is stably sorted to help |
| developers debugging their build issues. |
| |
| * The glossary entries for "commit-graph file" and "reachability |
| bitmap" have been added. |
| |
| * Various tests exercising the transfer.credentialsInUrl |
| configuration are taught to avoid making requests which require |
| resolving localhost to reduce CI-flakiness. |
| |
| * A redundant diagnostic message is dropped from test_path_is_missing(). |
| |
| * Simplify the run-command API. |
| |
| * Update the actions/github-script dependency in CI to avoid a |
| deprecation warning. |
| |
| * Progress on being able to initialize a rev_info struct with a |
| macro. |
| |
| * Add trace2 counters to the region to clear skip worktree bits in a |
| sparse checkout. |
| |
| * Modernize test script to avoid "test -f" and friends. |
| |
| * Avoid calling 'cache_tree_update()' when doing so would be |
| redundant. |
| |
| * Update the credential-cache documentation to provide a more |
| realistic example. |
| |
| * Makefile comments updates and reordering to clarify knobs used to |
| choose SHA implementations. |
| |
| * A design document for sparse-checkout's future directions has been |
| added. |
| |
| * Teach chainlint.pl to annotate the original test definition instead |
| of the token stream. |
| |
| * "make coccicheck" is time consuming. It has been made to run more |
| incrementally. |
| |
| * `parse_object()` has been hardened to check for the existence of a |
| suspected blob object. |
| |
| * The build procedure has been adjusted to GNUmake version 4.4, which |
| made some changes to how pattern rule with multiple targets are |
| handled. |
| |
| |
| Fixes since v2.38 |
| ----------------- |
| |
| * The codepath that reads from the index v4 had unaligned memory |
| accesses, which has been corrected. |
| |
| * Fix messages incorrectly marked for translation. |
| |
| * "git fsck" failed to release contents of tree objects already used |
| from the memory, which has been fixed. |
| |
| * "git clone" did not like to see the "--bare" and the "--origin" |
| options used together without a good reason. |
| |
| * "git remote rename" failed to rename a remote without fetch |
| refspec, which has been corrected. |
| |
| * Documentation on various Boolean GIT_* environment variables have |
| been clarified. |
| |
| * "git rebase -i" can mistakenly attempt to apply a fixup to a commit |
| itself, which has been corrected. |
| |
| * "git multi-pack-index repack/expire" used to repack unreachable |
| cruft into a new pack, which have been corrected. |
| |
| * In read-only repositories, "git merge-tree" tried to come up with a |
| merge result tree object, which it failed (which is not wrong) and |
| led to a segfault (which is bad), which has been corrected. |
| |
| * Force C locale while running tests around httpd to make sure we can |
| find expected error messages in the log. |
| |
| * Fix a logic in "mailinfo -b" that miscomputed the length of a |
| substring, which lead to an out-of-bounds access. |
| |
| * The codepath to sign learned to report errors when it fails to read |
| from "ssh-keygen". |
| |
| * Code clean-up that results in plugging a leak. |
| |
| * "GIT_EDITOR=: git branch --edit-description" resulted in failure, |
| which has been corrected. |
| |
| * The code to clean temporary object directories (used for |
| quarantine) tried to remove them inside its signal handler, which |
| was a no-no. |
| |
| * Update comment in the Makefile about the RUNTIME_PREFIX config knob. |
| |
| * Clarify that "the sentence after <area>: prefix does not begin with |
| a capital letter" rule applies only to the commit title. |
| |
| * "git branch --edit-description" on an unborn branch misleadingly |
| said that no such branch exists, which has been corrected. |
| |
| * Work around older clang that warns against C99 zero initialization |
| syntax for struct. |
| |
| * Giving "--invert-grep" and "--all-match" without "--grep" to the |
| "git log" command resulted in an attempt to access grep pattern |
| expression structure that has not been allocated, which has been |
| corrected. |
| (merge db84376f98 ab/grep-simplify-extended-expression later to maint). |
| |
| * "git diff rev^!" did not show combined diff to go to the rev from |
| its parents. |
| (merge a79c6b6081 rs/diff-caret-bang-with-parents later to maint). |
| |
| * Allow configuration files in "protected" scopes to include other |
| configuration files. |
| (merge ecec57b3c9 gc/bare-repo-discovery later to maint). |
| |
| * Give a bit more diversity to macOS CI by using sha1dc in one of the |
| jobs (the other one tests Apple Common Crypto). |
| (merge 1ad5c3df35 jc/ci-osx-with-sha1dc later to maint). |
| |
| * A bugfix with tracing support in midx codepath |
| (merge e9c3839944 tb/midx-bitmap-selection-fix later to maint). |
| |
| * When geometric repacking feature is in use together with the |
| --pack-kept-objects option, we lost packs marked with .keep files. |
| (merge 197443e80a tb/save-keep-pack-during-geometric-repack later to maint). |
| |
| * Move a global variable added as a hack during regression fixes to |
| its proper place in the API. |
| (merge 0b0ab95f17 ab/run-hook-api-cleanup later to maint). |
| |
| * Update to build procedure with VS using CMake/CTest. |
| (merge c858750b41 js/cmake-updates later to maint). |
| |
| * The short-help text shown by "git cmd -h" and the synopsis text |
| shown at the beginning of "git help cmd" have been made more |
| consistent. |
| |
| * When creating a multi-pack bitmap, remove per-pack bitmap files |
| unconditionally as they will never be consulted. |
| (merge 55d902cd61 tb/remove-unused-pack-bitmap later to maint). |
| |
| * Fix a longstanding syntax error in Git.pm error codepath. |
| |
| * "git diff --stat" etc. were invented back when everything was ASCII |
| and strlen() was a way to measure the display width of a string; |
| adjust them to compute the display width assuming UTF-8 pathnames. |
| (merge ce8529b2bb tb/diffstat-with-utf8-strwidth later to maint). |
| |
| * "git branch --edit-description" can exit with status -1 which is |
| not a good practice; it learned to use 1 as everybody else instead. |
| |
| * "git apply" limits its input to a bit less than 1 GiB. |
| |
| * Merging a branch with directory renames into a branch that changes |
| the directory to a symlink was mishandled by the ort merge |
| strategy, which has been corrected. |
| |
| * A bugfix to "git subtree" in its split and merge features. |
| |
| * Fix some bugs in the reflog messages when rebasing and changes the |
| reflog messages of "rebase --apply" to match "rebase --merge" with |
| the aim of making the reflog easier to parse. |
| |
| * "git rebase --keep-base" used to discard the commits that are |
| already cherry-picked to the upstream, even when "keep-base" meant |
| that the base, on top of which the history is being rebuilt, does |
| not yet include these cherry-picked commits. The --keep-base |
| option now implies --reapply-cherry-picks and --no-fork-point |
| options. |
| |
| * The way "git repack" created temporary files when it received a |
| signal was prone to deadlocking, which has been corrected. |
| |
| * Various tests exercising the transfer.credentialsInUrl |
| configuration are taught to avoid making requests which require |
| resolving localhost to reduce CI-flakiness. |
| |
| * The adjust_shared_perm() helper function learned to refrain from |
| setting the "g+s" bit on directories when it is not necessary. |
| |
| * "git archive" mistakenly complained twice about a missing |
| executable, which has been corrected. |
| |
| * Fix a bug where `git branch -d` did not work on an orphaned HEAD. |
| |
| * `git rebase --update-refs` would delete references when all |
| `update-ref` commands in the sequencer were removed, which has been |
| corrected. |
| |
| * Fix a regression in the bisect-helper which mistakenly treats |
| arguments to the command given to 'git bisect run' as arguments to |
| the helper. |
| |
| * Correct an error where `git rebase` would mistakenly use a branch or |
| tag named "refs/rewritten/xyz" when missing a rebase label. |
| |
| * Assorted fixes of parsing end-user input as integers. |
| (merge 14770cf0de pw/config-int-parse-fixes later to maint). |
| |
| * "git prune" may try to iterate over .git/objects/pack for trash |
| files to remove in it, and loudly fail when the directory is |
| missing, which is not necessary. The command has been taught to |
| ignore such a failure. |
| (merge 6974765352 ew/prune-with-missing-objects-pack later to maint). |
| |
| * Add one more candidate directory that may house httpd modules while |
| running tests. |
| (merge 1c7dc23d41 es/locate-httpd-module-location-in-test later to maint). |
| |
| * A handful of leaks in the line-log machinery have been plugged. |
| |
| * The format of a line in /proc/cpuinfo that describes a CPU on s390x |
| looked different from everybody else, and the code in chainlint.pl |
| failed to parse it. |
| (merge 1f51b77f4f ah/chainlint-cpuinfo-parse-fix later to maint). |
| |
| * Adjust the GitHub CI to newer ubuntu release. |
| (merge 0d3507f3e7 jx/ci-ubuntu-fix later to maint). |
| |
| * Other code cleanup, docfix, build fix, etc. |
| (merge 413bc6d20a ds/cmd-main-reorder later to maint). |
| (merge 8d2863e4ed nw/t1002-cleanup later to maint). |
| (merge 7c2dc122f9 rs/list-objects-filter-leakfix later to maint). |
| (merge 288fcb1c94 zk/push-use-bitmaps later to maint). |
| (merge 42db324c0f km/merge-recursive-typofix later to maint). |