Merge branch 'js/range-diff-wo-dotdot'
[git/debian.git] / Documentation / RelNotes / 2.31.0.txt
blobaae9204663c7a93f76fdfbefadffadcf8c09a4c9
1 Git 2.31 Release Notes
2 ======================
4 Updates since v2.30
5 -------------------
7 Backward incompatible and other important changes
9  * The "pack-redundant" command, which has been left stale with almost
10    unusable performance issues, now warns loudly when it gets used, as
11    we no longer want to recommend its use (instead just "repack -d"
12    instead).
14  * The development community has adopted Contributor Covenant v2.0 to
15    update from v1.4 that we have been using.
17  * The support for deprecated PCRE1 library has been dropped.
20 UI, Workflows & Features
22  * The "--format=%(trailers)" mechanism gets enhanced to make it
23    easier to design output for machine consumption.
25  * When a user does not tell "git pull" to use rebase or merge, the
26    command gives a loud message telling a user to choose between
27    rebase or merge but creates a merge anyway, forcing users who would
28    want to rebase to redo the operation.  Fix an early part of this
29    problem by tightening the condition to give the message---there is
30    no reason to stop or force the user to choose between rebase or
31    merge if the history fast-forwards.
33  * The configuration variable 'core.abbrev' can be set to 'no' to
34    force no abbreviation regardless of the hash algorithm.
36  * "git rev-parse" can be explicitly told to give output as absolute
37    or relative path with the `--path-format=(absolute|relative)` option.
39  * Bash completion (in contrib/) update to make it easier for
40    end-users to add completion for their custom "git" subcommands.
42  * "git maintenance" learned to drive scheduled maintenance on
43    platforms whose native scheduling methods are not 'cron'.
45  * After expiring a reflog and making a single commit, the reflog for
46    the branch would record a single entry that knows both @{0} and
47    @{1}, but we failed to answer "what commit were we on?", i.e. @{1}
49  * "git bundle" learns "--stdin" option to read its refs from the
50    standard input.  Also, it now does not lose refs whey they point
51    at the same object.
53  * "git log" learned a new "--diff-merges=<how>" option.
55  * "git ls-files" can and does show multiple entries when the index is
56    unmerged, which is a source for confusion unless -s/-u option is in
57    use.  A new option --deduplicate has been introduced.
59  * `git worktree list` now annotates worktrees as prunable, shows
60    locked and prunable attributes in --porcelain mode, and gained
61    a --verbose option.
64 Performance, Internal Implementation, Development Support etc.
66  * A 3-year old test that was not testing anything useful has been
67    corrected.
69  * Retire more names with "sha1" in it.
71  * The topological walk codepath is covered by new trace2 stats.
73  * Update the Code-of-conduct to version 2.0 from the upstream (we've
74    been using version 1.4).
76  * "git mktag" validates its input using its own rules before writing
77    a tag object---it has been updated to share the logic with "git
78    fsck".
80  * Two new ways to feed configuration variable-value pairs via
81    environment variables have been introduced, and the way
82    GIT_CONFIG_PARAMETERS encodes variable/value pairs has been tweaked
83    to make it more robust.
85  * Tests have been updated so that they do not to get affected by the
86    name of the default branch "git init" creates.
88  * "git fetch" learns to treat ref updates atomically in all-or-none
89    fashion, just like "git push" does, with the new "--atomic" option.
91  * The peel_ref() API has been replaced with peel_iterated_oid().
93  * The .use_shell flag in struct child_process that is passed to
94    run_command() API has been clarified with a bit more documentation.
96  * Document, clean-up and optimize the code around the cache-tree
97    extension in the index.
99  * The ls-refs protocol operation has been optimized to narrow the
100    sub-hierarchy of refs/ it walks to produce response.
102  * When removing many branches and tags, the code used to do so one
103    ref at a time.  There is another API it can use to delete multiple
104    refs, and it makes quite a lot of performance difference when the
105    refs are packed.
107  * The "pack-objects" command needs to iterate over all the tags when
108    automatic tag following is enabled, but it actually iterated over
109    all refs and then discarded everything outside "refs/tags/"
110    hierarchy, which was quite wasteful.
112  * A perf script was made more portable.
114  * Our setting of GitHub CI test jobs were a bit too eager to give up
115    once there is even one failure found.  Tweak the knob to allow
116    other jobs keep running even when we see a failure, so that we can
117    find more failures in a single run.
119  * We've carried compatibility codepaths for compilers without
120    variadic macros for quite some time, but the world may be ready for
121    them to be removed.  Force compilation failure on exotic platforms
122    where variadic macros are not available to find out who screams in
123    such a way that we can easily revert if it turns out that the world
124    is not yet ready.
126  * Code clean-up to ensure our use of hashtables using object names as
127    keys use the "struct object_id" objects, not the raw hash values.
129  * Lose the debugging aid that may have been useful in the past, but
130    no longer is, in the "grep" codepaths.
132  * Some pretty-format specifiers do not need the data in commit object
133    (e.g. "%H"), but we were over-eager to load and parse it, which has
134    been made even lazier.
136  * Get rid of "GETTEXT_POISON" support altogether, which may or may
137    not be controversial.
139  * Introduce an on-disk file to record revindex for packdata, which
140    traditionally was always created on the fly and only in-core.
143 Fixes since v2.30
144 -----------------
146  * Diagnose command line error of "git rebase" early.
148  * Clean up option descriptions in "git cmd --help".
150  * "git stash" did not work well in a sparsely checked out working
151    tree.
153  * Some tests expect that "ls -l" output has either '-' or 'x' for
154    group executable bit, but setgid bit can be inherited from parent
155    directory and make these fields 'S' or 's' instead, causing test
156    failures.
158  * "git for-each-repo --config=<var> <cmd>" should not run <cmd> for
159    any repository when the configuration variable <var> is not defined
160    even once.
162  * Fix 2.29 regression where "git mergetool --tool-help" fails to list
163    all the available tools.
165  * Fix for procedure to building CI test environment for mac.
167  * The implementation of "git branch --sort" wrt the detached HEAD
168    display has always been hacky, which has been cleaned up.
170  * Newline characters in the host and path part of git:// URL are
171    now forbidden.
173  * "git diff" showed a submodule working tree with untracked cruft as
174    "Submodule commit <objectname>-dirty", but a natural expectation is
175    that the "-dirty" indicator would align with "git describe --dirty",
176    which does not consider having untracked files in the working tree
177    as source of dirtiness.  The inconsistency has been fixed.
179  * When more than one commit with the same patch ID appears on one
180    side, "git log --cherry-pick A...B" did not exclude them all when a
181    commit with the same patch ID appears on the other side.  Now it
182    does.
184  * Documentation for "git fsck" lost stale bits that has become
185    incorrect.
187  * Doc fix for packfile URI feature.
189  * When "git rebase -i" processes "fixup" insn, there is no reason to
190    clean up the commit log message, but we did the usual stripspace
191    processing.  This has been corrected.
192    (merge f7d42ceec5 js/rebase-i-commit-cleanup-fix later to maint).
194  * Fix in passing custom args from "git clone" to "upload-pack" on the
195    other side.
196    (merge ad6b5fefbd jv/upload-pack-filter-spec-quotefix later to maint).
198  * The command line completion (in contrib/) completed "git branch -d"
199    with branch names, but "git branch -D" offered tagnames in addition,
200    which has been corrected.  "git branch -M" had the same problem.
201    (merge 27dc071b9a jk/complete-branch-force-delete later to maint).
203  * When commands are started from a subdirectory, they may have to
204    compare the path to the subdirectory (called prefix and found out
205    from $(pwd)) with the tracked paths.  On macOS, $(pwd) and
206    readdir() yield decomposed path, while the tracked paths are
207    usually normalized to the precomposed form, causing mismatch.  This
208    has been fixed by taking the same approach used to normalize the
209    command line arguments.
210    (merge 5c327502db tb/precompose-prefix-too later to maint).
212  * Other code cleanup, docfix, build fix, etc.
213    (merge e3f5da7e60 sg/t7800-difftool-robustify later to maint).