What's cooiking (2014/05 #06)
[alt-git.git] / whats-cooking.txt
blob195fa2e8015f96173051022781034aacc1a3f1f5
1 To: git@vger.kernel.org
2 Bcc: lwn@lwn.net
3 Subject: What's cooking in git.git (Mar 2014, #06; Tue, 25)
4 X-master-at: d393d140b5656e608b332c00ea3b14f9a060d604
5 X-next-at: 2ddfaae461cfeaf6df645d1978edc11df0e4914b
7 What's cooking in git.git (Mar 2014, #06; Tue, 25)
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 More topics merged to 'master', many of which are fallouts from GSoC
15 microprojects.
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 * bb/diff-no-index-dotdot (2014-03-19) 2 commits
26   (merged to 'next' on 2014-03-20 at 352f48c)
27  + diff-no-index: replace manual "."/".." check with is_dot_or_dotdot()
28  + diff-no-index: rename read_directory()
31 * cp/am-patch-format-doc (2014-03-17) 2 commits
32   (merged to 'next' on 2014-03-17 at 7437c77)
33  + Documentation/git-am: typofix
34   (merged to 'next' on 2014-03-12 at 17c3ada)
35  + Documentation/git-am: Document supported --patch-format options
38 * dm/configure-iconv-locale-charset (2014-03-11) 1 commit
39   (merged to 'next' on 2014-03-20 at 4443bfd)
40  + configure.ac: link with -liconv for locale_charset()
43 * jk/lib-terminal-lazy (2014-03-14) 1 commit
44   (merged to 'next' on 2014-03-20 at 5de832f)
45  + t/lib-terminal: make TTY a lazy prerequisite
47  The test helper lib-terminal always run an actual test_expect_* when
48  included, which screwed up with the use of skil-all that may have to
49  be done later.
52 * jk/mv-submodules-fix (2014-03-17) 2 commits
53   (merged to 'next' on 2014-03-17 at 7cae3b1)
54  + mv: prevent mismatched data when ignoring errors.
55  + builtin/mv: fix out of bounds write
57  "git mv" that moves a submodule forgot to adjust the array that
58  uses to keep track of which submodules were to be moved to update
59  its configuration.
62 * jk/warn-on-object-refname-ambiguity (2014-03-13) 4 commits
63   (merged to 'next' on 2014-03-17 at 3f8e98e)
64  + rev-list: disable object/refname ambiguity check with --stdin
65  + cat-file: restore warn_on_object_refname_ambiguity flag
66  + cat-file: fix a minor memory leak in batch_objects
67  + cat-file: refactor error handling of batch_objects
70 * mh/remove-subtree-long-pathname-fix (2014-03-13) 2 commits
71   (merged to 'next' on 2014-03-17 at 68cc994)
72  + entry.c: fix possible buffer overflow in remove_subtree()
73  + checkout_entry(): use the strbuf throughout the function
75  Length limit for the pathname used when removing a path in a deep
76  subdirectory has been removed to avoid buffer overflows.
79 * nd/commit-editor-cleanup (2014-02-25) 3 commits
80   (merged to 'next' on 2014-03-17 at 986605d)
81  + commit: add --cleanup=scissors
82  + wt-status.c: move cut-line print code out to wt_status_add_cut_line
83  + wt-status.c: make cut_line[] const to shrink .data section a bit
85  "git commit --cleanup=<mode>" learned a new mode, scissors.
88 * nd/indent-fix-connect-c (2014-03-13) 1 commit
89   (merged to 'next' on 2014-03-17 at a109efc)
90  + connect.c: SP after "}", not TAB
93 * nd/index-pack-error-message (2014-03-17) 1 commit
94   (merged to 'next' on 2014-03-20 at 4d722ac)
95  + index-pack: report error using the correct variable
97  "git index-pack" used a wrong variable to name the keep-file in an
98  error message when the file cannot be written or closed.
101 * rr/doc-merge-strategies (2014-03-17) 1 commit
102   (merged to 'next' on 2014-03-20 at d31f415)
103  + Documentation/merge-strategies: avoid hyphenated commands
105  There were a few instances of 'git-foo' remaining in the
106  documentation that should have been spelled 'git foo'.
109 * ss/test-on-mingw-rsync-path-no-absolute (2014-03-19) 1 commit
110   (merged to 'next' on 2014-03-20 at 2b7b95d)
111  + t5510: Do not use $(pwd) when fetching / pushing / pulling via rsync
114 * us/printf-not-echo (2014-03-18) 2 commits
115   (merged to 'next' on 2014-03-20 at 41205c8)
116  + test-lib.sh: do not "echo" caller-supplied strings
117  + rebase -i: do not "echo" random user-supplied strings
119  "rebase -i" produced a broken insn sheet when the title of a commit
120  happened to contain '\n' (or ended with '\c') due to a careless use
121  of 'echo'.
123 --------------------------------------------------
124 [New Topics]
126 * jk/tests-cleanup (2014-03-21) 12 commits
127  - t0001: drop subshells just for "cd"
128  - t0001: drop useless subshells
129  - t0001: use test_must_fail
130  - t0001: use test_config_global
131  - t0001: use test_path_is_*
132  - t0001: make symlink reinit test more careful
133  - t: prefer "git config --file" to GIT_CONFIG
134  - t: prefer "git config --file" to GIT_CONFIG with test_must_fail
135  - t: stop using GIT_CONFIG to cross repo boundaries
136  - t: drop useless sane_unset GIT_* calls
137  - t/test-lib: drop redundant unset of GIT_CONFIG
138  - t/Makefile: stop setting GIT_CONFIG
139  (this branch uses dt/tests-with-env-not-subshell.)
141  Will merge to 'next'.
143 --------------------------------------------------
144 [Stalled]
146 * tr/merge-recursive-index-only (2014-02-05) 3 commits
147  - merge-recursive: -Xindex-only to leave worktree unchanged
148  - merge-recursive: internal flag to avoid touching the worktree
149  - merge-recursive: remove dead conditional in update_stages()
150  (this branch is used by tr/remerge-diff.)
152  Will hold.
155 * tr/remerge-diff (2014-02-26) 5 commits
156  . log --remerge-diff: show what the conflict resolution changed
157  . name-hash: allow dir hashing even when !ignore_case
158  . merge-recursive: allow storing conflict hunks in index
159  . revision: fold all merge diff variants into an enum merge_diff_mode
160  . combine-diff: do not pass revs->dense_combined_merges redundantly
161  (this branch uses tr/merge-recursive-index-only.)
163  "log -p" output learns a new way to let users inspect a merge
164  commit by showing the differences between the automerged result
165  with conflicts the person who recorded the merge would have seen
166  and the final conflict resolution that was recorded in the merge.
168  RFC.  This latest round clashes with the kb/fast-hashmap topic in
169  'master'.
172 * sz/mingw-index-pack-threaded (2014-03-19) 1 commit
173  - Enable index-pack threading in msysgit.
175  Still under discussion among Windows folks
178 * bc/blame-crlf-test (2014-02-18) 1 commit
179  - blame: add a failing test for a CRLF issue.
181  I have a feeling that a fix for this should be fairly isolated and
182  trivial (it should be just the matter of paying attention to the
183  crlf settings when synthesizing the fake commit)---perhaps somebody
184  can squash in a fix to this?
187 * jk/makefile (2014-02-05) 16 commits
188  - FIXUP
189  - move LESS/LV pager environment to Makefile
190  - Makefile: teach scripts to include make variables
191  - FIXUP
192  - Makefile: auto-build C strings from make variables
193  - Makefile: drop *_SQ variables
194  - FIXUP
195  - Makefile: add c-quote helper function
196  - Makefile: introduce sq function for shell-quoting
197  - Makefile: always create files via make-var
198  - Makefile: store GIT-* sentinel files in MAKE/
199  - Makefile: prefer printf to echo for GIT-*
200  - Makefile: use tempfile/mv strategy for GIT-*
201  - Makefile: introduce make-var helper function
202  - Makefile: fix git-instaweb dependency on gitweb
203  - Makefile: drop USE_GETTEXT_SCHEME from GIT-CFLAGS
205  Simplify the Makefile rules and macros that exist primarily for
206  quoting purposes, and make it easier to robustly express the
207  dependency rules.
209  Expecting a reroll.
212 * kb/fast-hashmap-pack-struct (2014-02-24) 1 commit
213  - hashmap.h: make sure map entries are tightly packed
215  I am inclined to drop this; an alternative is to replace it with
216  the "more portable" one that uses #pragma, which I am willing to
217  try doing so on 'pu', though.
220 * po/everyday-doc (2014-01-27) 1 commit
221  - Make 'git help everyday' work
223  This may make the said command to emit something, but the source is
224  not meant to be formatted into a manual pages to begin with, and
225  also its contents are a bit stale.  It may be a good first step in
226  the right direction, but needs more work to at least get the
227  mark-up right before public consumption.
229  Will hold.
232 * jk/branch-at-publish-rebased (2014-01-17) 5 commits
233  - t1507 (rev-parse-upstream): fix typo in test title
234  - implement @{publish} shorthand
235  - branch_get: provide per-branch pushremote pointers
236  - branch_get: return early on error
237  - sha1_name: refactor upstream_mark
239  Give an easier access to the tracking branches from "other" side in
240  a triangular workflow by introducing B@{publish} that works in a
241  similar way to how B@{upstream} does.
243  Meant to be used as a basis for whatever Ram wants to build on.
245  Will hold.
248 * rb/merge-prepare-commit-msg-hook (2014-01-10) 4 commits
249  - merge: drop unused arg from abort_commit method signature
250  - merge: make prepare_to_commit responsible for write_merge_state
251  - t7505: ensure cleanup after hook blocks merge
252  - t7505: add missing &&
254  Expose more merge states (e.g. $GIT_DIR/MERGE_MODE) to hooks that
255  run during "git merge".  The log message stresses too much on one
256  hook, prepare-commit-msg, but it would equally apply to other hooks
257  like post-merge, I think.
259  Waiting for a reroll.
262 * jl/submodule-recursive-checkout (2013-12-26) 5 commits
263  - Teach checkout to recursively checkout submodules
264  - submodule: teach unpack_trees() to update submodules
265  - submodule: teach unpack_trees() to repopulate submodules
266  - submodule: teach unpack_trees() to remove submodule contents
267  - submodule: prepare for recursive checkout of submodules
269  Expecting a reroll.
272 * jc/graph-post-root-gap (2013-12-30) 3 commits
273  - WIP: document what we want at the end
274  - graph: remove unused code a bit
275  - graph: stuff the current commit into graph->columns[]
277  This was primarily a RFH ($gmane/239580).
280 * hv/submodule-ignore-fix (2013-12-06) 4 commits
281  - disable complete ignorance of submodules for index <-> HEAD diff
282  - always show committed submodules in summary after commit
283  - teach add -f option for ignored submodules
284  - fix 'git add' to skip submodules configured as ignored
286  Teach "git add" to be consistent with "git status" when changes to
287  submodules are set to be ignored, to avoid surprises after checking
288  with "git status" to see there isn't any change to be further added
289  and then see that "git add ." adds changes to them.
291  I think a reroll is coming, so this may need to be replaced, but I
292  needed some practice with heavy conflict resolution.  It conflicts
293  with two changes to "git add" that have been scheduled for Git 2.0
294  quite badly, and I think I got the resolution right this time.
296  Waiting for a reroll.
299 * np/pack-v4 (2013-09-18) 90 commits
300  . packv4-parse.c: add tree offset caching
301  . t1050: replace one instance of show-index with verify-pack
302  . index-pack, pack-objects: allow creating .idx v2 with .pack v4
303  . unpack-objects: decode v4 trees
304  . unpack-objects: allow to save processed bytes to a buffer
305  - ...
307  Nico and Duy advancing the eternal vaporware pack-v4.  This is here
308  primarily for wider distribution of the preview edition.
310  Temporarily ejected from 'pu', to try out jk/pack-bitmap, which
311  this topic conflicts with.
314 * tg/perf-lib-test-perf-cleanup (2013-09-19) 2 commits
315  - perf-lib: add test_perf_cleanup target
316  - perf-lib: split starting the test from the execution
318  Add test_perf_cleanup shell function to the perf suite, that allows
319  the script writers to define a test with a clean-up action.
321  Will hold.
324 * jc/format-patch (2013-04-22) 2 commits
325  - format-patch: --inline-single
326  - format-patch: rename "no_inline" field
328  A new option to send a single patch to the standard output to be
329  appended at the bottom of a message.  I personally have no need for
330  this, but it was easy enough to cobble together.  Tests, docs and
331  stripping out more MIMEy stuff are left as exercises to interested
332  parties.
335 * jc/show-branch (2014-03-24) 5 commits
336  - show-branch: use commit slab to represent bitflags of arbitrary width
337  - show-branch.c: remove "all_mask"
338  - show-branch.c: abstract out "flags" operation
339  - show-branch.c: lift all_mask/all_revs to a global static
340  - show-branch.c: update comment style
342  Waiting for the final step to lift the hard-limit before sending it out.
344 --------------------------------------------------
345 [Cooking]
347 * ca/doc-config-third-party (2014-03-21) 1 commit
348   (merged to 'next' on 2014-03-25 at 731e011)
349  + config.txt: third-party tools may and do use their own variables
351  Will merge to 'master'.
354 * dw/doc-status-no-longer-shows-pound-prefix (2014-03-21) 1 commit
355   (merged to 'next' on 2014-03-25 at 2683eb6)
356  + doc: status, remove leftover statement about '#' prefix
358  Will merge to 'master'.
361 * js/userdiff-cc (2014-03-21) 10 commits
362   (merged to 'next' on 2014-03-25 at 8c0e585)
363  + userdiff: have 'cpp' hunk header pattern catch more C++ anchor points
364  + t4018: test cases showing that the cpp pattern misses many anchor points
365  + t4018: test cases for the built-in cpp pattern
366  + t4018: reduce test files for pattern compilation tests
367  + t4018: convert custom pattern test to the new infrastructure
368  + t4018: convert java pattern test to the new infrastructure
369  + t4018: convert perl pattern tests to the new infrastructure
370  + t4018: an infrastructure to test hunk headers
371  + userdiff: support unsigned and long long suffixes of integer constants
372  + userdiff: support C++ ->* and .* operators in the word regexp
374  Improves the pattern to match the hunk-header for C/C++.
376  Will merge to 'master'.
379 * dp/makefile-charset-lib-doc (2014-03-23) 1 commit
380   (merged to 'next' on 2014-03-25 at b32e3ad)
381  + Makefile: describe CHARSET_LIB better
383  Will merge to 'master'.
386 * ib/rev-parse-parseopt-argh (2014-03-24) 5 commits
387  - parse-options: make sure argh string does not have SP or _
388  - update-index: teach --cacheinfo a new syntax "mode,sha1,path"
389  - parse-options: multi-word argh should use dash to separate words
390   (merged to 'next' on 2014-03-25 at d9083ed)
391  + t1502: protect runs of SPs used in the indentation
392  + rev-parse --parseopt: option argument name hints
394  Teaches the "rev-parse --parseopt" mechanism used by scripted
395  Porcelains to parse command line options and give help text how to
396  supply argv-help (the placeholder string for an option parameter,
397  e.g. "key-id" in "--gpg-sign=<key-id>").
399  Will merge the bottom part to 'master'.
402 * rs/pickaxe-i (2014-03-24) 10 commits
403   (merged to 'next' on 2014-03-25 at 3b6f21f)
404  + pickaxe: simplify kwset loop in contains()
405  + pickaxe: call strlen only when necessary in diffcore_pickaxe_count()
406  + pickaxe: move pickaxe() after pickaxe_match()
407  + pickaxe: merge diffcore_pickaxe_grep() and diffcore_pickaxe_count() into diffcore_pickaxe()
408  + pickaxe: honor -i when used with -S and --pickaxe-regex
409  + t4209: use helper functions to test --author
410  + t4209: use helper functions to test --grep
411  + t4209: factor out helper function test_log_icase()
412  + t4209: factor out helper function test_log()
413  + t4209: set up expectations up front
415  Allow the options -i/--regexp-ignore-case, --pickaxe-regex, and -S
416  to be used together and work as expected to perform a pickaxe
417  search using case-insensitive regular expression matching.
419  Will merge to 'master'.
422 * an/branch-config-message (2014-03-24) 1 commit
423  - branch.c: install_branch_config: simplify if chain
425  Will merge to 'next'.
428 * ah/doc-gitk-config (2014-03-20) 1 commit
429   (merged to 'next' on 2014-03-20 at d671b60)
430  + Documentation/gitk: document the location of the configulation file
432  Will merge to 'master'.
435 * as/grep-fullname-config (2014-03-20) 1 commit
436  - grep: add grep.fullName config variable
438  Will merge to 'next'.
441 * fr/add-interactive-argv-array (2014-03-18) 1 commit
442   (merged to 'next' on 2014-03-20 at 9d65f3d)
443  + add: use struct argv_array in run_add_interactive()
445  Will merge to 'master'.
448 * jk/pack-bitmap (2014-03-17) 1 commit
449   (merged to 'next' on 2014-03-20 at bba6246)
450  + pack-objects: turn off bitmaps when skipping objects
452  Instead of dying when asked to (re)pack with the reachability
453  bitmap when a bitmap cannot be built, just (re)pack without
454  producing a bitmap in such a case, with a warning.
456  Will merge to 'master', and probably to 'maint' later.
459 * jk/pack-bitmap-progress (2014-03-17) 2 commits
460   (merged to 'next' on 2014-03-20 at c7a83f9)
461  + pack-objects: show reused packfile objects in "Counting objects"
462  + pack-objects: show progress for reused packfiles
464  The progress output while repacking and transferring objects showed
465  an apparent large silence while writing the objects out of existing
466  packfiles, when the reachability bitmap was in use.
468  Will merge to 'master', and probably to 'maint' later.
471 * jk/subtree-prefix (2014-03-17) 1 commit
472   (merged to 'next' on 2014-03-20 at 81367fa)
473  + subtree: initialize "prefix" variable
475  A stray environment variable $prefix could have leaked into and
476  affected the behaviour of the "subtree" script.
478  Will merge to 'master'.
481 * nd/gc-aggressive (2014-03-17) 4 commits
482  - gc --aggressive: three phase repacking
483  - gc --aggressive: make --depth configurable
484  - pack-objects: support --keep
485  - environment.c: fix constness for odb_pack_keep()
488 * bg/rebase-off-of-previous-branch (2014-03-19) 1 commit
489   (merged to 'next' on 2014-03-21 at 916b759)
490  + rebase: allow "-" short-hand for the previous branch
492  Will merge to 'master'.
495 * dt/tests-with-env-not-subshell (2014-03-19) 1 commit
496   (merged to 'next' on 2014-03-25 at 19fe25f)
497  + tests: use "env" to run commands with temporary env-var settings
498  (this branch is used by jk/tests-cleanup.)
500  Will merge to 'master'.
503 * hs/simplify-bit-setting-in-fsck-tree (2014-03-20) 1 commit
504   (merged to 'next' on 2014-03-25 at 08efd68)
505  + fsck: use bitwise-or assignment operator to set flag
507  Will merge to 'master'.
510 * mm/status-porcelain-format-i18n-fix (2014-03-20) 2 commits
511  - SQUASH??? fix decl-after-stmt and simplify
512  - status: disable translation when --porcelain is used
514  Will merge to 'next' after squashing in the fixup.
517 * ap/remote-hg-skip-null-bookmarks (2014-03-25) 1 commit
518   (merged to 'next' on 2014-03-25 at a8cd922)
519  + remote-hg: do not fail on invalid bookmarks
521  Will merge to 'master'.
524 * ys/fsck-commit-parsing (2014-03-19) 2 commits
525   (merged to 'next' on 2014-03-21 at 2728983)
526  + fsck.c:fsck_commit(): use skip_prefix() to verify and skip constant
527  + fsck.c:fsck_ident(): ident points at a const string
529  Will merge to 'master'.
532 * bp/commit-p-editor (2014-03-18) 7 commits
533   (merged to 'next' on 2014-03-21 at 23b6b06)
534  + run-command: mark run_hook_with_custom_index as deprecated
535  + merge hook tests: fix and update tests
536  + merge: fix GIT_EDITOR override for commit hook
537  + commit: fix patch hunk editing with "commit -p -m"
538  + test patch hunk editing with "commit -p -m"
539  + merge hook tests: use 'test_must_fail' instead of '!'
540  + merge hook tests: fix missing '&&' in test
542  When it is not necessary to edit a commit log message (e.g. "git
543  commit -m" is given a message without specifying "-e"), we used to
544  disable the spawning of the editor by overriding GIT_EDITOR, but
545  this means all the uses of the editor, other than to edit the
546  commit log message, are also affected.
548  Will merge to 'master'.
551 * cn/fetch-prune-overlapping-destination (2014-03-24) 3 commits
552  - SQUASH??? style and leak fix
553  - fetch: handle overlaping refspecs on --prune
554  - fetch: add a failing test for prunning with overlapping refspecs
556  Protect refs in a hierarchy that can come from more than one remote
557  hierarcies from incorrect removal by "git fetch --prune".
559  Since I didn't get any responses to my earlier "Comments?", I ended
560  up reading it myself again and found a small leak.
562  Hoping to be able to merge a fix for this issue soonish.
565 * nd/multiple-work-trees (2014-03-25) 28 commits
566  - count-objects: report unused files in $GIT_DIR/repos/...
567  - gc: support prune --repos
568  - gc: style change -- no SP before closing bracket
569  - prune: strategies for linked checkouts
570  - checkout: detach if the branch is already checked out elsewhere
571  - checkout: clean up half-prepared directories in --to mode
572  - checkout: support checking out into a new working directory
573  - use new wrapper write_file() for simple file writing
574  - wrapper.c: wrapper to open a file, fprintf then close
575  - setup.c: support multi-checkout repo setup
576  - setup.c: detect $GIT_COMMON_DIR check_repository_format_gently()
577  - setup.c: convert check_repository_format_gently to use strbuf
578  - setup.c: detect $GIT_COMMON_DIR in is_git_directory()
579  - setup.c: convert is_git_directory() to use strbuf
580  - git-stash: avoid hardcoding $GIT_DIR/logs/....
581  - *.sh: avoid hardcoding $GIT_DIR/hooks/...
582  - git-sh-setup.sh: use rev-parse --git-path to get $GIT_DIR/objects
583  - $GIT_COMMON_DIR: a new environment variable
584  - commit: use SEQ_DIR instead of hardcoding "sequencer"
585  - fast-import: use git_path() for accessing .git dir instead of get_git_dir()
586  - reflog: avoid constructing .lock path with git_path
587  - *.sh: respect $GIT_INDEX_FILE
588  - git_path(): be aware of file relocation in $GIT_DIR
589  - path.c: group git_path(), git_pathdup() and strbuf_git_path() together
590  - path.c: rename vsnpath() to do_git_path()
591  - git_snpath(): retire and replace with strbuf_git_path()
592  - path.c: make get_pathname() call sites return const char *
593  - path.c: make get_pathname() return strbuf instead of static buffer
595  A replacement for contrib/workdir/git-new-workdir that does not
596  rely on symbolic links and make sharing of objects and refs safer
597  by making the borrowee and borrowers aware of each other.
600 * ks/tree-diff-nway (2014-03-20) 19 commits
601  - combine-diff: speed it up, by using multiparent diff tree-walker directly
602  - tree-diff: rework diff_tree() to generate diffs for multiparent cases as well
603  - Portable alloca for Git
604  - tree-diff: reuse base str(buf) memory on sub-tree recursion
605  - tree-diff: no need to call "full" diff_tree_sha1 from show_path()
606  - tree-diff: rework diff_tree interface to be sha1 based
607  - tree-diff: diff_tree() should now be static
608  - tree-diff: remove special-case diff-emitting code for empty-tree cases
609   (merged to 'next' on 2014-03-25 at cfcbdac)
610  + tree-diff: simplify tree_entry_pathcmp
611  + tree-diff: show_path prototype is not needed anymore
612  + tree-diff: rename compare_tree_entry -> tree_entry_pathcmp
613  + tree-diff: move all action-taking code out of compare_tree_entry()
614  + tree-diff: don't assume compare_tree_entry() returns -1,0,1
615   (merged to 'next' on 2014-03-21 at d872679)
616  + tree-diff: consolidate code for emitting diffs and recursion in one place
617  + tree-diff: show_tree() is not needed
618  + tree-diff: no need to pass match to skip_uninteresting()
619  + tree-diff: no need to manually verify that there is no mode change for a path
620  + combine-diff: move changed-paths scanning logic into its own function
621  + combine-diff: move show_log_first logic/action out of paths scanning
623  Instead of running N pair-wise diff-trees when inspecting a
624  N-parent merge, find the set of paths that were touched by walking
625  N+1 trees in parallel.  These set of paths can then be turned into
626  N pair-wise diff-tree results to be processed through rename
627  detections and such.  And N=2 case nicely degenerates to the usual
628  2-way diff-tree, which is very nice.
631 * nd/log-show-linear-break (2014-03-20) 2 commits
632  - log: add --show-linear-break to help see non-linear history
633  - object.h: centralize object flag allocation
635  Attempts to show where a single-strand-of-pearls break in "git log"
636  output.
638  The implementation seems to have got worse compared to the previous
639  round.  Will hold.
642 * cc/interpret-trailers (2014-03-07) 11 commits
643  - Documentation: add documentation for 'git interpret-trailers'
644  - trailer: add tests for commands in config file
645  - trailer: execute command from 'trailer.<name>.command'
646  - trailer: add tests for "git interpret-trailers"
647  - trailer: add interpret-trailers command
648  - trailer: put all the processing together and print
649  - trailer: parse trailers from stdin
650  - trailer: process command line trailer arguments
651  - trailer: read and process config information
652  - trailer: process trailers from stdin and arguments
653  - trailers: add data structures and basic functions
655  A new filter to programatically edit the tail end of the commit log
656  messages.
658  Will merge to 'next'.
660 --------------------------------------------------
661 [Discarded]
663 * jk/diff-funcname-cpp-regex (2014-03-05) 1 commit
664  . diff: simplify cpp funcname regex
666  Superceded.
669 * pw/branch-config-message (2014-03-13) 1 commit
670  . install_branch_config(): simplify verbose messages logic
672  Among the many attempts to microproject #8, this seemed to be the
673  most "done" among the table based ones; I however tend to think
674  that the original with minimum refactoring would be easier to read.
676  an/branch-config-message supersedes this topic.