Meta/Announce: use mailmap and tweak wording for maintenance tracks
[alt-git.git] / whats-cooking.txt
blob4fb2961e5fe7fe79a7f93c2874b2cb452309169f
1 To: git@vger.kernel.org
2 Bcc: lwn@lwn.net
3 Subject: What's cooking in git.git (Jun 2015, #05; Mon, 22)
4 X-master-at: 5b1d901c0173b41010856e30776c92d02987ea25
5 X-next-at: 6397abdce8831f34ac73793bdc73f48511c6d798
7 What's cooking in git.git (Jun 2015, #05; Mon, 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 Some of the topics in flight have overlaps with each other and have
15 been excluded from 'pu'; most notably, I think the remainder of
16 bc/object-id needs to wait until the for-each-ref topic from Karthik
17 settles and then rebased on it, or something.
19 Hopefully the pre-release freeze can start late this week, and the
20 next cycle would reopen mid next month.  In the meantime, let's
21 shift the focus on making sure that what has already been merged to
22 'master' are good (i.e. regression hunting and fixes).
24 You can find the changes described here in the integration branches
25 of the repositories listed at
27     http://git-blame.blogspot.com/p/git-public-repositories.html
29 --------------------------------------------------
30 [New Topics]
32 * js/rebase-i-clean-up-upon-continue-to-skip (2015-06-18) 3 commits
33  - rebase -i: do not leave a CHERRY_PICK_HEAD file behind
34  - SQUASH: test_must_fail is a shell function
35  - t3404: demonstrate CHERRY_PICK_HEAD bug
37  Abandoning an already applied change in "git rebase -i" with
38  "--continue" left CHERRY_PICK_HEAD and confused later steps.
40  Expecting a reroll.
41  ($gmane/271856)
44 * me/fetch-into-shallow-safety (2015-06-17) 1 commit
45  - fetch-pack: check for shallow if depth given
47  "git fetch --depth=<depth>" and "git clone --depth=<depth>" issued
48  a shallow transfer request even to an upload-pack that does not
49  support the capability.
51  Will merge to 'next'.
54 * mm/describe-doc (2015-06-16) 1 commit
55  - Documentation/describe: improve one-line summary
57  Will merge to 'next'.
60 * rh/test-color-avoid-terminfo-in-original-home (2015-06-17) 2 commits
61  - test-lib.sh: fix color support when tput needs ~/.terminfo
62  - Revert "test-lib.sh: do tests for color support after changing HOME"
64  An ancient test framework enhancement to allow color was not
65  entirely correct; this makes it work even when tput needs to read
66  from the ~/.terminfo under the user's real HOME directory.
68  Will merge to 'next'.
71 * tb/checkout-doc (2015-06-17) 1 commit
72  - git-checkout.txt: document "git checkout <pathspec>" better
74  $gmane/271812
77 * jk/pretty-encoding-doc (2015-06-17) 1 commit
78  - docs: clarify that --encoding can produce invalid sequences
80  $gmane/271879
83 * ak/format-patch-odir-config (2015-06-19) 1 commit
84  - format-patch: introduce format.outputDirectory configuration
86  Reroll exists but didn't pick it up as it seems to be still
87  collecting review comments.
90 * bc/gpg-verify-raw (2015-06-22) 7 commits
91  - verify-tag: add option to print raw gpg status information
92  - verify-commit: add option to print raw gpg status information
93  - gpg: centralize printing signature buffers
94  - gpg: centralize signature check
95  - verify-commit: add test for exit status on untrusted signature
96  - verify-tag: share code with verify-commit
97  - verify-tag: add tests
99  "git verify-tag" and "git verify-commit" have been taught to share
100  more code, and then learned to optionally show the verification
101  message from the underlying GPG implementation.
103  Will merge to 'next'.
106 * cb/parse-magnitude (2015-06-22) 2 commits
107  - parse-options: move unsigned long option parsing out of pack-objects.c
108  - test-parse-options: update to handle negative ints
110  Move machinery to parse human-readable scaled numbers like 1k, 4M,
111  and 2G as an option parameter's value from pack-objects to
112  parse-options API, to make it available to other codepaths.
114  Will merge to 'next'.
117 * cb/subtree-tests-update (2015-06-22) 3 commits
118  - contrib/subtree: small tidy-up to test
119  - contrib/subtree: fix broken &&-chains and revealed test error
120  - contrib/subtree: use tabs consitently for indentation in tests
122  Will merge to 'next'.
125 * da/mergetool-winmerge (2015-06-19) 1 commit
126  - mergetool-lib: fix default tool selection
128  An earlier change already in 'master' broke the default tool
129  selection for mergetool.
131  Will merge to 'next'.
134 * jk/cat-file-batch-all (2015-06-22) 8 commits
135  - cat-file: sort and de-dup output of --batch-all-objects
136  - cat-file: add --batch-all-objects option
137  - cat-file: split batch_one_object into two stages
138  - cat-file: stop returning value from batch_one_object
139  - cat-file: add --buffer option
140  - cat-file: move batch_options definition to top of file
141  - cat-file: minor style fix in options list
142  - Merge branch 'jk/maint-for-each-packed-object' into jk/cat-file-batch-all
143  (this branch uses jk/maint-for-each-packed-object.)
145  "cat-file" learned "--batch-all-objects" option to enumerate all
146  available objects in the repository more quickly than "rev-list
147  --all --objects" (the output includes unreachable objects, though).
151 * jk/maint-for-each-packed-object (2015-06-22) 1 commit
152  - for_each_packed_object: automatically open pack index
153  (this branch is used by jk/cat-file-batch-all.)
155  The for_each_packed_object() API function did not iterate over
156  objects in a packfile that hasn't been used yet.
158  Will merge to 'next'.
161 --------------------------------------------------
162 [Stalled]
164 * kk/log-merges-config (2015-04-21) 5 commits
165  - bash-completion: add support for git-log --merges= and log.merges
166  - t4202-log: add tests for --merges=
167  - Documentation: add git-log --merges= option and log.merges config. var
168  - log: honor log.merges= option
169  - revision: add --merges={show|only|hide} option
171  "git log" (but not other commands in the "log" family) learned to
172  pay attention to the log.merges configuration variable that can be
173  set to "show" (the normal behaviour), "only" (hide non-merge
174  commits), or "hide" (hide merge commits).  --merges=(show|only|hide)
175  can be used to override the setting from the command line.
177  The documentation may need to be updated once more ($gmane/267250).
178  Waiting for a reroll.
181 * mg/httpd-tests-update-for-apache-2.4 (2015-04-08) 2 commits
182  - t/lib-git-svn: check same httpd module dirs as lib-httpd
183  - t/lib-httpd: load mod_unixd
185  This is the first two commits in a three-patch series $gmane/266962
186  Will be rerolled.
187  with updated log message ($gmane/268061).
190 * mh/numparse (2015-03-19) 14 commits
191  - diff_opt_parse(): use convert_i() when handling --abbrev=<num>
192  - diff_opt_parse(): use convert_i() when handling "-l<num>"
193  - opt_arg(): simplify pointer handling
194  - opt_arg(): report errors parsing option values
195  - opt_arg(): use convert_i() in implementation
196  - opt_arg(): val is always non-NULL
197  - builtin_diff(): detect errors when parsing --unified argument
198  - handle_revision_opt(): use convert_ui() when handling "--abbrev="
199  - strtoul_ui(), strtol_i(): remove functions
200  - handle_revision_opt(): use convert_i() when handling "-<digit>"
201  - handle_revision_opt(): use skip_prefix() in many places
202  - write_subdirectory(): use convert_ui() for parsing mode
203  - cacheinfo_callback(): use convert_ui() when handling "--cacheinfo"
204  - numparse: new module for parsing integral numbers
206  Many codepaths use unchecked use of strtol() and friends (or even
207  worse, atoi()).  Introduce a set of wrappers that try to be more
208  careful.
210  Will be rerolled.
211  ($gmane/268058).
214 * tf/gitweb-project-listing (2015-03-19) 5 commits
215  - gitweb: make category headings into links when they are directories
216  - gitweb: optionally set project category from its pathname
217  - gitweb: add a link under the search box to clear a project filter
218  - gitweb: if the PATH_INFO is incomplete, use it as a project_filter
219  - gitweb: fix typo in man page
221  Update gitweb to make it more pleasant to deal with a hierarchical
222  forest of repositories.
224  Any comments from those who use or have their own code in Gitweb?
227 * jc/a-lone-dash-stands-for-previous-branch (2015-03-16) 1 commit
228  - "-" and "@{-1}" on various programs
230  Lose special case code to make a lone dash "-" mean the previous
231  branch aka "@{-1}" from a handful subcommands, and instead support
232  the notation throughout the system by reimplementing it at the
233  revisions layer.
235  Needs tests, documentation updates, etc.  Also does only a half-way
236  job dealing with range notation, which needs to be fixed before the
237  series goes anywhere.
240 * nd/list-files (2015-02-09) 21 commits
241  - t3080: tests for git-list-files
242  - list-files: -M aka diff-cached
243  - list-files -F: show submodules with the new indicator '&'
244  - list-files: add -F/--classify
245  - list-files: show directories as well as files
246  - list-files: do not show duplicate cached entries
247  - list-files: sort output and remove duplicates
248  - list-files: add -t back
249  - list-files: add -1 short for --no-column
250  - list-files: add -R/--recursive short for --max-depth=-1
251  - list-files: -u does not imply showing stages
252  - list-files: make alias 'ls' default to 'list-files'
253  - list-files: a user friendly version of ls-files and more
254  - ls-files: support --max-depth
255  - ls-files: add --column
256  - ls-files: add --color to highlight file names
257  - ls-files: buffer full item in strbuf before printing
258  - ls_colors.c: highlight submodules like directories
259  - ls_colors.c: add a function to color a file name
260  - ls_colors.c: parse color.ls.* from config file
261  - ls_colors.c: add $LS_COLORS parsing code
263  A new "git list-files" Porcelain command, "ls-files" with bells and
264  whistles.
266  Reroll to base on wt-status work ($gmane/265142) has seen some
267  positive discussions.
269  Waiting for a further polished reroll ($gmane/265534).
272 * js/fsck-opt (2015-06-22) 19 commits
273  - fsck: support ignoring objects in `git fsck` via fsck.skiplist
274  - fsck: git receive-pack: support excluding objects from fsck'ing
275  - fsck: introduce `git fsck --connectivity-only`
276  - fsck: support demoting errors to warnings
277  - fsck: document the new receive.fsck.<msg-id> options
278  - fsck: allow upgrading fsck warnings to errors
279  - fsck: optionally ignore specific fsck issues completely
280  - fsck: disallow demoting grave fsck errors to warnings
281  - fsck: add a simple test for receive.fsck.<msg-id>
282  - fsck: make fsck_tag() warn-friendly
283  - fsck: handle multiple authors in commits specially
284  - fsck: make fsck_commit() warn-friendly
285  - fsck: make fsck_ident() warn-friendly
286  - fsck: report the ID of the error/warning
287  - fsck (receive-pack): allow demoting errors to warnings
288  - fsck: offer a function to demote fsck errors to warnings
289  - fsck: provide a function to parse fsck message IDs
290  - fsck: introduce identifiers for fsck messages
291  - fsck: introduce fsck options
293  Rerolled (at v7) and seems more or less ready for 'next'.
296 * nd/pathspec-strip-fix (2015-04-18) 1 commit
297  - pathspec: adjust prefixlen after striping trailing slash
299  Does not quite fix ($gmane/267614).
300  Will discard.
303 * jc/diff-b-m (2015-02-23) 5 commits
304  . WIPWIP
305  . WIP: diff-b-m
306  - diffcore-rename: allow easier debugging
307  - diffcore-rename.c: add locate_rename_src()
308  - diffcore-break: allow debugging
310  "git diff -B -M" produced incorrect patch when the postimage of a
311  completely rewritten file is similar to the preimage of a removed
312  file; such a resulting file must not be expressed as a rename from
313  other place.
315  The fix in this patch is broken, unfortunately.
318 * pw/remote-set-url-fetch (2014-11-26) 1 commit
319  - remote: add --fetch and --both options to set-url
321  Expecting a reroll.
324 * tr/remerge-diff (2014-11-10) 9 commits
325  - t4213: avoid "|" in sed regexp
326  - log --remerge-diff: show what the conflict resolution changed
327  - name-hash: allow dir hashing even when !ignore_case
328  - merge-recursive: allow storing conflict hunks in index
329  - merge_diff_mode: fold all merge diff variants into an enum
330  - combine-diff: do not pass revs->dense_combined_merges redundantly
331  - merge-recursive: -Xindex-only to leave worktree unchanged
332  - merge-recursive: internal flag to avoid touching the worktree
333  - merge-recursive: remove dead conditional in update_stages()
335  "log -p" output learns a new way to let users inspect a merge
336  commit by showing the differences between the automerged result
337  with conflicts the person who recorded the merge would have seen
338  and the final conflict resolution that was recorded in the merge.
340  Waiting for a reroll.
341  ($gmane/256591).
344 * tg/perf-lib-test-perf-cleanup (2013-09-19) 2 commits
345  - perf-lib: add test_perf_cleanup target
346  - perf-lib: split starting the test from the execution
348  Add test_perf_cleanup shell function to the perf suite, that allows
349  the script writers to define a test with a clean-up action.
351  Will hold.
354 * jc/show-branch (2014-03-24) 5 commits
355  - show-branch: use commit slab to represent bitflags of arbitrary width
356  - show-branch.c: remove "all_mask"
357  - show-branch.c: abstract out "flags" operation
358  - show-branch.c: lift all_mask/all_revs to a global static
359  - show-branch.c: update comment style
361  Waiting for the final step to lift the hard-limit.
363 --------------------------------------------------
364 [Cooking]
366 * jk/pkt-log-pack (2015-06-16) 3 commits
367  - pkt-line: support tracing verbatim pack contents
368  - pkt-line: tighten sideband PACK check when tracing
369  - pkt-line: simplify starts_with checks in packet tracing
371  Enhance packet tracing machinery to allow capturing an incoming
372  pack data to a file for debugging.
375 * jk/stash-require-clean-index (2015-06-15) 1 commit
376   (merged to 'next' on 2015-06-16 at beb4883)
377  + Revert "stash: require a clean index to apply"
379  A hotfix for the topic already in 'master'.
381  Will merge to 'master'.
384 * kb/i18n-doc (2015-06-15) 1 commit
385  - Documentation/i18n.txt: clarify character encoding support
387  Comments (other than $gmane/271657)?
390 * kb/use-nsec-doc (2015-06-15) 1 commit
391  - Makefile / racy-git.txt: clarify USE_NSEC prerequisites
393  Comments (other than $gmane/271656)?
396 * kn/for-each-ref (2015-06-15) 11 commits
397  - ref-filter: make 'ref_array_item' use a FLEX_ARRAY for refname
398  - for-each-ref: introduce filter_refs()
399  - ref-filter: move code from 'for-each-ref'
400  - ref-filter: add 'ref-filter.h'
401  - for-each-ref: rename variables called sort to sorting
402  - for-each-ref: rename some functions and make them public
403  - for-each-ref: introduce 'ref_array_clear()'
404  - for-each-ref: introduce new structures for better organisation
405  - for-each-ref: rename 'refinfo' to 'ref_array_item'
406  - for-each-ref: clean up code
407  - for-each-ref: extract helper functions out of grab_single_ref()
409  GSoC project to rebuild ref listing by branch and tag based on the
410  for-each-ref machinery.
412  Will merge to 'next'.
415 * mh/init-delete-refs-api (2015-06-22) 19 commits
416  - delete_ref(): use the usual convention for old_sha1
417  - cmd_update_ref(): make logic more straightforward
418  - update_ref(): don't read old reference value before delete
419  - check_branch_commit(): make first parameter const
420  - refs.h: add some parameter names to function declarations
421  - refs: move the remaining ref module declarations to refs.h
422  - initial_ref_transaction_commit(): check for ref D/F conflicts
423  - initial_ref_transaction_commit(): check for duplicate refs
424  - refs: remove some functions from the module's public interface
425  - initial_ref_transaction_commit(): function for initial ref creation
426  - repack_without_refs(): make function private
427  - prune_refs(): use delete_refs()
428  - prune_remote(): use delete_refs()
429  - delete_refs(): bail early if the packed-refs file cannot be rewritten
430  - delete_refs(): make error message more generic
431  - delete_refs(): new function for the refs API
432  - delete_ref(): handle special case more explicitly
433  - remove_branches(): remove temporary
434  - delete_ref(): move declaration to refs.h
436  Clean up refs API and make "git clone" less intimate with the
437  implementation detail.
439  Will merge to 'next'.
442 * mh/replace-refs (2015-06-12) 1 commit
443  - Allow to control where the replace refs are looked for
445  Add an environment variable to tell Git to look into refs hierarchy
446  other than refs/replace/ for the object replacement data.
449 * nd/multiple-work-trees (2015-06-12) 1 commit
450  - checkout: don't check worktrees when not necessary
452  "git checkout [<tree-ish>] <paths>" spent unnecessary cycles
453  checking if the current branch was checked out elsewhere, when we
454  know we are not switching the branches ourselves.
456  Will merge to 'next'.
459 * pa/auto-gc-mac-osx (2015-06-12) 1 commit
460   (merged to 'next' on 2015-06-16 at 151ec95)
461  + hooks/pre-auto-gc: adjust power checking for newer OS X
463  Recent Mac OS X updates breaks the logic to detect that the machine
464  is on the AC power in the sample pre-auto-gc script.
466  Will merge to 'master'.
469 * pt/t0302-needs-sanity (2015-06-12) 1 commit
470   (merged to 'next' on 2015-06-16 at f0d8e17)
471  + t0302: "unreadable" test needs SANITY prereq
473  Will merge to 'master'.
476 * af/tcsh-completion-noclobber (2015-06-09) 1 commit
477   (merged to 'next' on 2015-06-16 at 621f205)
478  + git-completion.tcsh: fix redirect with noclobber
480  The tcsh completion writes a bash scriptlet but that would have
481  failed for users with noclobber set.
483  Will merge to 'master'.
486 * es/utf8-stupid-compiler-workaround (2015-06-05) 1 commit
487   (merged to 'next' on 2015-06-11 at dc0f2d2)
488  + utf8: NO_ICONV: silence uninitialized variable warning
490  A compilation workaround.
492  Will merge to 'master'.
495 * fk/doc-format-patch-vn (2015-06-10) 1 commit
496   (merged to 'next' on 2015-06-16 at 9be3516)
497  + doc: format-patch: fix typo
499  Docfix.
501  Will merge to 'master'.
504 * gp/status-rebase-i-info (2015-06-09) 5 commits
505  - SQUASH??? fix misindent
506  - status: add new tests for status during rebase -i
507  - status: give more information during rebase -i
508  - status: differentiate interactive from non-interactive rebases
509  - status: factor two rebase-related messages together
511  Teach "git status" to show a more detailed information regarding
512  the "rebase -i" session in progress.
514  Expecting a reroll.
517 * jc/prompt-document-ps1-state-separator (2015-06-10) 1 commit
518  - git-prompt.sh: document GIT_PS1_STATESEPARATOR
520  Docfix.
522  Will merge to 'next'.
525 * jk/index-pack-reduce-recheck (2015-06-09) 1 commit
526   (merged to 'next' on 2015-06-16 at ff83705)
527  + index-pack: avoid excessive re-reading of pack directory
529  Disable "have we lost a race with competing repack?" check while
530  receiving a huge object transfer that runs index-pack.
532  Will merge to 'master'.
535 * js/sleep-without-select (2015-06-05) 4 commits
536   (merged to 'next' on 2015-06-11 at 278edb1)
537  + lockfile: wait using sleep_millisec() instead of select()
538  + lockfile: convert retry timeout computations to millisecond
539  + help.c: wrap wait-only poll() invocation in sleep_millisec()
540  + lockfile: replace random() by rand()
542  Portability fix.
544  Will merge to 'master'.
547 * ld/p4-changes-block-size (2015-06-10) 4 commits
548   (merged to 'next' on 2015-06-16 at 09b7daa)
549  + git-p4: fixing --changes-block-size handling
550  + git-p4: add tests for non-numeric revision range
551  + git-p4: test with limited p4 server results
552  + git-p4: additional testing of --changes-block-size
554  More Perforce row number limit workaround for "git p4".
556  Will merge to 'master'.
559 * mh/fsck-reflog-entries (2015-06-08) 2 commits
560   (merged to 'next' on 2015-06-16 at 44e3202)
561  + fsck: report errors if reflog entries point at invalid objects
562  + fsck_handle_reflog_sha1(): new function
564  "git fsck" used to ignore missing or invalid objects recorded in reflog.
566  Will merge to 'master'.
569 * mk/utf8-no-iconv-warn (2015-06-08) 1 commit
570  - utf8.c: print warning about disabled iconv
572  Warn when a reencoding is requested in a build without iconv
573  support, as the end user is likely to get an unexpected result.  I
574  think the same level of safety should be added to a build with
575  iconv support when the specified encoding is not available, but the
576  patch does not go there.
578  Expecting a reroll.
581 * mr/rebase-i-customize-insn-sheet (2015-06-15) 1 commit
582  - git-rebase--interactive.sh: add config option for custom instruction format
584  "git rebase -i"'s list of todo is made configurable.
586  Will merge to 'next'.
589 * nd/untracked-cache (2015-06-08) 1 commit
590   (merged to 'next' on 2015-06-16 at 5e7df1d)
591  + read-cache: fix untracked cache invalidation when split-index is used
593  Hotfix for the 'untracked-cache' topic that is already in 'master'.
595  Will merge to 'master'.
598 * pt/am-abort-fix (2015-06-08) 6 commits
599   (merged to 'next' on 2015-06-16 at 9cac1de)
600  + am --abort: keep unrelated commits on unborn branch
601  + am --abort: support aborting to unborn branch
602  + am --abort: revert changes introduced by failed 3way merge
603  + am --skip: support skipping while on unborn branch
604  + am -3: support 3way merge on unborn branch
605  + am --skip: revert changes introduced by failed 3way merge
607  Various fixes around "git am" that applies a patch to a history
608  that is not there yet.
610  Will merge to 'master'.
613 * pt/am-foreign (2015-06-15) 5 commits
614  - am: teach mercurial patch parser how to read from stdin
615  - am: use gmtime() to parse mercurial patch date
616  - t4150: test applying StGit series
617  - am: teach StGit patch parser how to read from stdin
618  - t4150: test applying StGit patch
620  Various enhancements around "git am" reading patches generated by
621  foreign SCM.
623  Will merge to 'next'.
626 * pt/pull-builtin (2015-06-18) 19 commits
627  - pull: remove redirection to git-pull.sh
628  - pull --rebase: error on no merge candidate cases
629  - pull --rebase: exit early when the working directory is dirty
630  - pull: configure --rebase via branch.<name>.rebase or pull.rebase
631  - pull: teach git pull about --rebase
632  - pull: set reflog message
633  - pull: implement pulling into an unborn branch
634  - pull: fast-forward working tree if head is updated
635  - pull: check if in unresolved merge state
636  - pull: support pull.ff config
637  - pull: error on no merge candidates
638  - pull: pass git-fetch's options to git-fetch
639  - pull: pass git-merge's options to git-merge
640  - pull: pass verbosity, --progress flags to fetch and merge
641  - pull: implement fetch + merge
642  - pull: implement skeletal builtin pull
643  - argv-array: implement argv_array_pushv()
644  - parse-options-cb: implement parse_opt_passthru_argv()
645  - parse-options-cb: implement parse_opt_passthru()
647  Reimplement 'git pull' in C.
650 * rl/send-email-aliases (2015-06-17) 10 commits
651  - send-email: suppress meaningless whitespaces in from field
652  - send-email: allow multiple emails using --cc, --to and --bcc
653  - send-email: consider quote as delimiter instead of character
654  - send-email: reduce dependancies impact on parse_address_line
655  - send-email: minor code refactoring
656  - send-email: allow use of aliases in the From field of --compose mode
657  - send-email: refactor address list process
658  - t9001-send-email: refactor header variable fields replacement
659  - send-email: allow aliases in patch header and command script outputs
660  - t9001-send-email: move script creation in a setup test
662  "git send-email" now performs alias-expansion on names that are
663  given via --cccmd, etc.
665  This round comes with a lot more enhanced e-mail address parser,
666  which makes it a bit scary, but as long as it works as designed, it
667  makes it wonderful ;-).
669  Still RFC?
672 * sg/commit-cleanup-scissors (2015-06-09) 1 commit
673   (merged to 'next' on 2015-06-16 at 988e23d)
674  + commit: cope with scissors lines in commit message
676  "git commit --cleanup=scissors" was not careful enough to protect
677  against getting fooled by a line that looked like scissors.
679  Will merge to 'master'.
682 * sg/completion-commit-cleanup (2015-06-08) 1 commit
683   (merged to 'next' on 2015-06-16 at a9d1c77)
684  + completion: teach 'scissors' mode to 'git commit --cleanup='
686  Will merge to 'master'.
689 * wp/sha1-name-negative-match (2015-06-08) 2 commits
690  - sha1_name.c: introduce '^{/!-<negative pattern>}' notation
691  - test for '!' handling in rev-parse's named commits
693  Introduce "branch^{/!-<pattern>}" notation to name a commit
694  reachable from branch that does not match the given pattern.
696  Expecting a reroll.
699 * bc/object-id (2015-06-17) 10 commits
700  . remote.c: use struct object_id in many functions
701  . object-id: use struct object_id in struct object
702  . remote.c: use struct object_id in ref_newer()
703  . transport-helper.c: use struct object_id in push_refs_with_export()
704  . connect.c: use struct object_id in get_remote_heads()
705  . remote-curl: use struct object_id in parse_fetch()
706  . fetch-pack: use struct object_id in add_sought_entry_mem()
707  . object_id: convert struct ref to use object_id.
708  . sha1_file: introduce has_object_file() helper
709  . refs: convert some internal functions to use object_id
711  More transition from "unsigned char[40]" to "struct object_id".
713  While GSoC and other topics are actively moving existing code
714  around, this cannot go in; ejected from 'pu'.
717 * jc/ll-merge-expose-path (2015-06-04) 1 commit
718   (merged to 'next' on 2015-06-11 at 5c5fe41)
719  + ll-merge: pass the original path to external drivers
721  Traditionally, external low-level 3-way merge drivers are expected
722  to produce their results based solely on the contents of the three
723  variants given in temporary files named by %O, %A and %B on their
724  command line.  Additionally allow them to look at the final path
725  (given by %P).
727  Will merge to 'master'.
730 * jk/log-missing-default-HEAD (2015-06-03) 1 commit
731  - log: diagnose empty HEAD more clearly
733  "git init empty && git -C empty log" said "bad default revision 'HEAD'",
734  which was found to be a bit confusing to new users.
736  What's the status of this one?
739 * gr/rebase-i-drop-warn (2015-06-01) 2 commits
740  - git rebase -i: warn about removed commits
741  - git-rebase -i: add command "drop" to remove a commit
743  Add "drop commit-object-name subject" command as another way to
744  skip replaying of a commit in "rebase -i", and then punish those
745  who do not use it (and instead just remove the lines) by throwing
746  a warning.
748  Expecting a reroll ($gmane/271831).
751 * jh/strbuf-read-use-read-in-full (2015-06-01) 1 commit
752  - strbuf_read(): skip unnecessary strbuf_grow() at eof
754  Avoid one extra iteration and strbuf_grow() of 8kB in
755  strbuf_read().
757  Looked reasonable; perhaps a log message clarification is needed.
759  Expecting a reroll.
762 * mh/reporting-broken-refs-from-for-each-ref (2015-06-08) 4 commits
763   (merged to 'next' on 2015-06-16 at 31af2b8)
764  + read_loose_refs(): treat NULL_SHA1 loose references as broken
765  + read_loose_refs(): simplify function logic
766  + for-each-ref: report broken references correctly
767  + t6301: new tests of for-each-ref error handling
769  "git for-each-ref" reported "missing object" for 0{40} when it
770  encounters a broken ref.  The lack of object whose name is 0{40} is
771  not the problem; the ref being broken is.
773  Will merge to 'master'.
776 * jc/apply-reject-noop-hunk (2015-06-01) 1 commit
777   (merged to 'next' on 2015-06-11 at 8063665)
778  + apply: reject a hunk that does not do anything
780  "git apply" cannot diagnose a patch corruption when the breakage is
781  to mark the length of the hunk shorter than it really is on the
782  hunk header line "@@ -l,k +m,n @@"; one special case it could is
783  when the hunk becomes no-op (e.g. k == n == 2 for two-line context
784  patch output), and it learned how to do so.
786  Will merge to 'master'.
789 * es/configure-getdelim (2015-06-03) 2 commits
790   (merged to 'next' on 2015-06-11 at cdead14)
791  + configure: add getdelim() check
792  + config.mak.uname: Darwin: define HAVE_GETDELIM for modern OS X releases
794  Auto-detect availability of getdelim() that helps optimized version
795  of strbuf_getwholeline().
797  Will merge to 'master'.
800 * es/osx-header-pollutes-mask-macro (2015-06-03) 2 commits
801   (merged to 'next' on 2015-06-11 at cd8c39e)
802  + ewah: use less generic macro name
803  + ewah/bitmap: silence warning about MASK macro redefinition
805  Will merge to 'master'.
808 * es/send-email-sendmail-alias (2015-06-01) 10 commits
809   (merged to 'next' on 2015-06-11 at b5e310e)
810  + send-email: further warn about unsupported sendmail aliases features
811  + t9001: add sendmail aliases line continuation tests
812  + t9001: refactor sendmail aliases test infrastructure
813  + send-email: implement sendmail aliases line continuation support
814  + send-email: simplify sendmail aliases comment and blank line recognizer
815  + send-email: refactor sendmail aliases parser
816  + send-email: fix style: cuddle 'elsif' and 'else' with closing brace
817  + send-email: drop noise comments which merely repeat what code says
818  + send-email: visually distinguish sendmail aliases parser warnings
819  + send-email: further document missing sendmail aliases functionality
821  "git send-email" learned to handle more forms of sendmail style
822  aliases file.
824  Will merge to 'master'.
827 * jc/do-not-feed-tags-to-clear-commit-marks (2015-06-01) 1 commit
828   (merged to 'next' on 2015-06-11 at 65b4308)
829  + format-patch: do not feed tags to clear_commit_marks()
831  "git format-patch --ignore-if-upstream A..B" did not like to be fed
832  tags as boundary commits.
834  Will merge to 'master'.
837 * mg/index-read-error-messages (2015-06-01) 2 commits
838  - messages: uniform error messages for index write
839  - show-index: uniform error messages for index read
841  The tip was RFC.
842  Expecting a reroll.
845 * pt/pull-optparse (2015-06-02) 3 commits
846   (merged to 'next' on 2015-06-11 at e252b4c)
847  + pull: use git-rev-parse --parseopt for option parsing
848  + pull: handle git-fetch's options as well
849  + Merge branch 'pt/pull-tests' into pt/pull-optparse
851  "git pull" has become more aware of the options meant for
852  underlying "git fetch" and then learned to use parse-options
853  parser.
855  Will merge to 'master'.
858 * qn/blame-show-email (2015-06-01) 1 commit
859   (merged to 'next' on 2015-06-11 at b4998e2)
860  + blame: add blame.showEmail configuration
862  "git blame" learned blame.showEmail configuration variable.
864  Will merge to 'master'.
867 * rl/am-3way-config (2015-06-04) 3 commits
868   (merged to 'next' on 2015-06-11 at 9b9910d)
869  + git-am: add am.threeWay config variable
870  + t4150-am: refactor am -3 tests
871  + git-am.sh: fix initialization of the threeway variable
873  "git am" learned am.threeWay configuration variable.
875  Will merge to 'master'.
878 * hv/submodule-config (2015-06-15) 4 commits
879  - do not die on error of parsing fetchrecursesubmodules option
880  - use new config API for worktree configurations of submodules
881  - extract functions for submodule config set and lookup
882  - implement submodule config API for lookup of .gitmodules values
884  The gitmodules API accessed from the C code learned to cache stuff
885  lazily.
887  Looked reasonable from a cursory read.
890 * sg/config-name-only (2015-05-28) 3 commits
891  - completion: use new 'git config' options to reliably list variable names
892  - SQUASH
893  - config: add options to list only variable names
895  "git config --list" output was hard to parse when values consist of
896  multiple lines.  Introduce a way to show only the keys.
898  Adding a single --name-only option may be a better way to go than
899  adding two new options.
901  Expecting reroll.
904 * jc/push-tags-also (2015-05-29) 1 commit
905  - push --tags: push tags *in addition to* other stuff
907  "git fetch --tags" learned to fetch tags in addition to other stuff
908  a few years ago, but "git push --tags" didn't.  Now it does.
911 * jc/commit-slab (2015-05-22) 1 commit
912  - commit-slab: introduce slabname##_peek() function
914  Memory use reduction when commit-slab facility is used to annotate
915  sparsely (which is not recommended in the first place).
918 * jc/clone-bundle (2015-04-30) 1 commit
919  - repack: optionally create a clone.bundle
921  Still an early WIP
924 * ee/clean-remove-dirs (2015-06-15) 5 commits
925  - clean: improve performance when removing lots of directories
926  - p7300: add performance tests for clean
927  - t7300: add tests to document behavior of clean and nested git
928  - setup: sanity check file size in read_gitfile_gently
929  - setup: add gentle version of read_gitfile
931  Replace "is this subdirectory a separate repository that should not
932  be touched?" check "git clean" does by checking if it has .git/HEAD
933  using the submodule-related code with a more optimized check.
935  Looked reasonable from a cursory read.
938 * jc/merge-drop-old-syntax (2015-04-29) 1 commit
939   (merged to 'next' on 2015-05-28 at 6bfd8b9)
940  + merge: drop 'git merge <message> HEAD <commit>' syntax
942  Stop supporting "git merge <message> HEAD <commit>" syntax that
943  has been deprecated since October 2007.
945  Will keep in 'next' during the 2.5 cycle.