Meta/Reintegrate: use older editions of what's cooking report as needed
[alt-git.git] / whats-cooking.txt
blob97ecba54adc389c6555d62e054cbe3bddb523b0a
1 To: git@vger.kernel.org
2 Bcc: lwn@lwn.net
3 Subject: What's cooking in git.git (Feb 2015, #06; Sun, 22)
4 X-master-at: 355d4e1739d1e88561ac04d2a2423c2aa93693d9
5 X-next-at: a0c6b3dbaae84fcad8b65e4ac8caa8982d3d24a8
7 What's cooking in git.git (Feb 2015, #06; Sun, 22)
8 --------------------------------------------------
10 Here are the topics that have been cooking.  Commits prefixed with
11 '-' are only in 'pu' (proposed updates) while commits prefixed with
12 '+' are in 'next'.
14 The 'master' front have merged many topics that can further merged
15 to the maintainance tracks.  We may want to do a v2.3.1 soonish.
17 You can find the changes described here in the integration branches
18 of the repositories listed at
20     http://git-blame.blogspot.com/p/git-public-repositories.html
22 --------------------------------------------------
23 [Graduated to "master"]
25 * ab/merge-file-prefix (2015-02-11) 1 commit
26   (merged to 'next' on 2015-02-16 at 89e0252)
27  + merge-file: correctly open files when in a subdir
29  "git merge-file" did not work correctly in a subdirectory.
32 * es/blame-commit-info-fix (2015-02-10) 1 commit
33   (merged to 'next' on 2015-02-16 at f76ff44)
34  + builtin/blame: destroy initialized commit_info only
36  "git blame" died, trying to free an uninitialized piece of memory.
39 * es/squelch-openssl-warnings-on-macosx (2015-02-09) 1 commit
40   (merged to 'next' on 2015-02-16 at bbe2880)
41  + git-compat-util: do not step on MAC_OS_X_VERSION_MIN_REQUIRED
43  An earlier workaround to squelch unhelpful deprecation warnings
44  from the complier on Mac OSX unnecessarily set minimum required
45  version of the OS, which the user might want to raise (or lower)
46  for other reasons.
49 * jc/conf-var-doc (2015-02-02) 3 commits
50   (merged to 'next' on 2015-02-16 at 97512a3)
51  + CodingGuidelines: describe naming rules for configuration variables
52  + config.txt: mark deprecated variables more prominently
53  + config.txt: clarify that add.ignore-errors is deprecated
55  Longstanding configuration variable naming rules has been added to
56  the documentation.
59 * jc/diff-files-ita (2015-02-04) 1 commit
60   (merged to 'next' on 2015-02-16 at d7867a3)
61  + run_diff_files(): clarify computation of sha1 validity
63  Code cleanup.
66 * jk/prune-mtime (2015-02-09) 2 commits
67   (merged to 'next' on 2015-02-16 at 3d46eae)
68  + sha1_file: fix iterating loose alternate objects
69  + for_each_loose_file_in_objdir: take an optional strbuf path
71  In v2.2.0, we broke "git prune" that runs in a repository that
72  borrows from an alternate object store.
75 * ps/submodule-sanitize-path-upon-add (2015-02-02) 1 commit
76   (merged to 'next' on 2015-02-16 at 8253132)
77  + git-submodule.sh: fix '/././' path normalization
79  "git submodule add" failed to squash "path/to/././submodule" to
80  "path/to/submodule".
83 * ss/check-builtins-on-windows (2015-02-05) 1 commit
84   (merged to 'next' on 2015-02-16 at 2c10cc1)
85  + check-builtins: strip executable suffix $X when enumerating builtins
88 * tc/curl-vernum-output-broken-in-7.11 (2015-02-03) 1 commit
89   (merged to 'next' on 2015-02-16 at de90f95)
90  + Makefile: handle broken curl version number in version check
92  Certain older vintages of cURL give irregular output from
93  "curl-config --vernum", which confused our build system.
95 --------------------------------------------------
96 [New Topics]
98 * mm/am-c-doc (2015-02-20) 2 commits
99  - Documentation/git-am.txt: mention mailinfo.scissors config variable
100  - Documentation/config.txt: document mailinfo.scissors
102  The configuration variable 'mailinfo.scissors' was hard to
103  discover in the documentation.
105  Will merge to 'next'.
108 * rs/simple-cleanups (2015-02-22) 4 commits
109  - sha1_name: use strlcpy() to copy strings
110  - pretty: use starts_with() to check for a prefix
111  - for-each-ref: use skip_prefix() to avoid duplicate string comparison
112  - connect: use strcmp() for string comparison
114  Will merge to 'next'.
116 --------------------------------------------------
117 [Stalled]
119 * nd/list-files (2015-02-09) 21 commits
120  . t3080: tests for git-list-files
121  . list-files: -M aka diff-cached
122  . list-files -F: show submodules with the new indicator '&'
123  . list-files: add -F/--classify
124  . list-files: show directories as well as files
125  . list-files: do not show duplicate cached entries
126  . list-files: sort output and remove duplicates
127  . list-files: add -t back
128  . list-files: add -1 short for --no-column
129  . list-files: add -R/--recursive short for --max-depth=-1
130  . list-files: -u does not imply showing stages
131  . list-files: make alias 'ls' default to 'list-files'
132  . list-files: a user friendly version of ls-files and more
133  . ls-files: support --max-depth
134  . ls-files: add --column
135  . ls-files: add --color to highlight file names
136  . ls-files: buffer full item in strbuf before printing
137  . ls_colors.c: highlight submodules like directories
138  . ls_colors.c: add a function to color a file name
139  . ls_colors.c: parse color.ls.* from config file
140  . ls_colors.c: add $LS_COLORS parsing code
142  A new "git list-files" Porcelain command, "ls-files" with bells and
143  whistles.
145  No comments?  No reviews?  No interests?
148 * nd/untracked-cache (2015-02-09) 24 commits
149  - git-status.txt: advertisement for untracked cache
150  - untracked cache: guard and disable on system changes
151  - mingw32: add uname()
152  - t7063: tests for untracked cache
153  - update-index: test the system before enabling untracked cache
154  - update-index: manually enable or disable untracked cache
155  - status: enable untracked cache
156  - untracked-cache: temporarily disable with $GIT_DISABLE_UNTRACKED_CACHE
157  - untracked cache: mark index dirty if untracked cache is updated
158  - untracked cache: print stats with $GIT_TRACE_UNTRACKED_STATS
159  - untracked cache: avoid racy timestamps
160  - read-cache.c: split racy stat test to a separate function
161  - untracked cache: invalidate at index addition or removal
162  - untracked cache: load from UNTR index extension
163  - untracked cache: save to an index extension
164  - ewah: add convenient wrapper ewah_serialize_strbuf()
165  - untracked cache: don't open non-existent .gitignore
166  - untracked cache: mark what dirs should be recursed/saved
167  - untracked cache: record/validate dir mtime and reuse cached output
168  - untracked cache: make a wrapper around {open,read,close}dir()
169  - untracked cache: invalidate dirs recursively if .gitignore changes
170  - untracked cache: initial untracked cache validation
171  - untracked cache: record .gitignore information and dir hierarchy
172  - dir.c: optionally compute sha-1 of a .gitignore file
174  Need extra sets of eyes to review this.
177 * ak/stash-store-create-help (2015-01-13) 1 commit
178  - stash: show "create" and "store" subcommands in usage-help
180  Will discard.
183 * bp/diff-relative-config (2015-01-07) 2 commits
184  - diff: teach diff.relative to give default to --relative=<value>
185  - diff: teach --no-relative to override earlier --relative
187  No comments?  No interests?
190 * jc/diff-b-m (2015-02-17) 4 commits
191  - WIP: diff-b-m
192  - diffcore-rename: allow easier debugging
193  - diffcore-rename.c: add locate_rename_src()
194  - diffcore-break: allow debugging
195  (this branch uses jc/diff-test-updates.)
197  "git diff -B -M" produced incorrect patch when the postimage of a
198  completely rewritten file is similar to the preimage of a removed
199  file; such a resulting file must not be expressed as a rename from
200  other place.
202  The fix in this patch is broken, unfortunately.
205 * nd/slim-index-pack-memory-usage (2015-02-10) 3 commits
206  - index-pack: kill union delta_base to save memory
207  - FIXUP
208  - index-pack: reduce memory footprint a bit
210  Need to replace with the reroll ($gmane/264126).
213 * pw/remote-set-url-fetch (2014-11-26) 1 commit
214  - remote: add --fetch and --both options to set-url
216  Expecting a reroll.
219 * je/quiltimport-no-fuzz (2014-10-21) 2 commits
220  - git-quiltimport: flip the default not to allow fuzz
221  - git-quiltimport.sh: allow declining fuzz with --exact option
223  "quiltimport" drove "git apply" always with -C1 option to reduce
224  context of the patch in order to give more chance to somewhat stale
225  patches to apply.  Add an "--exact" option to disable, and also
226  "-C$n" option to customize this behaviour.  The top patch
227  optionally flips the default to "--exact".
229  Tired of waiting for an Ack
230  Will discard.
233 * tr/remerge-diff (2014-11-10) 9 commits
234  - t4213: avoid "|" in sed regexp
235  - log --remerge-diff: show what the conflict resolution changed
236  - name-hash: allow dir hashing even when !ignore_case
237  - merge-recursive: allow storing conflict hunks in index
238  - merge_diff_mode: fold all merge diff variants into an enum
239  - combine-diff: do not pass revs->dense_combined_merges redundantly
240  - merge-recursive: -Xindex-only to leave worktree unchanged
241  - merge-recursive: internal flag to avoid touching the worktree
242  - merge-recursive: remove dead conditional in update_stages()
244  "log -p" output learns a new way to let users inspect a merge
245  commit by showing the differences between the automerged result
246  with conflicts the person who recorded the merge would have seen
247  and the final conflict resolution that was recorded in the merge.
249  Waiting for a reroll ($gmane/256591).
252 * hv/submodule-config (2014-11-11) 4 commits
253  - do not die on error of parsing fetchrecursesubmodules option
254  - use new config API for worktree configurations of submodules
255  - extract functions for submodule config set and lookup
256  - implement submodule config cache for lookup of submodule names
258  Kicked back to 'pu' per request ($gmane/255610).
261 * ab/add-interactive-show-diff-func-name (2014-05-12) 2 commits
262  - SQUASH??? git-add--interactive: Preserve diff heading when splitting hunks
263  - git-add--interactive: Preserve diff heading when splitting hunks
265  Waiting for a reroll.
268 * jn/gitweb-utf8-in-links (2014-05-27) 1 commit
269  - gitweb: Harden UTF-8 handling in generated links
271  $gmane/250758?
274 * ss/userdiff-update-csharp-java (2014-06-02) 2 commits
275  - userdiff: support Java try keyword
276  - userdiff: support C# async methods and correct C# keywords
278  Reviews sent; waiting for a response.
281 * bg/rebase-off-of-previous-branch (2014-04-16) 1 commit
282  - git-rebase: print name of rev when using shorthand
284  Teach "git rebase -" to report the concrete name of the branch
285  (i.e. the previous one).
287  But it stops short and does not do the same for "git rebase @{-1}".
288  Expecting a reroll.
291 * rb/merge-prepare-commit-msg-hook (2014-01-10) 4 commits
292  - merge: drop unused arg from abort_commit method signature
293  - merge: make prepare_to_commit responsible for write_merge_state
294  - t7505: ensure cleanup after hook blocks merge
295  - t7505: add missing &&
297  Expose more merge states (e.g. $GIT_DIR/MERGE_MODE) to hooks that
298  run during "git merge".  The log message stresses too much on one
299  hook, prepare-commit-msg, but it would equally apply to other hooks
300  like post-merge, I think.
302  Waiting for a reroll.
305 * jc/graph-post-root-gap (2013-12-30) 3 commits
306  - WIP: document what we want at the end
307  - graph: remove unused code a bit
308  - graph: stuff the current commit into graph->columns[]
310  This was primarily a RFH ($gmane/239580).
313 * tg/perf-lib-test-perf-cleanup (2013-09-19) 2 commits
314  - perf-lib: add test_perf_cleanup target
315  - perf-lib: split starting the test from the execution
317  Add test_perf_cleanup shell function to the perf suite, that allows
318  the script writers to define a test with a clean-up action.
320  Will hold.
323 * jc/show-branch (2014-03-24) 5 commits
324  - show-branch: use commit slab to represent bitflags of arbitrary width
325  - show-branch.c: remove "all_mask"
326  - show-branch.c: abstract out "flags" operation
327  - show-branch.c: lift all_mask/all_revs to a global static
328  - show-branch.c: update comment style
330  Waiting for the final step to lift the hard-limit before sending it out.
332 --------------------------------------------------
333 [Cooking]
335 * tb/connect-ipv6-parse-fix (2015-02-22) 3 commits
336  - t5500: show user name and host in diag-url
337  - t5601: add more test cases for IPV6
338  - connect.c: allow ssh://user@[2001:db8::1]/repo.git
340  Waiting for comments from Brian who had objections to the previous
341  round.
344 * ak/git-pm-typofix (2015-02-18) 1 commit
345   (merged to 'next' on 2015-02-20 at 0fa233a)
346  + Git.pm: two minor typo fixes
348  Typofix in comments.
350  Will merge to 'master'.
353 * jc/decorate-leaky-separator-color (2015-02-20) 2 commits
354  - config.txt: spell out how certain typed values are written
355  - log --decorate: do not leak "commit" color into the next item
357  "git log --decorate" did not reset colors correctly around the
358  branch names.
360  Waiting for discussion on the tip one.
363 * ms/submodule-update-config-doc (2015-02-20) 1 commit
364  - submodule: Improve documentation of update subcommand
366  The interaction between "git submodule update" and the
367  submodule.*.update configuration was not clearly documented.
370 * dp/remove-duplicated-header-inclusion (2015-02-13) 1 commit
371   (merged to 'next' on 2015-02-18 at a1bf108)
372  + do not include the same header twice
374  Code clean-up.
376  Will merge to 'master'.
379 * jc/diff-test-updates (2015-02-15) 6 commits
380   (merged to 'next' on 2015-02-18 at f152c9f)
381  + t4008: modernise style
382  + t/diff-lib: check exact object names in compare_diff_raw
383  + tests: do not borrow from COPYING and README from the real source
384  + t4010: correct expected object names
385  + t9300: correct expected object names
386  + t4008: correct stale comments
387  (this branch is used by jc/diff-b-m.)
389  Test clean-up.
391  Will merge to 'master'.
394 * jc/send-email-sensible-encoding (2015-02-13) 1 commit
395   (merged to 'next' on 2015-02-18 at 7457655)
396  + send-email: ask confirmation if given encoding name is very short
398  "git send-email" used to accept a mistaken "y" (or "yes") as an
399  answer to "What encoding do you want to use [UTF-8]? " without
400  questioning.  Now it asks for confirmation when the answer looks
401  too short to be a valid encoding name.
403  Will merge to 'master'.
406 * jk/push-config (2015-02-17) 4 commits
407  - [NEEDSACK] push: allow --follow-tags to be set by config push.followTags
408  - cmd_push: pass "flags" pointer to config callback
409  - cmd_push: set "atomic" bit directly
410  - git_push_config: drop cargo-culted wt_status pointer
412  Waiting for Ack and/or update for the tip one from Dave Olszewski
413  ($gmane/263880, $gmane/263991).
416 * km/send-email-getopt-long-workarounds (2015-02-16) 1 commit
417   (merged to 'next' on 2015-02-18 at 84c1597)
418  + git-send-email.perl: support no- prefix with older GetOptions
420  Even though we officially haven't dropped Perl 5.8 support, the
421  Getopt::Long package that came with it does not support "--no-"
422  prefix to negate a boolean option; manually add support to help
423  people with older Getopt::Long package.
425  Will merge to 'master'.
428 * mh/transport-capabilities (2015-02-13) 2 commits
429   (merged to 'next' on 2015-02-18 at 87e8fcc)
430  + transport-helper: ask the helper to set the same options for import as for fetch
431  + transport-helper: ask the helper to set progress and verbosity options after asking for its capabilities
433  The transport-helper did not give transport options such as
434  verbosity, progress, cloning, etc. to import and export based
435  helpers, like it did for fetch and push based helpers, robbing them
436  the chance to honor the wish of the end-users better.
438  Will merge to 'master'.
441 * sb/hex-object-name-is-at-most-41-bytes-long (2015-02-13) 1 commit
442   (merged to 'next' on 2015-02-18 at 53d522b)
443  + hex.c: reduce memory footprint of sha1_to_hex static buffers
445  Code clean-up.
447  Will merge to 'master'.
450 * jk/daemon-interpolate (2015-02-17) 3 commits
451   (merged to 'next' on 2015-02-20 at 21118a7)
452  + daemon: sanitize incoming virtual hostname
453  + t5570: test git-daemon's --interpolated-path option
454  + git_connect: let user override virtual-host we send to daemon
456  The "interpolated-path" option of "git daemon" inserted any string
457  client declared on the "host=" capability request without checking.
458  Sanitize and limit %H and %CH to a saner and a valid DNS name.
460  Will merge to 'master'.
463 * rs/daemon-interpolate (2015-02-17) 2 commits
464   (merged to 'next' on 2015-02-18 at c0f5750)
465  + daemon: use callback to build interpolated path
466  + daemon: look up client-supplied hostname lazily
468  "git daemon" looked up the hostname even when "%CH" and "%IP"
469  interpolations are not requested, which was unnecessary.
471  Will merge to 'master'.
474 * sb/plug-leak-in-make-cache-entry (2015-02-17) 1 commit
475   (merged to 'next' on 2015-02-18 at e637f65)
476  + read-cache.c: free cache entry when refreshing fails
478  "update-index --refresh" used to leak when an entry cannot be
479  refreshed for whatever reason.
481  Will merge to 'master'.
484 * jn/doc-api-errors (2014-12-04) 1 commit
485   (merged to 'next' on 2015-02-18 at f60eda6)
486  + doc: document error handling functions and conventions
488  The error handling functions and conventions are now documented in
489  the API manual.
491  Will merge to 'master'.
494 * jk/sanity (2015-02-15) 3 commits
495   (merged to 'next' on 2015-02-18 at 5c54b53)
496  + test-lib.sh: set prerequisite SANITY by testing what we really need
497  + tests: correct misuses of POSIXPERM
498  + t/lib-httpd: switch SANITY check for NOT_ROOT
500  The tests that wanted to see that file becomes unreadable after
501  running "chmod a-r file", and the tests that wanted to make sure it
502  is not run as root, we used "can we write into the / directory?" as
503  a cheap substitute, but on some platforms that is not a good
504  heuristics.  The tests and their prerequisites have been updated to
505  check what they really require.
507  Will merge to 'master'.
510 * jc/max-io-size-and-ssize-max (2015-02-12) 1 commit
511   (merged to 'next' on 2015-02-18 at 0c8a4da)
512  + xread/xwrite: clip MAX_IO_SIZE to SSIZE_MAX
514  Our default I/O size (8 MiB) for large files was too large for some
515  platforms with smaller SSIZE_MAX, leading to read(2)/write(2)
516  failures.
518  Will merge to 'master'.
521 * jk/fast-import-die-nicely-fix (2015-02-10) 1 commit
522   (merged to 'next' on 2015-02-18 at e249425)
523  + fast-import: avoid running end_packfile recursively
525  "git fast-import" used to crash when it could not close and
526  conclude the resulting packfile cleanly.
528  Will merge to 'master'.
531 * mh/expire-updateref-fixes (2015-02-09) 10 commits
532  - reflog_expire(): lock symbolic refs themselves, not their referent
533  - reflog_expire(): never update a reference to null_sha1
534  - reflog_expire(): ignore --updateref for symbolic references
535  - reflog: rearrange the manpage
536  - reflog: fix documentation
537  - lock_ref_sha1_basic(): do not set force_write for missing references
538  - write_ref_sha1(): Move write elision test to callers
539  - write_ref_sha1(): remove check for lock == NULL
540  - Merge branch 'sb/atomic-push' into mh/ref-trans-value-check
541  - Merge branch 'mh/reflog-expire' into mh/ref-trans-value-check
543  Under discussion ($gmane/263552)
546 * mh/refs-have-new (2015-02-17) 13 commits
547  - refs.h: remove duplication in function docstrings
548  - update_ref(): improve documentation
549  - ref_transaction_verify(): new function to check a reference's value
550  - ref_transaction_delete(): check that old_sha1 is not null_sha1
551  - ref_transaction_create(): check that new_sha1 is valid
552  - commit: avoid race when creating orphan commits
553  - commit: add tests of commit races
554  - ref_transaction_delete(): remove "have_old" parameter
555  - ref_transaction_update(): remove "have_old" parameter
556  - struct ref_update: move "have_old" into "flags"
557  - refs.c: change some "flags" to "unsigned int"
558  - refs: remove the gap in the REF_* constant values
559  - refs: move REF_DELETING to refs.c
561  Simplify the ref transaction API around how "the ref should be
562  pointing at this object" is specified.
564  Looked sensible.
565  Will merge to 'next', unless there is an objection.
568 * jc/apply-beyond-symlink (2015-02-10) 4 commits
569   (merged to 'next' on 2015-02-18 at 4109de1)
570  + apply: do not touch a file beyond a symbolic link
571  + apply: do not read from beyond a symbolic link
572  + apply: do not read from the filesystem under --index
573  + apply: reject input that touches outside the working area
575  "git apply" was not very careful about reading from, removing,
576  updating and creating paths outside the working tree (under
577  --index/--cached) or the current directory (when used as a
578  replacement for GNU patch).
580  Will merge to 'master'.
583 * tc/missing-http-proxyauth (2015-02-03) 1 commit
584   (merged to 'next' on 2015-02-18 at 8ff01ad)
585  + http: support curl < 7.10.7
587  We did not check the curl library version before using
588  CURLOPT_PROXYAUTH feature that may not exist.
590  Will merge to 'master'.
593 * jc/apply-ws-fix-expands-report (2015-01-22) 1 commit
594   (merged to 'next' on 2015-02-18 at b571668)
595  + apply: detect and mark whitespace errors in context lines when fixing
597  "git apply --whitespace=fix" fixed whitespace errors in the common
598  context lines but did so without reporting.
600  Will merge to 'master'.
603 * js/fsck-opt (2015-01-21) 19 commits
604  - fsck: support ignoring objects in `git fsck` via fsck.skiplist
605  - fsck: git receive-pack: support excluding objects from fsck'ing
606  - fsck: introduce `git fsck --quick`
607  - fsck: support demoting errors to warnings
608  - fsck: document the new receive.fsck.* options
609  - fsck: allow upgrading fsck warnings to errors
610  - fsck: optionally ignore specific fsck issues completely
611  - fsck: disallow demoting grave fsck errors to warnings
612  - fsck: add a simple test for receive.fsck.*
613  - fsck: make fsck_tag() warn-friendly
614  - fsck: handle multiple authors in commits specially
615  - fsck: make fsck_commit() warn-friendly
616  - fsck: make fsck_ident() warn-friendly
617  - fsck: report the ID of the error/warning
618  - fsck: allow demoting errors to warnings via receive.fsck.warn = <key>
619  - fsck: offer a function to demote fsck errors to warnings
620  - fsck: provide a function to parse fsck message IDs
621  - fsck: introduce identifiers for fsck messages
622  - fsck: introduce fsck options
624  "fsck.warnings = <list of error tokens>" I suggested turned out to
625  be an unpopular choice (sorry Dscho).
627  Expecting a reroll.
630 * jk/strbuf-doc-to-header (2015-01-16) 7 commits
631   (merged to 'next' on 2015-02-18 at 0482c65)
632  + strbuf.h: group documentation for trim functions
633  + strbuf.h: drop boilerplate descriptions of strbuf_split_*
634  + strbuf.h: reorganize api function grouping headers
635  + strbuf.h: format asciidoc code blocks as 4-space indent
636  + strbuf.h: drop asciidoc list formatting from API docs
637  + strbuf.h: unify documentation comments beginnings
638  + strbuf.h: integrate api-strbuf.txt documentation
640  Resolve the "doc vs header" to favor the latter.
642  Will merge to 'master'.
645 * nd/attr-optim (2014-12-29) 3 commits
646   (merged to 'next' on 2015-02-18 at 598e68a)
647  + attr: avoid heavy work when we know the specified attr is not defined
648  + attr: do not attempt to expand when we know it's not a macro
649  + attr.c: rename arg name attr_nr to avoid shadowing the global one
651  Optimize attribute look-up, mostly useful in "git grep" on a
652  project that does not use many attributes, by avoiding it when we
653  (should) know that the attributes are not defined in the first
654  place.
656  Will merge to 'master'.
659 * nd/multiple-work-trees (2015-01-27) 38 commits
660   (merged to 'next' on 2015-02-18 at b51f696)
661  + t2026 needs procondition SANITY
662  + git-checkout.txt: a note about multiple checkout support for submodules
663  + checkout: add --ignore-other-wortrees
664  + checkout: pass whole struct to parse_branchname_arg instead of individual flags
665  + git-common-dir: make "modules/" per-working-directory directory
666  + checkout: do not fail if target is an empty directory
667  + t2025: add a test to make sure grafts is working from a linked checkout
668  + checkout: don't require a work tree when checking out into a new one
669  + git_path(): keep "info/sparse-checkout" per work-tree
670  + count-objects: report unused files in $GIT_DIR/worktrees/...
671  + gc: support prune --worktrees
672  + gc: factor out gc.pruneexpire parsing code
673  + gc: style change -- no SP before closing parenthesis
674  + checkout: clean up half-prepared directories in --to mode
675  + checkout: reject if the branch is already checked out elsewhere
676  + prune: strategies for linked checkouts
677  + checkout: support checking out into a new working directory
678  + use new wrapper write_file() for simple file writing
679  + wrapper.c: wrapper to open a file, fprintf then close
680  + setup.c: support multi-checkout repo setup
681  + setup.c: detect $GIT_COMMON_DIR check_repository_format_gently()
682  + setup.c: convert check_repository_format_gently to use strbuf
683  + setup.c: detect $GIT_COMMON_DIR in is_git_directory()
684  + setup.c: convert is_git_directory() to use strbuf
685  + git-stash: avoid hardcoding $GIT_DIR/logs/....
686  + *.sh: avoid hardcoding $GIT_DIR/hooks/...
687  + git-sh-setup.sh: use rev-parse --git-path to get $GIT_DIR/objects
688  + $GIT_COMMON_DIR: a new environment variable
689  + commit: use SEQ_DIR instead of hardcoding "sequencer"
690  + fast-import: use git_path() for accessing .git dir instead of get_git_dir()
691  + reflog: avoid constructing .lock path with git_path
692  + *.sh: respect $GIT_INDEX_FILE
693  + git_path(): be aware of file relocation in $GIT_DIR
694  + path.c: group git_path(), git_pathdup() and strbuf_git_path() together
695  + path.c: rename vsnpath() to do_git_path()
696  + git_snpath(): retire and replace with strbuf_git_path()
697  + path.c: make get_pathname() call sites return const char *
698  + path.c: make get_pathname() return strbuf instead of static buffer
700  A replacement for contrib/workdir/git-new-workdir that does not
701  rely on symbolic links and make sharing of objects and refs safer
702  by making the borrowee and borrowers aware of each other.
704  Will cook in 'next'.
706 --------------------------------------------------
707 [Discarded]
709 * tc/t9001-noxmailer (2015-01-30) 1 commit
710  . t9001: use older Getopt::Long boolean prefix '--no' rather than '--no-'
712  Kyle's update to explicitly support --no-option with older
713  Getopt::Long ($gmane/263203) makes this unnecessary.