What's cooking (2014/07 #02)
[alt-git.git] / whats-cooking.txt
blob6c1598e4f85877fef3e82089fea4f00619c2526a
1 To: git@vger.kernel.org
2 Bcc: lwn@lwn.net
3 Subject: What's cooking in git.git (Jul 2014, #02; Mon, 14)
4 X-master-at: 66f467c3e6aa9c1e28eaf7b71cea5e452fc104e8
5 X-next-at: a2efa2fd3a2243dea76a6988cbda3d2f4acf3381
7 What's cooking in git.git (Jul 2014, #02; Mon, 14)
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 We would need to start slowing down to prepare for -rc0 preview at
15 the end of next week and then feature freeze.  Some topics that
16 joined 'next' late may want to stay there for the remainder of this
17 cycle.
19 You can find the changes described here in the integration branches
20 of the repositories listed at
22     http://git-blame.blogspot.com/p/git-public-repositories.html
24 --------------------------------------------------
25 [New Topics]
27 * jk/skip-prefix (2014-07-10) 1 commit
28   (merged to 'next' on 2014-07-14 at 0fbd06e)
29  + tag: use skip_prefix instead of magic numbers
30  (this branch is used by jk/tag-sort.)
32  Will merge to 'master'.
34  One more to an already graduated topic.
37 * rs/code-cleaning (2014-07-10) 5 commits
38   (merged to 'next' on 2014-07-14 at d5a89c8)
39  + fsck: simplify fsck_commit_buffer() by using commit_list_count()
40  + commit: use commit_list_append() instead of duplicating its code
41  + merge: simplify merge_trivial() by using commit_list_append()
42  + use strbuf_addch for adding single characters
43  + use strbuf_addbuf for adding strbufs
45  Will merge to 'master'.
48 * ah/fix-http-push (2014-07-13) 1 commit
49   (merged to 'next' on 2014-07-14 at 5d06516)
50  + http-push.c: make CURLOPT_IOCTLDATA a usable pointer
52  An ancient rewrite passed a wrong pointer to a curl library
53  function in a rarely used code path.
55  Will merge to 'master'.
58 * jc/reopen-lock-file (2014-07-14) 1 commit
59  - lockfile: allow reopening a closed but still locked file
60  (this branch uses nd/split-index.)
62  Needed in the "commit -p" code path to update the cache tree in the
63  index.
66 * jk/alloc-commit-id (2014-07-13) 8 commits
67  - diff-tree: avoid lookup_unknown_object
68  - object_as_type: set commit index
69  - alloc: factor out commit index
70  - add object_as_type helper for casting objects
71  - parse_object_buffer: do not set object type
72  - move setting of object->type to alloc_* functions
73  - alloc: write out allocator definitions
74  - alloc.c: remove the alloc_raw_commit_node() function
76  Make sure all in-core commit objects are assigned a unique number
77  so that they can be annotated using the commit-slab API.
79  Will merge to 'next'.
82 * jk/remote-curl-squelch-extra-errors (2014-07-10) 3 commits
83   (merged to 'next' on 2014-07-14 at a2efa2f)
84  + remote-curl: mark helper-protocol errors more clearly
85  + remote-curl: use error instead of fprintf(stderr)
86  + remote-curl: do not complain on EOF from parent git
88  Will merge to 'master'.
91 * rs/ref-transaction-0 (2014-07-14) 19 commits
92   (merged to 'next' on 2014-07-14 at b21bcee)
93  + refs.c: change ref_transaction_update() to do error checking and return status
94  + refs.c: remove the onerr argument to ref_transaction_commit
95  + update-ref: use err argument to get error from ref_transaction_commit
96  + refs.c: make update_ref_write update a strbuf on failure
97  + refs.c: make ref_update_reject_duplicates take a strbuf argument for errors
98  + refs.c: log_ref_write should try to return meaningful errno
99  + refs.c: make resolve_ref_unsafe set errno to something meaningful on error
100  + refs.c: commit_packed_refs to return a meaningful errno on failure
101  + refs.c: make remove_empty_directories always set errno to something sane
102  + refs.c: verify_lock should set errno to something meaningful
103  + refs.c: make sure log_ref_setup returns a meaningful errno
104  + refs.c: add an err argument to repack_without_refs
105  + lockfile.c: make lock_file return a meaningful errno on failurei
106  + lockfile.c: add a new public function unable_to_lock_message
107  + refs.c: add a strbuf argument to ref_transaction_commit for error logging
108  + refs.c: allow passing NULL to ref_transaction_free
109  + refs.c: constify the sha arguments for ref_transaction_create|delete|update
110  + refs.c: ref_transaction_commit should not free the transaction
111  + refs.c: remove ref_transaction_rollback
112  (this branch is used by rs/ref-transaction.)
114  Early part of Ronnie's "ref transaction" topic.
115  Portability workaround may be needed on top ($gmane/252496).
117 --------------------------------------------------
118 [Graduated to "master"]
120 * jk/skip-prefix (2014-06-20) 18 commits
121  (merged to 'next' on 2014-06-23 at cd387a6)
122  + http-push: refactor parsing of remote object names
123  + imap-send: use skip_prefix instead of using magic numbers
124  + use skip_prefix to avoid repeated calculations
125  + git: avoid magic number with skip_prefix
126  + fetch-pack: refactor parsing in get_ack
127  + fast-import: refactor parsing of spaces
128  + stat_opt: check extra strlen call
129  + daemon: use skip_prefix to avoid magic numbers
130  + fast-import: use skip_prefix for parsing input
131  + use skip_prefix to avoid repeating strings
132  + use skip_prefix to avoid magic numbers
133  + transport-helper: avoid reading past end-of-string
134  + fast-import: fix read of uninitialized argv memory
135  + apply: use skip_prefix instead of raw addition
136  + refactor skip_prefix to return a boolean
137  + avoid using skip_prefix as a boolean
138  + daemon: mark some strings as const
139  + parse_diff_color_slot: drop ofs parameter
142 * kb/path-max-must-go (2014-07-13) 1 commit
143   (merged to 'next' on 2014-07-14 at b0b9834)
144  + cache.h: rename cache_def_free to cache_def_clear
147 * dt/refs-check-refname-component-sse-fix (2014-07-08) 2 commits
148   (merged to 'next' on 2014-07-08 at 35b839c)
149  + refs: fix valgrind suppression file
150  + refs.c: handle REFNAME_REFSPEC_PATTERN at end of page
152  Fixes to a topic that is already in 'master'.
155 * jc/fix-clone-single-starting-at-a-tag (2014-06-23) 1 commit
156   (merged to 'next' on 2014-07-02 at cc0c4b1)
157  + builtin/clone.c: detect a clone starting at a tag correctly
159  "git clone -b brefs/tags/bar" would have mistakenly thought we were
160  following a single tag, even though it was a name of the branch,
161  because it incorrectly used strstr().
164 * jk/pretty-G-format-fixes (2014-06-25) 6 commits
165   (merged to 'next' on 2014-06-26 at 7138407)
166  + move "%G" format test from t7510 to t6006
167   (merged to 'next' on 2014-06-20 at f504bbc)
168  + pretty: avoid reading past end-of-string with "%G"
169  + t7510: check %G* pretty-format output
170  + t7510: test a commit signed by an unknown key
171  + t7510: use consistent &&-chains in loop
172  + t7510: stop referring to master in later tests
174  "%G" (nothing after G) is an invalid pretty format specifier, but
175  the parser did not notice it as garbage.
178 * jk/xstrfmt (2014-06-25) 11 commits
179   (merged to 'next' on 2014-06-25 at 5031d4e)
180  + setup_git_env(): introduce git_path_from_env() helper
181   (merged to 'next' on 2014-06-23 at 64f2558)
182  + unique_path: fix unlikely heap overflow
183  + walker_fetch: fix minor memory leak
184  + merge: use argv_array when spawning merge strategy
185  + sequencer: use argv_array_pushf
186  + setup_git_env: use git_pathdup instead of xmalloc + sprintf
187  + use xstrfmt to replace xmalloc + strcpy/strcat
188  + use xstrfmt to replace xmalloc + sprintf
189  + use xstrdup instead of xmalloc + strcpy
190  + use xstrfmt in favor of manual size calculations
191  + strbuf: add xstrfmt helper
194 * mg/verify-commit (2014-06-23) 5 commits
195   (merged to 'next' on 2014-07-02 at 6d77bcf)
196  + t7510: test verify-commit
197  + t7510: exit for loop with test result
198  + verify-commit: scriptable commit signature verification
199  + gpg-interface: provide access to the payload
200  + gpg-interface: provide clear helper for struct signature_check
202  Add 'verify-commit' to be used in a way similar to 'verify-tag' is
203  used.  Further work on verifying the mergetags might be needed.
206 * rs/fix-alt-odb-path-comparison (2014-07-01) 1 commit
207   (merged to 'next' on 2014-07-08 at f9c69e5)
208  + sha1_file: avoid overrunning alternate object base string
211 * rs/simplify-archive-tests (2014-07-07) 1 commit
212   (merged to 'next' on 2014-07-08 at c46cfac)
213  + t5000, t5003: simplify commit
216 * rs/status-code-clean-up (2014-06-29) 2 commits
217   (merged to 'next' on 2014-07-08 at db67965)
218  + wt-status: simplify building of summary limit argument
219  + wt-status: use argv_array for environment
222 * sk/mingw-dirent (2014-06-09) 5 commits
223   (merged to 'next' on 2014-06-30 at ae9e2d6)
224  + Win32 dirent: improve dirent implementation
225  + Win32 dirent: clarify #include directives
226  + Win32 dirent: change FILENAME_MAX to MAX_PATH
227  + Win32 dirent: remove unused dirent.d_reclen member
228  + Win32 dirent: remove unused dirent.d_ino member
231 * sk/mingw-main (2014-06-10) 2 commits
232   (merged to 'next' on 2014-06-30 at 447cb50)
233  + mingw: avoid const warning
234  + Win32: move main macro to a function
235  (this branch is used by sk/mingw-uni-console and sk/mingw-unicode-spawn-args.)
238 * sk/mingw-uni-console (2014-06-16) 7 commits
239   (merged to 'next' on 2014-06-30 at f4fbc41)
240  + Win32: reliably detect console pipe handles
241  + Win32: fix broken pipe detection
242  + Win32: Thread-safe windows console output
243  + Win32: add Unicode conversion functions
244  + Win32: warn if the console font doesn't support Unicode
245  + Win32: detect console streams more reliably
246  + Win32: support Unicode console output
247  (this branch is used by sk/mingw-unicode-spawn-args; uses sk/mingw-main.)
250 * sk/mingw-unicode-spawn-args (2014-06-16) 6 commits
251   (merged to 'next' on 2014-06-30 at c8f79d0)
252  + Win32: Unicode arguments (incoming)
253  + Win32: Unicode arguments (outgoing)
254  + MinGW: disable CRT command line globbing
255  + Win32: fix potential multi-threading issue
256  + Win32: simplify internal mingw_spawn* APIs
257  + Win32: let mingw_execve() return an int
258  (this branch uses sk/mingw-main and sk/mingw-uni-console.)
260 --------------------------------------------------
261 [Stalled]
263 * ab/add-interactive-show-diff-func-name (2014-05-12) 2 commits
264  - SQUASH??? git-add--interactive: Preserve diff heading when splitting hunks
265  - git-add--interactive: Preserve diff heading when splitting hunks
267  Waiting for a reroll.
270 * jn/gitweb-utf8-in-links (2014-05-27) 1 commit
271  - gitweb: Harden UTF-8 handling in generated links
273  $gmane/250758?
276 * rh/prompt-tests (2014-06-05) 11 commits
277  - t9904: new __git_ps1 tests for Zsh
278  - test-lib: make it possible to override how test code is eval'd
279  - lib-prompt-tests.sh: add variable for string that encodes percent in PS1
280  - lib-prompt-tests.sh: put all tests inside a function
281  - t9903: move prompt tests to a new lib-prompt-tests.sh file
282  - t9903: move PS1 color code variable definitions to lib-bash.sh
283  - t9903: include "Bash" in test names via new $shellname var
284  - t9903: run pc mode tests again with PS1 expansion disabled
285  - t9903: move test name prefix to a separate variable
286  - t9903: put the Bash pc mode prompt test cases in a function
287  - t9903: remove Zsh test from the suite of Bash prompt tests
289  Expecting a reroll to limit the damage to test_eval_; also reported
290  to be broken with older zsh that are still in the field ($gmane/251231).
293 * ss/userdiff-update-csharp-java (2014-06-02) 2 commits
294  - userdiff: support Java try keyword
295  - userdiff: support C# async methods and correct C# keywords
297  Reviews sent; waiting for a response.
300 * cc/interpret-trailers (2014-05-28) 11 commits
301  - Documentation: add documentation for 'git interpret-trailers'
302  - trailer: add tests for commands in config file
303  - trailer: execute command from 'trailer.<name>.command'
304  - trailer: add tests for "git interpret-trailers"
305  - trailer: add interpret-trailers command
306  - trailer: put all the processing together and print
307  - trailer: parse trailers from file or stdin
308  - trailer: process command line trailer arguments
309  - trailer: read and process config information
310  - trailer: process trailers from input message and arguments
311  - trailer: add data structures and basic functions
313  A new filter to programatically edit the tail end of the commit log
314  messages.
316  What is the status of this one?  I think I saw reviews by Michael
317  but after that I do not recall seeing any updates.
320 * mh/lockfile (2014-04-15) 25 commits
321  . trim_last_path_elm(): replace last_path_elm()
322  . resolve_symlink(): take a strbuf parameter
323  . resolve_symlink(): use a strbuf for internal scratch space
324  . change lock_file::filename into a strbuf
325  . commit_lock_file(): use a strbuf to manage temporary space
326  . try_merge_strategy(): use a statically-allocated lock_file object
327  . try_merge_strategy(): remove redundant lock_file allocation
328  . struct lock_file: declare some fields volatile
329  . lockfile: avoid transitory invalid states
330  . commit_lock_file(): die() if called for unlocked lockfile object
331  . commit_lock_file(): inline temporary variable
332  . remove_lock_file(): call rollback_lock_file()
333  . lock_file(): exit early if lockfile cannot be opened
334  . write_packed_entry_fn(): convert cb_data into a (const int *)
335  . prepare_index(): declare return value to be (const char *)
336  . delete_ref_loose(): don't muck around in the lock_file's filename
337  . cache.h: define constants LOCK_SUFFIX and LOCK_SUFFIX_LEN
338  . lockfile.c: document the various states of lock_file objects
339  . lock_file(): always add lock_file object to lock_file_list
340  . hold_lock_file_for_append(): release lock on errors
341  . lockfile: unlock file if lockfile permissions cannot be adjusted
342  . rollback_lock_file(): set fd to -1
343  . rollback_lock_file(): do not clear filename redundantly
344  . api-lockfile: expand the documentation
345  . unable_to_lock_die(): rename function from unable_to_lock_index_die()
347  Ejected from 'pu' to unclutter.
348  Expecting a reroll.
351 * bg/rebase-off-of-previous-branch (2014-04-16) 1 commit
352  - git-rebase: print name of rev when using shorthand
354  Teach "git rebase -" to report the concrete name of the branch
355  (i.e. the previous one).
357  But it stops short and does not do the same for "git rebase @{-1}".
358  Expecting a reroll.
361 * tr/merge-recursive-index-only (2014-02-05) 3 commits
362  - merge-recursive: -Xindex-only to leave worktree unchanged
363  - merge-recursive: internal flag to avoid touching the worktree
364  - merge-recursive: remove dead conditional in update_stages()
365  (this branch is used by tr/remerge-diff.)
368 * tr/remerge-diff (2014-02-26) 5 commits
369  . log --remerge-diff: show what the conflict resolution changed
370  . name-hash: allow dir hashing even when !ignore_case
371  . merge-recursive: allow storing conflict hunks in index
372  . revision: fold all merge diff variants into an enum merge_diff_mode
373  . combine-diff: do not pass revs->dense_combined_merges redundantly
374  (this branch uses tr/merge-recursive-index-only.)
376  "log -p" output learns a new way to let users inspect a merge
377  commit by showing the differences between the automerged result
378  with conflicts the person who recorded the merge would have seen
379  and the final conflict resolution that was recorded in the merge.
381  Needs to be rebased, now kb/fast-hashmap topic is in.
384 * jk/makefile (2014-02-05) 16 commits
385  . FIXUP
386  . move LESS/LV pager environment to Makefile
387  . Makefile: teach scripts to include make variables
388  . FIXUP
389  . Makefile: auto-build C strings from make variables
390  . Makefile: drop *_SQ variables
391  . FIXUP
392  . Makefile: add c-quote helper function
393  . Makefile: introduce sq function for shell-quoting
394  . Makefile: always create files via make-var
395  . Makefile: store GIT-* sentinel files in MAKE/
396  . Makefile: prefer printf to echo for GIT-*
397  . Makefile: use tempfile/mv strategy for GIT-*
398  . Makefile: introduce make-var helper function
399  . Makefile: fix git-instaweb dependency on gitweb
400  . Makefile: drop USE_GETTEXT_SCHEME from GIT-CFLAGS
402  Simplify the Makefile rules and macros that exist primarily for
403  quoting purposes, and make it easier to robustly express the
404  dependency rules.
406  Expecting a reroll.
409 * po/everyday-doc (2014-01-27) 1 commit
410  - Make 'git help everyday' work
412  This may make the said command to emit something, but the source is
413  not meant to be formatted into a manual pages to begin with, and
414  also its contents are a bit stale.  It may be a good first step in
415  the right direction, but needs more work to at least get the
416  mark-up right before public consumption.
418  Will hold.
421 * rb/merge-prepare-commit-msg-hook (2014-01-10) 4 commits
422  - merge: drop unused arg from abort_commit method signature
423  - merge: make prepare_to_commit responsible for write_merge_state
424  - t7505: ensure cleanup after hook blocks merge
425  - t7505: add missing &&
427  Expose more merge states (e.g. $GIT_DIR/MERGE_MODE) to hooks that
428  run during "git merge".  The log message stresses too much on one
429  hook, prepare-commit-msg, but it would equally apply to other hooks
430  like post-merge, I think.
432  Waiting for a reroll.
435 * jc/graph-post-root-gap (2013-12-30) 3 commits
436  - WIP: document what we want at the end
437  - graph: remove unused code a bit
438  - graph: stuff the current commit into graph->columns[]
440  This was primarily a RFH ($gmane/239580).
443 * tg/perf-lib-test-perf-cleanup (2013-09-19) 2 commits
444  - perf-lib: add test_perf_cleanup target
445  - perf-lib: split starting the test from the execution
447  Add test_perf_cleanup shell function to the perf suite, that allows
448  the script writers to define a test with a clean-up action.
450  Will hold.
453 * jc/show-branch (2014-03-24) 5 commits
454  - show-branch: use commit slab to represent bitflags of arbitrary width
455  - show-branch.c: remove "all_mask"
456  - show-branch.c: abstract out "flags" operation
457  - show-branch.c: lift all_mask/all_revs to a global static
458  - show-branch.c: update comment style
460  Waiting for the final step to lift the hard-limit before sending it out.
463 * jh/submodule-tests (2014-04-17) 1 commit
464  - t7410: 210 tests for various 'git submodule update' scenarios
466  More or less abandoned.  Will drop.
468 --------------------------------------------------
469 [Cooking]
471 * nd/multiple-work-trees (2014-07-14) 31 commits
472  - checkout: don't require a work tree when checking out into a new one
473  - git_path(): keep "info/sparse-checkout" per work-tree
474  - count-objects: report unused files in $GIT_DIR/repos/...
475  - gc: support prune --repos
476  - gc: factor out gc.pruneexpire parsing code
477  - gc: style change -- no SP before closing parenthesis
478  - prune: strategies for linked checkouts
479  - checkout: detach if the branch is already checked out elsewhere
480  - checkout: clean up half-prepared directories in --to mode
481  - checkout: support checking out into a new working directory
482  - use new wrapper write_file() for simple file writing
483  - wrapper.c: wrapper to open a file, fprintf then close
484  - setup.c: support multi-checkout repo setup
485  - setup.c: detect $GIT_COMMON_DIR check_repository_format_gently()
486  - setup.c: convert check_repository_format_gently to use strbuf
487  - setup.c: detect $GIT_COMMON_DIR in is_git_directory()
488  - setup.c: convert is_git_directory() to use strbuf
489  - git-stash: avoid hardcoding $GIT_DIR/logs/....
490  - *.sh: avoid hardcoding $GIT_DIR/hooks/...
491  - git-sh-setup.sh: use rev-parse --git-path to get $GIT_DIR/objects
492  - $GIT_COMMON_DIR: a new environment variable
493  - commit: use SEQ_DIR instead of hardcoding "sequencer"
494  - fast-import: use git_path() for accessing .git dir instead of get_git_dir()
495  - reflog: avoid constructing .lock path with git_path
496  - *.sh: respect $GIT_INDEX_FILE
497  - git_path(): be aware of file relocation in $GIT_DIR
498  - path.c: group git_path(), git_pathdup() and strbuf_git_path() together
499  - path.c: rename vsnpath() to do_git_path()
500  - git_snpath(): retire and replace with strbuf_git_path()
501  - path.c: make get_pathname() call sites return const char *
502  - path.c: make get_pathname() return strbuf instead of static buffer
504  A replacement for contrib/workdir/git-new-workdir that does not
505  rely on symbolic links and make sharing of objects and refs safer
506  by making the borrowee and borrowers aware of each other.
508  Rerolled.
511 * cc/replace-edit (2014-06-25) 3 commits
512   (merged to 'next' on 2014-07-10 at 097cd5e)
513  + replace: use argv_array in export_object
514  + avoid double close of descriptors handed to run_command
515  + replace: replace spaces with tabs in indentation
516  (this branch is used by jk/replace-edit-raw.)
518  Teach "git replace" an "--edit" mode.
520  Will merge to 'master'.
523 * jk/replace-edit-raw (2014-06-25) 1 commit
524   (merged to 'next' on 2014-07-10 at b934bb0)
525  + replace: add a --raw mode for --edit
526  (this branch uses cc/replace-edit.)
528  Teach "git replace --edit" mode a "--raw" option to allow
529  editing the bare-metal representation data of objects.
531  Will merge to 'master'.
534 * ep/submodule-code-cleanup (2014-06-30) 1 commit
535   (merged to 'next' on 2014-07-10 at d4de30a)
536  + submodule.c: use the ARRAY_SIZE macro
538  Will merge to 'master'.
541 * jk/strip-suffix (2014-06-30) 9 commits
542   (merged to 'next' on 2014-07-10 at e6cfa29)
543  + prepare_packed_git_one: refactor duplicate-pack check
544  + verify-pack: use strbuf_strip_suffix
545  + strbuf: implement strbuf_strip_suffix
546  + index-pack: use strip_suffix to avoid magic numbers
547  + use strip_suffix instead of ends_with in simple cases
548  + replace has_extension with ends_with
549  + implement ends_with via strip_suffix
550  + add strip_suffix function
551  + sha1_file: replace PATH_MAX buffer with strbuf in prepare_packed_git_one()
553  Will merge to 'master'.
556 * jk/tag-contains (2014-06-30) 8 commits
557  - perf: add tests for tag --contains
558  - tag: use commit_contains
559  - commit: provide a fast multi-tip contains function
560  - string-list: add pos to iterator callback
561  - add functions for memory-efficient bitmaps
562  - paint_down_to_common: use prio_queue
563  - tag: factor out decision to stream tags
564  - tag: allow --sort with -n
566  Expecting a reroll.
569 * mg/fix-log-mergetag-color (2014-07-10) 1 commit
570   (merged to 'next' on 2014-07-14 at e90dba1)
571  + log: correctly identify mergetag signature verification status
573  Will merge to 'master'.
576 * mk/merge-incomplete-files (2014-06-30) 2 commits
577   (merged to 'next' on 2014-07-10 at d1115f4)
578  + git-merge-file: do not add LF at EOF while applying unrelated change
579  + t6023-merge-file.sh: fix and mark as broken invalid tests
581  Will merge to 'master'.
584 * tb/crlf-tests (2014-07-08) 2 commits
585   (merged to 'next' on 2014-07-08 at 40764b7)
586  + t0027: combinations of core.autocrlf, core.eol and text
587  + t0025: rename the test files
589  Will merge to 'master'.
592 * ak/profile-feedback-build (2014-07-08) 4 commits
593   (merged to 'next' on 2014-07-14 at c40e86e)
594  + Fix profile feedback with -jN and add profile-fast
595  + Run the perf test suite for profile feedback too
596  + Don't define away __attribute__ on gcc
597  + Use BASIC_FLAGS for profile feedback
599  Will merge to 'master'.
602 * cb/filter-branch-prune-empty-degenerate-merges (2014-07-01) 1 commit
603   (merged to 'next' on 2014-07-10 at 860cfea)
604  + filter-branch: eliminate duplicate mapped parents
606  Will merge to 'master'.
609 * cc/for-each-mergetag (2014-07-07) 1 commit
610  - commit: add for_each_mergetag()
611  (this branch is used by cc/replace-graft.)
613  Will merge to 'next'.
616 * dt/cache-tree-repair (2014-07-14) 4 commits
617  - cache-tree: Write updated cache-tree after commit
618  - cache-tree: subdirectory tests
619  - test-dump-cache-tree: invalid trees are not errors
620  - cache-tree: create/update cache-tree on checkout
622  Add a few more places in "commit" and "checkout" that make sure
623  that the cache-tree is fully populated in the index.
625  Will merge to 'next'.
628 * jl/test-lint-scripts (2014-07-10) 2 commits
629   (merged to 'next' on 2014-07-14 at c03721c)
630  + t/Makefile: always test all lint targets when running tests
631  + t/Makefile: check helper scripts for non-portable shell commands too
633  Will merge to 'master'.
636 * kb/hashmap-updates (2014-07-07) 4 commits
637  - hashmap: add string interning API
638  - hashmap: add simplified hashmap_get_from_hash() API
639  - hashmap: improve struct hashmap member documentation
640  - hashmap: factor out getting a hash code from a SHA1
642  Expecting a reroll ($gmane/252973 and possibly $gmane/252976).
646 * zk/log-graph-showsig (2014-07-09) 1 commit
647   (merged to 'next' on 2014-07-14 at 4429c2e)
648  + log: fix indentation for --graph --show-signature
650  The "--show-signature" option did not pay much attention to
651  "--graph".
653  Will merge to 'master'.
656 * cc/replace-graft (2014-07-07) 9 commits
657  - replace: add test for --graft with a mergetag
658  - replace: check mergetags when using --graft
659  - replace: add test for --graft with signed commit
660  - replace: remove signature when using --graft
661  - contrib: add convert-grafts-to-replace-refs.sh
662  - Documentation: replace: add --graft option
663  - replace: add test for --graft
664  - replace: add --graft option
665  - replace: cleanup redirection style in tests
666  (this branch uses cc/for-each-mergetag.)
668  "git replace" learned a "--graft" option to rewrite parents of a
669  commit.
672 * kb/perf-trace (2014-07-13) 17 commits
673  - api-trace.txt: add trace API documentation
674  - progress: simplify performance measurement by using getnanotime()
675  - wt-status: simplify performance measurement by using getnanotime()
676  - git: add performance tracing for git's main() function to debug scripts
677  - trace: add trace_performance facility to debug performance issues
678  - trace: add high resolution timer function to debug performance issues
679  - trace: add 'file:line' to all trace output
680  - trace: move code around, in preparation to file:line output
681  - trace: add current timestamp to all trace output
682  - trace: disable additional trace output for unit tests
683  - trace: add infrastructure to augment trace output with additional info
684  - sha1_file: change GIT_TRACE_PACK_ACCESS logging to use trace API
685  - Documentation/git.txt: improve documentation of 'GIT_TRACE*' variables
686  - trace: improve trace performance
687  - trace: remove redundant printf format attribute
688  - trace: consistently name the format parameter
689  - trace: move trace declarations from cache.h to new trace.h
691  Will merge to 'next'.
694 * hv/submodule-config (2014-06-30) 4 commits
695  - do not die on error of parsing fetchrecursesubmodules option
696  - use new config API for worktree configurations of submodules
697  - extract functions for submodule config set and lookup
698  - implement submodule config cache for lookup of submodule names
701 * jl/submodule-tests (2014-07-14) 14 commits
702   (merged to 'next' on 2014-07-14 at 0c750bb)
703  + revert: add t3513 for submodule updates
704  + stash: add t3906 for submodule updates
705  + am: add t4255 for submodule updates
706  + cherry-pick: add t3512 for submodule updates
707  + pull: add t5572 for submodule updates
708  + rebase: add t3426 for submodule updates
709  + merge: add t7613 for submodule updates
710  + bisect: add t6041 for submodule updates
711  + reset: add t7112 for submodule updates
712  + read-tree: add t1013 for submodule updates
713  + apply: add t4137 for submodule updates
714  + checkout: call the new submodule update test framework
715  + submodules: add the lib-submodule-update.sh test library
716  + test-lib: add test_dir_is_empty()
718  Will merge to 'master'.
721 * po/error-message-style (2014-07-10) 1 commit
722   (merged to 'next' on 2014-07-14 at ed17678)
723  + doc: give some guidelines for error messages
725  Will merge to 'master'.
728 * rs/ref-transaction (2014-07-14) 29 commits
729  - refs.c: make write_ref_sha1 static
730  - fetch.c: change s_update_ref to use a ref transaction
731  - refs.c: propagate any errno==ENOTDIR from _commit back to the callers
732  - refs.c: pass a skip list to name_conflict_fn
733  - refs.c: call lock_ref_sha1_basic directly from commit
734  - refs.c: move the check for valid refname to lock_ref_sha1_basic
735  - refs.c: pass NULL as *flags to read_ref_full
736  - refs.c: pass the ref log message to _create/delete/update instead of _commit
737  - refs.c: add an err argument to delete_ref_loose
738  - refs.c: make delete_ref use a transaction
739  - refs.c: make prune_ref use a transaction to delete the ref
740  - refs.c: remove lock_ref_sha1
741  - refs.c: remove the update_ref_write function
742  - refs.c: remove the update_ref_lock function
743  - refs.c: make lock_ref_sha1 static
744  - walker.c: use ref transaction for ref updates
745  - fast-import.c: use a ref transaction when dumping tags
746  - receive-pack.c: use a reference transaction for updating the refs
747  - refs.c: change update_ref to use a transaction
748  - branch.c: use ref transaction for all ref updates
749  - fast-import.c: change update_branch to use ref transactions
750  - sequencer.c: use ref transactions for all ref updates
751  - commit.c: use ref transactions for updates
752  - replace.c: use the ref transaction functions for updates
753  - tag.c: use ref transactions when doing updates
754  - refs.c: add transaction.status and track OPEN/CLOSED/ERROR
755  - refs.c: make ref_transaction_begin take an err argument
756  - refs.c: update ref_transaction_delete to check for error and return status
757  - refs.c: change ref_transaction_create to do error checking and return status
758  (this branch uses rs/ref-transaction-0.)
762 * nd/split-index (2014-06-13) 32 commits
763   (merged to 'next' on 2014-07-08 at 49325ef)
764  + t1700: new tests for split-index mode
765  + t2104: make sure split index mode is off for the version test
766  + read-cache: force split index mode with GIT_TEST_SPLIT_INDEX
767  + read-tree: note about dropping split-index mode or index version
768  + read-tree: force split-index mode off on --index-output
769  + rev-parse: add --shared-index-path to get shared index path
770  + update-index --split-index: do not split if $GIT_DIR is read only
771  + update-index: new options to enable/disable split index mode
772  + split-index: strip pathname of on-disk replaced entries
773  + split-index: do not invalidate cache-tree at read time
774  + split-index: the reading part
775  + split-index: the writing part
776  + read-cache: mark updated entries for split index
777  + read-cache: save deleted entries in split index
778  + read-cache: mark new entries for split index
779  + read-cache: split-index mode
780  + read-cache: save index SHA-1 after reading
781  + entry.c: update cache_changed if refresh_cache is set in checkout_entry()
782  + cache-tree: mark istate->cache_changed on prime_cache_tree()
783  + cache-tree: mark istate->cache_changed on cache tree update
784  + cache-tree: mark istate->cache_changed on cache tree invalidation
785  + unpack-trees: be specific what part of the index has changed
786  + resolve-undo: be specific what part of the index has changed
787  + update-index: be specific what part of the index has changed
788  + read-cache: be specific what part of the index has changed
789  + read-cache: be strict about "changed" in remove_marked_cache_entries()
790  + read-cache: store in-memory flags in the first 12 bits of ce_flags
791  + read-cache: relocate and unexport commit_locked_index()
792  + read-cache: new API write_locked_index instead of write_index/write_cache
793  + sequencer: do not update/refresh index if the lock cannot be held
794  + ewah: delete unused ewah_read_mmap_native declaration
795  + ewah: fix constness of ewah_read_mmap
796  (this branch is used by jc/reopen-lock-file.)
798  An experiment to use two files (the base file and incremental
799  changes relative to it) to represent the index to reduce I/O cost
800  of rewriting a large index when only small part of the working tree
801  changes.
803  Will merge to 'master'.
806 * jc/test-lazy-prereq (2014-06-13) 1 commit
807  - tests: drop GIT_*_TIMING_TESTS environment variable support
809  Test-script clean-up.
811  Will hold.
814 * mt/patch-id-stable (2014-06-10) 1 commit
815  - patch-id: change default to stable
817  Teaches "git patch-id" to compute the patch ID that does not change
818  when the files in a single patch is reordered. As this new algorithm
819  is backward incompatible, the last bit to flip it to be the default
820  is left out of 'master' for now.
822  Will hold.