@@ -22,16 +22,42 @@ UI, Workflows & Features
2222
2323 * Various updates to "git p4".
2424
25+ * "git p4" didn't interact with the internal of .git directory
26+ correctly in the modern "git-worktree"-enabled world.
27+
28+ * "git branch --list" and friends learned "--ignore-case" option to
29+ optionally sort branches and tags case insensitively.
30+
31+ * In addition to %(subject), %(body), "log --pretty=format:..."
32+ learned a new placeholder %(trailers).
33+
34+ * "git rebase" learned "--quit" option, which allows a user to
35+ remove the metadata left by an earlier "git rebase" that was
36+ manually aborted without using "git rebase --abort".
37+
2538
2639Performance, Internal Implementation, Development Support etc.
2740
28- *
41+ * Commands that operate on a log message and add lines to the trailer
42+ blocks, such as "format-patch -s", "cherry-pick (-x|-s)", and
43+ "commit -s", have been taught to use the logic of and share the
44+ code with "git interpret-trailer".
2945
46+ * The default Travis-CI configuration specifies newer P4 and GitLFS.
47+ (merge 5f703e8f02 ls/travis-update-p4-and-lfs later to maint).
3048
31- Also contains various documentation updates and code clean-ups.
49+ * The "fast hash" that had disastrous performance issues in some
50+ corner cases has been retired from the internal diff.
3251
33- *
52+ * The character width table has been updated to match Unicode 9.0
53+ (merge 9e6e9aefdf bb/unicode-9.0 later to maint).
3454
55+ * Update the procedure to generate "tags" for developer support.
56+ (merge 046e4c1c09 jk/make-tags-find-sources-tweak later to maint).
57+
58+
59+
60+ Also contains various documentation updates and code clean-ups.
3561
3662Fixes since v2.10
3763-----------------
@@ -81,6 +107,67 @@ notes for details).
81107 * "git p4" LFS support was broken when LFS stores an empty blob.
82108 (merge d5eb3cf5e7 ls/p4-empty-file-on-lfs later to maint).
83109
110+ * A corner case in merge-recursive regression that crept in
111+ during 2.10 development cycle has been fixed.
112+ (merge 1c25d2d8ed jc/renormalize-merge-kill-safer-crlf later to maint).
113+
114+ * Transport with dumb http can be fooled into following foreign URLs
115+ that the end user does not intend to, especially with the server
116+ side redirects and http-alternates mechanism, which can lead to
117+ security issues. Tighten the redirection and make it more obvious
118+ to the end user when it happens.
119+ (merge cb4d2d35c4 jk/http-walker-limit-redirect-2.9 later to maint).
120+
121+ * Update the error messages from the dumb-http client when it fails
122+ to obtain loose objects; we used to give sensible error message
123+ only upon 404 but we now forbid unexpected redirects that needs to
124+ be reported with something sensible.
125+ (merge 3680f16f9d jk/http-walker-limit-redirect later to maint).
126+
127+ * When diff.renames configuration is on (and with Git 2.9 and later,
128+ it is enabled by default, which made it worse), "git stash"
129+ misbehaved if a file is removed and another file with a very
130+ similar content is added.
131+ (merge 9d4e28ead5 jk/stash-disable-renames-internally later to maint).
132+
133+ * "git diff --no-index" did not take "--no-abbrev" option.
134+ (merge 43d1948b7b jb/diff-no-index-no-abbrev later to maint).
135+
136+ * "git difftool --dir-diff" had a minor regression when started from
137+ a subdirectory, which has been fixed.
138+ (merge 853e10c197 da/difftool-dir-diff-fix later to maint).
139+
140+ * "git commit --allow-empty --only" (no pathspec) with dirty index
141+ ought to be an acceptable way to create a new commit that does not
142+ change any paths, but it was forbidden, perhaps because nobody
143+ needed it so far.
144+ (merge beb635ca9c ak/commit-only-allow-empty later to maint).
145+
146+ * Git 2.11 had a minor regression in "merge --ff-only" that competed
147+ with another process that simultanously attempted to update the
148+ index. We used to explain what went wrong with an error message,
149+ but the new code silently failed. The error message has been
150+ resurrected.
151+
152+ * A pathname that begins with "//" or "\\" on Windows is special but
153+ path normalization logic was unaware of it.
154+ (merge 7814fbe3f1 js/normalize-path-copy-ceil later to maint).
155+
156+ * "git pull --rebase", when there is no new commits on our side since
157+ we forked from the upstream, should be able to fast-forward without
158+ invoking "git rebase", but it didn't.
159+ (merge 33b842a1e9 jc/pull-rebase-ff later to maint).
160+
161+ * The way to specify hotkeys to "xxdiff" that is used by "git
162+ mergetool" has been modernized to match recent versions of xxdiff.
163+ (merge 6cf5f6cef7 da/mergetool-xxdiff-hotkey later to maint).
164+
84165 * Other minor doc, test and build updates and code cleanups.
85166 (merge fa6ca11105 nd/qsort-in-merge-recursive later to maint).
86167 (merge fa3142c919 ak/lazy-prereq-mktemp later to maint).
168+ (merge 9c48b4fb23 ls/t0021-fixup later to maint).
169+ (merge 584f99c87b sb/unpack-trees-grammofix later to maint).
170+ (merge 54471fdcc3 jk/readme-gmane-is-no-more later to maint).
171+ (merge 9e189f1a5c sb/t3600-cleanup later to maint).
172+ (merge e2c20be57c lr/doc-fix-cet later to maint).
173+ (merge 47437fd3bd kh/tutorial-grammofix later to maint).
0 commit comments