All of lore.kernel.org
 help / color / mirror / Atom feed
* What's cooking in git.git (Jun 2016, #04; Tue, 14)
@ 2016-06-14 22:08 Junio C Hamano
  2016-06-15  2:36 ` Mike Hommey
                   ` (2 more replies)
  0 siblings, 3 replies; 9+ messages in thread
From: Junio C Hamano @ 2016-06-14 22:08 UTC (permalink / raw)
  To: git

Here are the topics that have been cooking.  Commits prefixed with
'-' are only in 'pu' (proposed updates) while commits prefixed with
'+' are in 'next'.  The ones marked with '.' do not appear in any of
the integration branches, but I am still holding onto them.

Git 2.9 has been tagged.  Let's wait for a few days to clean up
possible fallout and then start a new cycle by rewinding the tip of
'next'.  I expect I'd eject a few premature topics out of 'next'
while doing so.

You can find the changes described here in the integration branches
of the repositories listed at

    http://git-blame.blogspot.com/p/git-public-repositories.html

--------------------------------------------------
[Graduated to "master"]

* jc/t2300-setup (2016-06-01) 1 commit
  (merged to 'next' on 2016-06-06 at 20f7f83)
 + t2300: run git-sh-setup in an environment that better mimics the real life
 (this branch is used by va/i18n-even-more.)

 A test fix.


* jk/diff-compact-heuristic (2016-06-10) 1 commit
 - diff: disable compaction heuristic for now

 It turns out that the earlier effort to update the heuristics may
 want to use a bit more time to mature.  Turn it off by default.


* jk/shell-portability (2016-06-01) 2 commits
  (merged to 'next' on 2016-06-06 at 5de784e)
 + t5500 & t7403: lose bash-ism "local"
 + test-lib: add in-shell "env" replacement

 test fixes.

--------------------------------------------------
[New Topics]

* lv/status-say-working-tree-not-directory (2016-06-09) 1 commit
 - Use "working tree" instead of "working directory" for git status

 "git status" used to say "working directory" when it meant "working
 tree".

 Will merge to 'next'.


* jk/parseopt-string-list (2016-06-13) 3 commits
 - blame,shortlog: don't make local option variables static
 - interpret-trailers: don't duplicate option strings
 - parse_opt_string_list: stop allocating new strings
 (this branch is used by jk/string-list-static-init.)

 The command line argument parsing that uses OPT_STRING_LIST() often
 made a copy of the argv[] element, which was unnecessary.

 Will merge to 'next'.


* jk/repack-keep-unreachable (2016-06-14) 3 commits
 - repack: extend --keep-unreachable to loose objects
 - repack: add --keep-unreachable option
 - repack: document --unpack-unreachable option

 "git repack" learned the "--keep-unreachable" option, which sends
 loose unreachable objects to a pack instead of leaving them loose.
 This helps heuristics based on the number of loose objects
 (e.g. "gc --auto").

 Will merge to 'next'.


* lf/recv-sideband-cleanup (2016-06-13) 1 commit
 - sideband.c: refactor recv_sideband()

 Code simplification.  It however loses the atomicity of the output
 9ac13ec9 (atomic write for sideband remote messages, 2006-10-11)
 tried to add to an once-much-simpler codebase.

 Expecting a reroll.


* nd/test-lib-httpd-show-error-log-in-verbose (2016-06-13) 1 commit
 - lib-httpd.sh: print error.log on error

 Debugging aid.

 Will merge to 'next'.


* pc/occurred (2016-06-10) 2 commits
 - config.c: fix misspelt "occurred" in an error message
 - refs.h: fix misspelt "occurred" in a comment

 Will merge to 'next'.


* sb/submodule-clone-retry (2016-06-13) 2 commits
 - submodule update: continue when a clone fails
 - submodule--helper: initial clone learns retry logic
 (this branch uses sb/submodule-recommend-shallowness.)

 "git submodule update" that drives many "git clone" could
 eventually hit flaky servers/network conditions on one of the
 submodules; the command learned to retry the attempt.


* jc/blame-reverse (2016-06-14) 2 commits
 - blame: dwim "blame --reverse OLD" as "blame --reverse OLD.."
 - blame: improve diagnosis for "--reverse NEW"


* jc/deref-tag (2016-06-14) 1 commit
 - blame, line-log: do not loop around deref_tag()

 Code clean-up.

 Will merge to 'next'.


* jk/fetch-prune-doc (2016-06-14) 1 commit
 - fetch: document that pruning happens before fetching

 Will merge to 'next'.


* km/fetch-do-not-free-remote-name (2016-06-14) 1 commit
 - builtin/fetch.c: don't free remote->name after fetch

 Will merge to 'next'.


* nb/gnome-keyring-build (2016-06-14) 1 commit
 - gnome-keyring: Don't hard-code pkg-config executable

 Build improvements for gnome-keyring (in contrib/)

 Will merge to 'next'.


* pb/strbuf-read-file-doc (2016-06-14) 1 commit
 - strbuf: describe the return value of strbuf_read_file

 Will merge to 'next'.

--------------------------------------------------
[Stalled]

* sb/bisect (2016-04-15) 22 commits
 - SQUASH???
 - bisect: get back halfway shortcut
 - bisect: compute best bisection in compute_relevant_weights()
 - bisect: use a bottom-up traversal to find relevant weights
 - bisect: prepare for different algorithms based on find_all
 - bisect: rename count_distance() to compute_weight()
 - bisect: make total number of commits global
 - bisect: introduce distance_direction()
 - bisect: extract get_distance() function from code duplication
 - bisect: use commit instead of commit list as arguments when appropriate
 - bisect: replace clear_distance() by unique markers
 - bisect: use struct node_data array instead of int array
 - bisect: get rid of recursion in count_distance()
 - bisect: make algorithm behavior independent of DEBUG_BISECT
 - bisect: make bisect compile if DEBUG_BISECT is set
 - bisect: plug the biggest memory leak
 - bisect: add test for the bisect algorithm
 - t6030: generalize test to not rely on current implementation
 - t: use test_cmp_rev() where appropriate
 - t/test-lib-functions.sh: generalize test_cmp_rev
 - bisect: allow 'bisect run' if no good commit is known
 - bisect: write about `bisect next` in documentation

 The internal algorithm used in "git bisect" to find the next commit
 to check has been optimized greatly.

 Expecting a reroll.
 ($gmane/291163)


* sg/completion-updates (2016-02-28) 21 commits
 . completion: cache the path to the repository
 . completion: extract repository discovery from __gitdir()
 . completion: don't guard git executions with __gitdir()
 . completion: consolidate silencing errors from git commands
 . completion: don't use __gitdir() for git commands
 . completion: respect 'git -C <path>'
 . completion: fix completion after 'git -C <path>'
 . completion: don't offer commands when 'git --opt' needs an argument
 . rev-parse: add '--absolute-git-dir' option
 . completion: list short refs from a remote given as a URL
 . completion: don't list 'HEAD' when trying refs completion outside of a repo
 . completion: list refs from remote when remote's name matches a directory
 . completion: respect 'git --git-dir=<path>' when listing remote refs
 . completion: fix most spots not respecting 'git --git-dir=<path>'
 . completion: ensure that the repository path given on the command line exists
 . completion tests: add tests for the __git_refs() helper function
 . completion tests: check __gitdir()'s output in the error cases
 . completion tests: consolidate getting path of current working directory
 . completion tests: make the $cur variable local to the test helper functions
 . completion tests: don't add test cruft to the test repository
 . completion: improve __git_refs()'s in-code documentation

 Will be rerolled.
 ($gmane/287839)


* az/p4-bare-no-rebase (2016-02-19) 1 commit
 - git-p4.py: Don't try to rebase on submit from bare repository

 "git p4 submit" attempts to do a rebase, which would fail if done
 in a bare repository.  Not doing this rebase would paper over the
 failure, which is what this patch does, but it is unclear what the
 side effect of not rebasing is.

 Needs a better explanation.


* nd/icase (2016-02-15) 12 commits
 - grep.c: reuse "icase" variable
 - diffcore-pickaxe: support case insensitive match on non-ascii
 - diffcore-pickaxe: "share" regex error handling code
 - grep/pcre: support utf-8
 - gettext: add is_utf8_locale()
 - grep/pcre: prepare locale-dependent tables for icase matching
 - grep/icase: avoid kwsset when -F is specified
 - grep/icase: avoid kwsset on literal non-ascii strings
 - test-regex: expose full regcomp() to the command line
 - test-regex: isolate the bug test code
 - grep: break down an "if" stmt in preparation for next changes
 - grep: allow -F -i combination

 "git grep -i" has been taught to fold case in non-ascii locales.

 Needs review.
 ($gmane/286137)


* ec/annotate-deleted (2015-11-20) 1 commit
 - annotate: skip checking working tree if a revision is provided

 Usability fix for annotate-specific "<file> <rev>" syntax with deleted
 files.

 Waiting for review.


* dg/subtree-rebase-test (2016-01-19) 1 commit
 - contrib/subtree: Add a test for subtree rebase that loses commits

 Reviewed up to v5.
 Will be rerolled.
 ($gmane/284426)


* js/am-3-merge-recursive-direct (2015-10-12) 2 commits
 - am: make a direct call to merge_recursive
 - merge_recursive_options: introduce the "gently" flag

 The merge_recursive_generic() function has been made a bit safer to
 call from inside a process.  "git am -3" was taught to make a direct
 call to the function when falling back to three-way merge.

 Being able to make a direct call would be good in general, but as a
 performance thing, the change needs to be backed up by numbers.

 I haven't gone through the "gently" change with fine toothed comb;
 I can see that the change avoids calling die(), but I haven't made
 sure that the program states (e.g. what's in the in-core index) are
 adjusted sensibly when it returns to the caller instead of dying,
 or the codepaths that used to die() are free of resource leaks.
 The original code certainly did not care the program states at the
 point of dying exactly because it knew it is going to exit, but now
 they have to care, and they need to be audited.

 Will be rerolled.
 ($gmane/292205)


* dk/gc-more-wo-pack (2016-01-13) 4 commits
 - gc: clean garbage .bitmap files from pack dir
 - t5304: ensure non-garbage files are not deleted
 - t5304: test .bitmap garbage files
 - prepare_packed_git(): find more garbage

 Follow-on to dk/gc-idx-wo-pack topic, to clean up stale
 .bitmap and .keep files.

 Waiting for a reroll.
 ($gmane/284368).


* jc/diff-b-m (2015-02-23) 5 commits
 . WIPWIP
 . WIP: diff-b-m
 - diffcore-rename: allow easier debugging
 - diffcore-rename.c: add locate_rename_src()
 - diffcore-break: allow debugging

 "git diff -B -M" produced incorrect patch when the postimage of a
 completely rewritten file is similar to the preimage of a removed
 file; such a resulting file must not be expressed as a rename from
 other place.

 The fix in this patch is broken, unfortunately.
 Will discard.


* jc/merge-impossible-no-commit (2016-04-26) 2 commits
 - merge: warn --no-commit merge when no new commit is created
 - merge: do not contaminate option_commit with --squash

 "git merge --no-commit" silently succeeded when there is no need to
 create any commit, either when you are more recent than the commit
 you tried to merge, or you can fast-forward to the commit you tried
 to merge.  The command gives a warning message in such cases.

 Just tying loose ends in a discussion.  Unless somebody else
 champions this topic, I'll drop it.

 Will discard.

--------------------------------------------------
[Cooking]

* nd/shallow-deepen (2016-06-13) 27 commits
 - fetch, upload-pack: --deepen=N extends shallow boundary by N commits
 - upload-pack: add get_reachable_list()
 - upload-pack: split check_unreachable() in two, prep for get_reachable_list()
 - t5500, t5539: tests for shallow depth excluding a ref
 - clone: define shallow clone boundary with --shallow-exclude
 - fetch: define shallow boundary with --shallow-exclude
 - upload-pack: support define shallow boundary by excluding revisions
 - refs: add expand_ref()
 - t5500, t5539: tests for shallow depth since a specific date
 - clone: define shallow clone boundary based on time with --shallow-since
 - fetch: define shallow boundary with --shallow-since
 - upload-pack: add deepen-since to cut shallow repos based on time
 - shallow.c: implement a generic shallow boundary finder based on rev-list
 - fetch-pack: use a separate flag for fetch in deepening mode
 - fetch-pack.c: mark strings for translating
 - fetch-pack: use a common function for verbose printing
 - fetch-pack: use skip_prefix() instead of starts_with()
 - upload-pack: move rev-list code out of check_non_tip()
 - upload-pack: make check_non_tip() clean things up on error
 - upload-pack: tighten number parsing at "deepen" lines
 - upload-pack: use skip_prefix() instead of starts_with()
 - upload-pack: move "unshallow" sending code out of deepen()
 - upload-pack: remove unused variable "backup"
 - upload-pack: move "shallow" sending code out of deepen()
 - upload-pack: move shallow deepen code out of receive_needs()
 - transport-helper.c: refactor set_helper_option()
 - remote-curl.c: convert fetch_git() to use argv_array

 The existing "git fetch --depth=<n>" option was hard to use
 correctly when making the history of an existing shallow clone
 deeper.  A new option, "--deepen=<n>", has been added to make this
 easier to use.  "git clone" also learned "--shallow-since=<date>"
 and "--shallow-exclude=<tag>" options to make it easier to specify
 "I am interested only in the recent N months worth of history" and
 "Give me only the history since that version".

 Rerolled.


* jk/avoid-unbounded-alloca (2016-06-07) 1 commit
 - tree-diff: avoid alloca for large allocations

 Will merge to 'next'.


* jk/send-pack-stdio (2016-06-10) 2 commits
 - write_or_die: remove the unused write_or_whine() function
 - send-pack: use buffered I/O to talk to pack-objects

 Code clean-up.

 Will merge to 'next'.


* pb/commit-editmsg-path (2016-06-09) 1 commit
 - builtin/commit.c: memoize git-path for COMMIT_EDITMSG

 Code clean-up.

 Will merge to 'next'.


* wd/userdiff-css (2016-06-03) 1 commit
  (merged to 'next' on 2016-06-06 at 536102f)
 + userdiff: add built-in pattern for CSS

 Update the funcname definition to support css files.

 Will merge to 'master' after 2.9 final.


* jc/attr-more (2016-06-09) 8 commits
 - attr.c: outline the future plans by heavily commenting
 - attr.c: always pass check[] to collect_some_attrs()
 - attr.c: introduce empty_attr_check_elems()
 - attr.c: correct ugly hack for git_all_attrs()
 - attr.c: rename a local variable check
 - fixup! d5ad6c13
 - attr.c: pass struct git_attr_check down the callchain
 - attr.c: add push_stack() helper
 (this branch uses jc/attr; is tangled with sb/pathspec-label and sb/submodule-default-paths.)

 The beginning of long and tortuous journey to clean-up attribute
 subsystem implementation.


* jk/rev-list-count-with-bitmap (2016-06-03) 2 commits
  (merged to 'next' on 2016-06-06 at dd9b30f)
 + rev-list: disable bitmaps when "-n" is used with listing objects
 + rev-list: "adjust" results of "--count --use-bitmap-index -n"

 "git rev-list --count" whose walk-length is limited with "-n"
 option did not work well with the counting optimized to look at the
 bitmap index.

 Will merge to 'master' after 2.9 final.


* mh/ref-iterators (2016-06-03) 13 commits
  (merged to 'next' on 2016-06-06 at c8e79dc)
 + for_each_reflog(): reimplement using iterators
 + dir_iterator: new API for iterating over a directory tree
 + for_each_reflog(): don't abort for bad references
 + do_for_each_ref(): reimplement using reference iteration
 + refs: introduce an iterator interface
 + ref_resolves_to_object(): new function
 + entry_resolves_to_object(): rename function from ref_resolves_to_object()
 + get_ref_cache(): only create an instance if there is a submodule
 + remote rm: handle symbolic refs correctly
 + delete_refs(): add a flags argument
 + refs: use name "prefix" consistently
 + do_for_each_ref(): move docstring to the header file
 + refs: remove unnecessary "extern" keywords
 (this branch is used by mh/ref-store; uses mh/split-under-lock; is tangled with mh/update-ref-errors.)

 The API to iterate over all the refs (i.e. for_each_ref(), etc.)
 has been revamped.

 Will merge to 'master' after 2.9 final.


* ew/mboxrd-format-am (2016-06-06) 3 commits
 - am: support --patch-format=mboxrd
 - mailsplit: support unescaping mboxrd messages
 - pretty: support "mboxrd" output format

 Teach format-patch and mailsplit (hence "am") how a line that
 happens to begin with "From " in the e-mail message is quoted with
 ">", so that these lines can be restored to their original shape.


* lf/receive-pack-auto-gc-to-client (2016-06-06) 1 commit
 - receive-pack: send auto-gc output over sideband 2

 Allow messages that are generated by auto gc during "git push" on
 the receiving end to be explicitly passed back to the sending end
 over sideband, so that they are shown with "remote: " prefix to
 avoid confusing the users.


* mg/cherry-pick-multi-on-unborn (2016-06-06) 1 commit
 - cherry-pick: allow to pick to unborn branches

 "git cherry-pick A" worked on an unborn branch, but "git
 cherry-pick A..B" didn't.


* mj/log-show-signature-conf (2016-06-06) 2 commits
 - log: "--no-show-signature" commmand-line option
 - log: add "log.showsignature" configuration variable

 "git log" learns log.showSignature configuration variable, and a
 command line option "--no-show-signature" to countermand it.

 The order of the commits in the topic need to be reversed.


* nd/i-t-a-commitable (2016-06-06) 3 commits
 - commit: don't count i-t-a entries when checking if the new commit is empty
 - Resurrect "diff-lib.c: adjust position of i-t-a entries in diff"
 - diff.h: extend "flags" field to 64 bits because we're out of bits

 "rm .git/index && git add -N * && git commit" allows you to create
 an empty commit without --allow-empty; attempt to forbid it.

 Breaks many tests by completely butchering "git commit", it seems.


* sg/reflog-past-root (2016-06-06) 1 commit
 - reflog: continue walking the reflog past root commits

 "git reflog" stopped upon seeing an entry that denotes a branch
 creation event (aka "unborn"), which made it appear as if the
 reflog was truncated.


* tb/complete-status (2016-06-10) 3 commits
 - completion: add git status
 - completion: add __git_get_option_value helper
 - completion: factor out untracked file modes into a variable

 The completion script (in contrib/) learned to complete "git
 status" options.


* tr/doc-tt (2016-06-08) 4 commits
 - doc: change configuration variables format
 - doc: more consistency in environment variables format
 - doc: change environment variables format
 - doc: clearer rule about formatting literals

 The documentation set has been updated so that literal commands,
 configuration variables and environment variables are consistently
 typeset in fixed-width font and bold in manpages.

 Will merge to 'next'.


* vs/prompt-avoid-unset-variable (2016-06-06) 1 commit
 - git-prompt.sh: Don't error on null ${ZSH,BASH}_VERSION, $short_sha

 The git-prompt scriptlet (in contrib/) was not friendly with those
 who uses "set -u", which has been fixed.


* rj/compat-regex-size-max-fix (2016-06-06) 1 commit
 - regex: fix a SIZE_MAX macro redefinition warning

 A compilation fix.

 Will merge to 'next'.


* bc/cocci-object-id (2016-06-06) 8 commits
 - merge-recursive: convert merge_recursive_generic to object_id
 - merge-recursive: convert leaf functions to use struct object_id
 - merge-recursive: convert struct merge_file_info to object_id
 - merge-recursive: convert struct stage_data to use object_id
 - Rename struct diff_filespec's sha1_valid member.
 - Convert struct diff_filespec to struct object_id
 - Apply standard object_id Coccinelle transformations.
 - Add basic Coccinelle transforms.

 Move from "unsigned char [20]" to "struct object_id" continues,
 with help from an automated tool.


* et/add-chmod-x (2016-06-07) 1 commit
 - add: add --chmod=+x / --chmod=-x options

 "git update-index --add --chmod=+x file" may be usable as an escape
 hatch, but not a friendly thing to force for people who do need to
 use it regularly.  "git add --chmod=+x file" can be used instead.

 Will merge to 'next'.


* mh/connect (2016-06-06) 10 commits
 - connect: [host:port] is legacy for ssh
 - connect: move ssh command line preparation to a separate function
 - connect: actively reject git:// urls with a user part
 - connect: change the --diag-url output to separate user and host
 - connect: make parse_connect_url() return the user part of the url as a separate value
 - connect: group CONNECT_DIAG_URL handling code
 - connect: make parse_connect_url() return separated host and port
 - connect: re-derive a host:port string from the separate host and port variables
 - connect: call get_host_and_port() earlier
 - connect: document why we sometimes call get_port after get_host_and_port

 Ok, folks, is everybody happy with this version?


* aq/upload-pack-use-parse-options (2016-05-31) 1 commit
  (merged to 'next' on 2016-06-06 at 505f1ee)
 + upload-pack.c: use parse-options API

 "git upload-pack" command has been updated to use the parse-options
 API.

 Will merge to 'master' after 2.9 final.


* jc/clear-pathspec (2016-06-02) 1 commit
  (merged to 'next' on 2016-06-06 at 9e7e291)
 + pathspec: rename free_pathspec() to clear_pathspec()

 We usually call a function that clears the contents a data
 structure X without freeing the structure itself clear_X(), and
 call a function that does clear_X() and also frees it free_X().
 free_pathspec() function has been renamed to clear_pathspec()
 to avoid confusion.

 Will merge to 'master' after 2.9 final.


* sb/submodule-recommend-shallowness (2016-05-27) 2 commits
  (merged to 'next' on 2016-05-31 at 1ee161c)
 + submodule update: learn `--[no-]recommend-shallow` option
 + submodule-config: keep shallow recommendation around
 (this branch is used by sb/submodule-clone-retry.)

 An upstream project can make a recommendation to make only a
 shallow clone for some submodules in the .gitmodules file it ship.

 Will merge to 'master' after 2.9 final.


* tb/convert-peek-in-index (2016-06-07) 3 commits
 - correct ce_compare_data() in a middle of a merge
 - read-cache: factor out get_sha1_from_index() helper
 - convert: unify the "auto" handling of CRLF

 Needs review.


* va/i18n-even-more (2016-06-07) 38 commits
 - i18n: branch: mark comment when editing branch description for translation
 - i18n: unmark die messages for translation
 - i18n: submodule: escape shell variables inside eval_gettext
 - i18n: submodule: join strings marked for translation
 - i18n: init-db: join message pieces
 - i18n: remote: allow translations to reorder message
 - i18n: remote: mark URL fallback text for translation
 - i18n: standardise messages
 - i18n: sequencer: add period to error message
 - i18n: merge: change command option help to lowercase
 - i18n: merge: mark messages for translation
 - i18n: notes: mark options for translation
 - i18n: notes: mark strings for translation
 - i18n: transport-helper.c: change N_() call to _()
 - i18n: bisect: mark strings for translation
 - t5523: use test_i18ngrep for negation
 - t4153: fix negated test_i18ngrep call
 - t9003: become resilient to GETTEXT_POISON
 - tests: unpack-trees: update to use test_i18n* functions
 - tests: use test_i18n* functions to suppress false positives
 - i18n: setup: mark strings for translation
 - i18n: rebase-interactive: mark comments of squash for translation
 - i18n: rebase-interactive: mark here-doc strings for translation
 - i18n: rebase-interactive: mark strings for translation
 - i18n: git-sh-setup.sh: mark strings for translation
 - t6030: update to use test_i18ncmp
 - i18n: bisect: simplify error message for i18n
 - i18n: rebase: mark placeholder for translation
 - i18n: rebase: fix marked string to use eval_gettext variant
 - merge-octupus: use die shell function from git-sh-setup.sh
 - i18n: merge-octopus: mark messages for translation
 - i18n: sequencer: mark string for translation
 - i18n: sequencer: mark entire sentences for translation
 - i18n: transport: mark strings for translation
 - i18n: advice: internationalize message for conflicts
 - i18n: advice: mark string about detached head for translation
 - i18n: builtin/remote.c: fix mark for translation
 - Merge branch 'jc/t2300-setup' into HEAD

 More markings of messages for i18n, with updates to various tests
 to pass GETTEXT_POISON tests.

 One patch from the original submission dropped due to conflicts
 with other topics in flight.


* jg/dash-is-last-branch-in-worktree-add (2016-05-31) 1 commit
  (merged to 'next' on 2016-06-02 at 3959ef6)
 + worktree: allow "-" short-hand for @{-1} in add command

 "git worktree add" learned that '-' can be used as a short-hand for
 "@{-1}", the previous branch.

 Will merge to 'master' after 2.9 final.


* dk/blame-move-no-reason-for-1-line-context (2016-05-29) 1 commit
 - blame: require 0 context lines while finding moved lines with -M

 "git blame -M" missed a single line that was moved within the file.

 We may want to squash a test or two to this commit.  Volunteers?


* nd/worktree-lock (2016-06-13) 6 commits
 - worktree.c: find_worktree() search by path suffix
 - worktree: add "unlock" command
 - worktree: add "lock" command
 - worktree.c: add is_worktree_locked()
 - worktree.c: add is_main_worktree()
 - worktree.c: add find_worktree()
 (this branch uses nd/worktree-cleanup-post-head-protection.)

 "git worktree prune" protected worktrees that are marked as
 "locked" by creating a file in a known location.  "git worktree"
 command learned a dedicated command pair to create and remoev such
 a file, so that the users do not have to do this with editor.

 Ok, folks, is everybody happy with this version?


* et/pretty-format-c-auto (2016-05-27) 1 commit
  (merged to 'next' on 2016-05-31 at 1e9c920)
 + format_commit_message: honor `color=auto` for `%C(auto)`

 %C(auto) in a custom format string that commands in `git log`
 family takes unconditionally turned the color on, ignoring
 --no-color or --color=auto with output not connected to a tty;
 this was corrected to make the format truly behave as "auto".

 Will merge to 'master' after 2.9 final.


* ew/daemon-socket-keepalive (2016-05-25) 1 commit
  (merged to 'next' on 2016-05-31 at c32acf1)
 + daemon: enable SO_KEEPALIVE for all sockets

 When "git daemon" is run without --[init-]timeout specified, a
 connection from a client that silently goes offline can hang around
 for a long time, wasting resources.  The socket-level KEEPALIVE has
 been enabled to allow the OS to notice such failed connections.

 Will merge to 'master' after 2.9 final.


* jk/upload-pack-hook (2016-06-02) 7 commits
 - upload-pack: provide a hook for running pack-objects
 - t1308: do not get fooled by symbolic links to the source tree
 - config: add a notion of "scope"
 - config: return configset value for current_config_ functions
 - config: set up config_source for command-line config
 - git_config_parse_parameter: refactor cleanup code
 - git_config_with_options: drop "found" counting

 Allow a custom "git upload-pack" replacement to respond to
 "fetch/clone" request.

 Still under discussion.
 ($gmane/295705).


* rs/xdiff-hunk-with-func-line (2016-06-09) 9 commits
  (merged to 'next' on 2016-06-10 at 9ff9ba8)
 + xdiff: fix merging of appended hunk with -W
  (merged to 'next' on 2016-06-02 at 0c2e335)
 + grep: -W: don't extend context to trailing empty lines
 + t7810: add test for grep -W and trailing empty context lines
 + xdiff: don't trim common tail with -W
 + xdiff: -W: don't include common trailing empty lines in context
 + xdiff: ignore empty lines before added functions with -W
 + xdiff: handle appended chunks better with -W
 + xdiff: factor out match_func_rec()
 + t4051: rewrite, add more tests

 "git show -W" (extend hunks to cover the entire function, delimited
 by lines that match the "funcname" pattern) used to show the entire
 file when a change added an entire function at the end of the file,
 which has been fixed.

 Will merge to 'master' after 2.9 final.


* sb/submodule-misc-cleanups (2016-05-25) 1 commit
  (merged to 'next' on 2016-05-31 at 0d07b9c)
 + submodule update: make use of the existing fetch_in_submodule function

 Minor simplification.

 Will merge to 'master' after 2.9 final.


* sb/submodule-default-paths (2016-06-14) 8 commits
 - completion: clone can recurse into submodules
 - clone: add --init-submodule=<pathspec> switch
 - submodule update: add `--init-default-path` switch
 - Merge branch 'sb/pathspec-label' into sb/submodule-default-paths
 - Merge branch 'jc/attr' into sb/submodule-default-paths
 - Merge branch 'sb/clone-shallow-passthru' into sb/submodule-default-paths
 - Merge branch 'sb/submodule-deinit-all' into sb/submodule-default-paths
 - Merge branch 'sb/submodule-parallel-update' into sb/submodule-default-paths
 (this branch uses jc/attr and sb/pathspec-label; is tangled with jc/attr-more.)

 Will hold.


* ah/no-verify-signature-with-pull-rebase (2016-05-20) 1 commit
  (merged to 'next' on 2016-05-31 at 30add83)
 + pull: warn on --verify-signatures with --rebase

 "git pull --rebase --verify-signature" learned to warn the user
 that "--verify-signature" is a no-op.

 Will merge to 'master' after 2.9 final.


* ep/http-curl-trace (2016-05-24) 2 commits
 - imap-send.c: introduce the GIT_TRACE_CURL enviroment variable
 - http.c: implement the GIT_TRACE_CURL environment variable

 HTTP transport gained an option to produce more detailed debugging
 trace.

 Rerolled.  Is everybody happy with this version?


* jc/attr (2016-05-25) 18 commits
  (merged to 'next' on 2016-05-31 at 5b2f08b)
 + attr: support quoting pathname patterns in C style
 + attr: expose validity check for attribute names
 + attr: add counted string version of git_attr()
 + attr: add counted string version of git_check_attr()
 + attr: retire git_check_attrs() API
 + attr: convert git_check_attrs() callers to use the new API
 + attr: convert git_all_attrs() to use "struct git_attr_check"
 + attr: (re)introduce git_check_attr() and struct git_attr_check
 + attr: rename function and struct related to checking attributes
 + attr.c: plug small leak in parse_attr_line()
 + attr.c: tighten constness around "git_attr" structure
 + attr.c: simplify macroexpand_one()
 + attr.c: mark where #if DEBUG ends more clearly
 + attr.c: complete a sentence in a comment
 + attr.c: explain the lack of attr-name syntax check in parse_attr()
 + attr.c: update a stale comment on "struct match_attr"
 + attr.c: use strchrnul() to scan for one line
 + commit.c: use strchrnul() to scan for one line
 (this branch is used by jc/attr-more, sb/pathspec-label and sb/submodule-default-paths.)

 The attributes API has been updated so that it can later be
 optimized using the knowledge of which attributes are queried.


* cc/apply-introduce-state (2016-06-06) 50 commits
  (merged to 'next' on 2016-06-06 at 9f6bdcb)
 + builtin/apply: remove misleading comment on lock_file field
  (merged to 'next' on 2016-06-03 at 1ab0cf9)
 + builtin/apply: move 'newfd' global into 'struct apply_state'
 + builtin/apply: add 'lock_file' pointer into 'struct apply_state'
 + builtin/apply: move applying patches into apply_all_patches()
 + builtin/apply: move 'state' check into check_apply_state()
 + builtin/apply: move 'symlink_changes' global into 'struct apply_state'
 + builtin/apply: move 'fn_table' global into 'struct apply_state'
 + builtin/apply: move 'state_linenr' global into 'struct apply_state'
 + builtin/apply: move 'max_change' and 'max_len' into 'struct apply_state'
 + builtin/apply: move 'ws_ignore_action' into 'struct apply_state'
 + builtin/apply: move 'ws_error_action' into 'struct apply_state'
 + builtin/apply: move 'applied_after_fixing_ws' into 'struct apply_state'
 + builtin/apply: move 'squelch_whitespace_errors' into 'struct apply_state'
 + builtin/apply: remove whitespace_option arg from set_default_whitespace_mode()
 + builtin/apply: move 'whitespace_option' into 'struct apply_state'
 + builtin/apply: move 'whitespace_error' global into 'struct apply_state'
 + builtin/apply: move 'root' global into 'struct apply_state'
 + builtin/apply: move 'p_value_known' global into 'struct apply_state'
 + builtin/apply: move 'p_value' global into 'struct apply_state'
 + builtin/apply: move 'has_include' global into 'struct apply_state'
 + builtin/apply: move 'limit_by_name' global into 'struct apply_state'
 + builtin/apply: move 'patch_input_file' global into 'struct apply_state'
 + builtin/apply: move 'apply' global into 'struct apply_state'
 + builtin/apply: move 'p_context' global into 'struct apply_state'
 + builtin/apply: move 'fake_ancestor' global into 'struct apply_state'
 + builtin/apply: move 'line_termination' global into 'struct apply_state'
 + builtin/apply: move 'unsafe_paths' global into 'struct apply_state'
 + builtin/apply: move 'no_add' global into 'struct apply_state'
 + builtin/apply: move 'threeway' global into 'struct apply_state'
 + builtin/apply: move 'summary' global into 'struct apply_state'
 + builtin/apply: move 'numstat' global into 'struct apply_state'
 + builtin/apply: move 'diffstat' global into 'struct apply_state'
 + builtin/apply: move 'cached' global into 'struct apply_state'
 + builtin/apply: move 'allow_overlap' global into 'struct apply_state'
 + builtin/apply: move 'update_index' global into 'struct apply_state'
 + builtin/apply: move 'apply_verbosely' global into 'struct apply_state'
 + builtin/apply: move 'apply_with_reject' global into 'struct apply_state'
 + builtin/apply: move 'apply_in_reverse' global into 'struct apply_state'
 + builtin/apply: move 'check_index' global into 'struct apply_state'
 + builtin/apply: move 'check' global into 'struct apply_state'
 + builtin/apply: move 'unidiff_zero' global into 'struct apply_state'
 + builtin/apply: move 'state' init into init_apply_state()
 + builtin/apply: introduce 'struct apply_state' to start libifying
 + builtin/apply: move 'read_stdin' global into cmd_apply()
 + builtin/apply: move 'options' variable into cmd_apply()
 + builtin/apply: extract line_by_line_fuzzy_match() from match_fragment()
 + builtin/apply: avoid local variable shadowing 'len' parameter
 + builtin/apply: avoid parameter shadowing 'linenr' global
 + builtin/apply: avoid parameter shadowing 'p_value' global
 + builtin/apply: make gitdiff_verify_name() return void

 The "git apply" standalone program is being libified; this is the
 first step to move many state variables into a structure that can
 be explicitly (re)initialized to make the machinery callable more
 than once.

 The next step that moves some remaining state variables into the
 structure and turns die()s into an error return that propagates up
 to the caller is not queued yet but in flight.  It would be good to
 review the above first and give the remainder of the series a solid
 base to build on.

 Will hold.


* pb/bisect (2016-05-24) 3 commits
 - bisect--helper: `write_terms` shell function in C
 - bisect: rewrite `check_term_format` shell function in C
 - bisect--helper: use OPT_CMDMODE instead of OPT_BOOL

 Beginning of GSoC "git bisect" project.


* sb/pathspec-label (2016-06-03) 6 commits
  (merged to 'next' on 2016-06-03 at 362f097)
 + pathspec: disable preload-index when attribute pathspec magic is in use
 + pathspec: allow escaped query values
  (merged to 'next' on 2016-05-31 at e72b604)
 + pathspec: allow querying for attributes
 + pathspec: move prefix check out of the inner loop
 + pathspec: move long magic parsing out of prefix_pathspec
 + Documentation: fix a typo
 (this branch is used by sb/submodule-default-paths; uses jc/attr; is tangled with jc/attr-more.)

 The pathspec mechanism learned ":(attr:X)$pattern" pathspec magic
 to limit paths that match $pattern further by attribute settings.
 The preload-index mechanism is disabled when the new pathspec magic
 is in use (at least for now), because the attribute subsystem is
 not thread-ready.

 Will hold.


* nd/worktree-cleanup-post-head-protection (2016-05-24) 6 commits
 - worktree: simplify prefixing paths
 - worktree: avoid 0{40}, too many zeroes, hard to read
 - worktree.c: use is_dot_or_dotdot()
 - git-worktree.txt: keep subcommand listing in alphabetical order
 - worktree.c: rewrite mark_current_worktree() to avoid strbuf
 - completion: support git-worktree
 (this branch is used by nd/worktree-lock.)

 Further preparatory clean-up for "worktree" feature.

 Expecting a reroll.
 ($gmane/294136, etc.)


* mh/split-under-lock (2016-05-13) 33 commits
  (merged to 'next' on 2016-06-03 at 2e71330)
 + lock_ref_sha1_basic(): only handle REF_NODEREF mode
 + commit_ref_update(): remove the flags parameter
 + lock_ref_for_update(): don't resolve symrefs
 + lock_ref_for_update(): don't re-read non-symbolic references
 + refs: resolve symbolic refs first
 + ref_transaction_update(): check refname_is_safe() at a minimum
 + unlock_ref(): move definition higher in the file
 + lock_ref_for_update(): new function
 + add_update(): initialize the whole ref_update
 + verify_refname_available(): adjust constness in declaration
 + refs: don't dereference on rename
 + refs: allow log-only updates
 + delete_branches(): use resolve_refdup()
 + ref_transaction_commit(): correctly report close_ref() failure
 + ref_transaction_create(): disallow recursive pruning
 + refs: make error messages more consistent
 + lock_ref_sha1_basic(): remove unneeded local variable
 + read_raw_ref(): move docstring to header file
 + read_raw_ref(): improve docstring
 + read_raw_ref(): rename symref argument to referent
 + read_raw_ref(): clear *type at start of function
 + read_raw_ref(): rename flags argument to type
 + ref_transaction_commit(): remove local variable n
 + rename_ref(): remove unneeded local variable
 + commit_ref_update(): write error message to *err, not stderr
 + refname_is_safe(): insist that the refname already be normalized
 + refname_is_safe(): don't allow the empty string
 + refname_is_safe(): use skip_prefix()
 + remove_dir_recursively(): add docstring
 + safe_create_leading_directories(): improve docstring
 + read_raw_ref(): don't get confused by an empty directory
 + commit_ref(): if there is an empty dir in the way, delete it
 + t1404: demonstrate a bug resolving references
 (this branch is used by mh/ref-iterators, mh/ref-store and mh/update-ref-errors.)

 Further preparatory work on the refs API before the pluggable
 backend series can land.

 Will merge to 'master' after 2.9 final.


* ew/fast-import-unpack-limit (2016-05-29) 2 commits
  (merged to 'next' on 2016-05-29 at af32aba)
 + fast-import: invalidate pack_id references after loosening
  (merged to 'next' on 2016-05-11 at ffd4efb)
 + fast-import: implement unpack limit

 "git fast-import" learned the same performance trick to avoid
 creating too small a packfile as "git fetch" and "git push" have,
 using *.unpackLimit configuration.

 Will hold.


* jc/send-email-skip-backup (2016-04-12) 1 commit
 - send-email: detect and offer to skip backup files

 A careless invocation of "git send-email directory/" after editing
 0001-change.patch with an editor often ends up sending both
 0001-change.patch and its backup file, 0001-change.patch~, causing
 embarrassment and a minor confusion.  Detect such an input and
 offer to skip the backup files when sending the patches out.

 Needs review.


* kn/ref-filter-branch-list (2016-05-17) 17 commits
 - branch: implement '--format' option
 - branch: use ref-filter printing APIs
 - branch, tag: use porcelain output
 - ref-filter: allow porcelain to translate messages in the output
 - ref-filter: add `:dir` and `:base` options for ref printing atoms
 - ref-filter: make remote_ref_atom_parser() use refname_atom_parser_internal()
 - ref-filter: introduce symref_atom_parser() and refname_atom_parser()
 - ref-filter: introduce refname_atom_parser_internal()
 - ref-filter: make "%(symref)" atom work with the ':short' modifier
 - ref-filter: add support for %(upstream:track,nobracket)
 - ref-filter: make %(upstream:track) prints "[gone]" for invalid upstreams
 - ref-filter: introduce format_ref_array_item()
 - ref-filter: move get_head_description() from branch.c
 - ref-filter: modify "%(objectname:short)" to take length
 - ref-filter: implement %(if:equals=<string>) and %(if:notequals=<string>)
 - ref-filter: include reference to 'used_atom' within 'atom_value'
 - ref-filter: implement %(if), %(then), and %(else) atoms

 The code to list branches in "git branch" has been consolidated
 with the more generic ref-filter API.

 Rerolled.
 Needs review.


* dt/index-helper (2016-05-20) 20 commits
 - index-helper: indexhelper.exitafter config
 - trace: measure where the time is spent in the index-heavy operations
 - index-helper: optionally automatically run
 - index-helper: autorun mode
 - index-helper: don't run if already running
 - index-helper: kill mode
 - watchman: add a config option to enable the extension
 - unpack-trees: preserve index extensions
 - update-index: enable/disable watchman support
 - index-helper: use watchman to avoid refreshing index with lstat()
 - watchman: support watchman to reduce index refresh cost
 - read-cache: add watchman 'WAMA' extension
 - index-helper: log warnings
 - index-helper: add --detach
 - daemonize(): set a flag before exiting the main process
 - index-helper: add --strict
 - index-helper: new daemon for caching index and related stuff
 - pkt-line: add gentle version of packet_write
 - read-cache: allow to keep mmap'd memory after reading
 - read-cache.c: fix constness of verify_hdr()

 A new "index-helper" daemon has been introduced to give newly
 spawned Git process a quicker access to the data in the index, and
 optionally interface with the watchman daemon to further reduce the
 refresh cost.

 Rerolled.
 ($gmane/295106).


* jc/bundle (2016-03-03) 6 commits
 - index-pack: --clone-bundle option
 - Merge branch 'jc/index-pack' into jc/bundle
 - bundle v3: the beginning
 - bundle: keep a copy of bundle file name in the in-core bundle header
 - bundle: plug resource leak
 - bundle doc: 'verify' is not about verifying the bundle

 The beginning of "split bundle", which could be one of the
 ingredients to allow "git clone" traffic off of the core server
 network to CDN.


* jc/merge-drop-old-syntax (2015-04-29) 1 commit
 - merge: drop 'git merge <message> HEAD <commit>' syntax

 Stop supporting "git merge <message> HEAD <commit>" syntax that has
 been deprecated since October 2007, and issues a deprecation
 warning message since v2.5.0.

 It has been reported that git-gui still uses the deprecated syntax,
 which needs to be fixed before this final step can proceed.
 ($gmane/282594)

--------------------------------------------------
[Discarded]

* mh/connect-leak (2016-04-28) 1 commit
 . git_connect(): fix memory leak with CONNECT_DIAG_URL

 Is already made obsolete with a patch in flight under discussion.
 ($gmane/292962)

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: What's cooking in git.git (Jun 2016, #04; Tue, 14)
  2016-06-14 22:08 What's cooking in git.git (Jun 2016, #04; Tue, 14) Junio C Hamano
@ 2016-06-15  2:36 ` Mike Hommey
  2016-06-15 18:32   ` Junio C Hamano
  2016-06-15  7:35 ` Elia Pinto
  2016-06-15 10:12 ` Duy Nguyen
  2 siblings, 1 reply; 9+ messages in thread
From: Mike Hommey @ 2016-06-15  2:36 UTC (permalink / raw)
  To: Junio C Hamano; +Cc: git

On Tue, Jun 14, 2016 at 03:08:04PM -0700, Junio C Hamano wrote:
> Here are the topics that have been cooking.  Commits prefixed with
> '-' are only in 'pu' (proposed updates) while commits prefixed with
> '+' are in 'next'.  The ones marked with '.' do not appear in any of
> the integration branches, but I am still holding onto them.
> 
> Git 2.9 has been tagged.  Let's wait for a few days to clean up
> possible fallout and then start a new cycle by rewinding the tip of
> 'next'.  I expect I'd eject a few premature topics out of 'next'
> while doing so.
> 
> You can find the changes described here in the integration branches
> of the repositories listed at
> 
>     http://git-blame.blogspot.com/p/git-public-repositories.html
> 
> --------------------------------------------------
> [Graduated to "master"]
> 
> * jc/t2300-setup (2016-06-01) 1 commit
>   (merged to 'next' on 2016-06-06 at 20f7f83)
>  + t2300: run git-sh-setup in an environment that better mimics the real life
>  (this branch is used by va/i18n-even-more.)
> 
>  A test fix.
> 
> 
> * jk/diff-compact-heuristic (2016-06-10) 1 commit
>  - diff: disable compaction heuristic for now
> 
>  It turns out that the earlier effort to update the heuristics may
>  want to use a bit more time to mature.  Turn it off by default.
> 
> 
> * jk/shell-portability (2016-06-01) 2 commits
>   (merged to 'next' on 2016-06-06 at 5de784e)
>  + t5500 & t7403: lose bash-ism "local"
>  + test-lib: add in-shell "env" replacement
> 
>  test fixes.
> 
> --------------------------------------------------
> [New Topics]
> 
> * lv/status-say-working-tree-not-directory (2016-06-09) 1 commit
>  - Use "working tree" instead of "working directory" for git status
> 
>  "git status" used to say "working directory" when it meant "working
>  tree".
> 
>  Will merge to 'next'.
> 
> 
> * jk/parseopt-string-list (2016-06-13) 3 commits
>  - blame,shortlog: don't make local option variables static
>  - interpret-trailers: don't duplicate option strings
>  - parse_opt_string_list: stop allocating new strings
>  (this branch is used by jk/string-list-static-init.)
> 
>  The command line argument parsing that uses OPT_STRING_LIST() often
>  made a copy of the argv[] element, which was unnecessary.
> 
>  Will merge to 'next'.
> 
> 
> * jk/repack-keep-unreachable (2016-06-14) 3 commits
>  - repack: extend --keep-unreachable to loose objects
>  - repack: add --keep-unreachable option
>  - repack: document --unpack-unreachable option
> 
>  "git repack" learned the "--keep-unreachable" option, which sends
>  loose unreachable objects to a pack instead of leaving them loose.
>  This helps heuristics based on the number of loose objects
>  (e.g. "gc --auto").
> 
>  Will merge to 'next'.
> 
> 
> * lf/recv-sideband-cleanup (2016-06-13) 1 commit
>  - sideband.c: refactor recv_sideband()
> 
>  Code simplification.  It however loses the atomicity of the output
>  9ac13ec9 (atomic write for sideband remote messages, 2006-10-11)
>  tried to add to an once-much-simpler codebase.
> 
>  Expecting a reroll.
> 
> 
> * nd/test-lib-httpd-show-error-log-in-verbose (2016-06-13) 1 commit
>  - lib-httpd.sh: print error.log on error
> 
>  Debugging aid.
> 
>  Will merge to 'next'.
> 
> 
> * pc/occurred (2016-06-10) 2 commits
>  - config.c: fix misspelt "occurred" in an error message
>  - refs.h: fix misspelt "occurred" in a comment
> 
>  Will merge to 'next'.
> 
> 
> * sb/submodule-clone-retry (2016-06-13) 2 commits
>  - submodule update: continue when a clone fails
>  - submodule--helper: initial clone learns retry logic
>  (this branch uses sb/submodule-recommend-shallowness.)
> 
>  "git submodule update" that drives many "git clone" could
>  eventually hit flaky servers/network conditions on one of the
>  submodules; the command learned to retry the attempt.
> 
> 
> * jc/blame-reverse (2016-06-14) 2 commits
>  - blame: dwim "blame --reverse OLD" as "blame --reverse OLD.."
>  - blame: improve diagnosis for "--reverse NEW"
> 
> 
> * jc/deref-tag (2016-06-14) 1 commit
>  - blame, line-log: do not loop around deref_tag()
> 
>  Code clean-up.
> 
>  Will merge to 'next'.
> 
> 
> * jk/fetch-prune-doc (2016-06-14) 1 commit
>  - fetch: document that pruning happens before fetching
> 
>  Will merge to 'next'.
> 
> 
> * km/fetch-do-not-free-remote-name (2016-06-14) 1 commit
>  - builtin/fetch.c: don't free remote->name after fetch
> 
>  Will merge to 'next'.
> 
> 
> * nb/gnome-keyring-build (2016-06-14) 1 commit
>  - gnome-keyring: Don't hard-code pkg-config executable
> 
>  Build improvements for gnome-keyring (in contrib/)
> 
>  Will merge to 'next'.
> 
> 
> * pb/strbuf-read-file-doc (2016-06-14) 1 commit
>  - strbuf: describe the return value of strbuf_read_file
> 
>  Will merge to 'next'.
> 
> --------------------------------------------------
> [Stalled]
> 
> * sb/bisect (2016-04-15) 22 commits
>  - SQUASH???
>  - bisect: get back halfway shortcut
>  - bisect: compute best bisection in compute_relevant_weights()
>  - bisect: use a bottom-up traversal to find relevant weights
>  - bisect: prepare for different algorithms based on find_all
>  - bisect: rename count_distance() to compute_weight()
>  - bisect: make total number of commits global
>  - bisect: introduce distance_direction()
>  - bisect: extract get_distance() function from code duplication
>  - bisect: use commit instead of commit list as arguments when appropriate
>  - bisect: replace clear_distance() by unique markers
>  - bisect: use struct node_data array instead of int array
>  - bisect: get rid of recursion in count_distance()
>  - bisect: make algorithm behavior independent of DEBUG_BISECT
>  - bisect: make bisect compile if DEBUG_BISECT is set
>  - bisect: plug the biggest memory leak
>  - bisect: add test for the bisect algorithm
>  - t6030: generalize test to not rely on current implementation
>  - t: use test_cmp_rev() where appropriate
>  - t/test-lib-functions.sh: generalize test_cmp_rev
>  - bisect: allow 'bisect run' if no good commit is known
>  - bisect: write about `bisect next` in documentation
> 
>  The internal algorithm used in "git bisect" to find the next commit
>  to check has been optimized greatly.
> 
>  Expecting a reroll.
>  ($gmane/291163)
> 
> 
> * sg/completion-updates (2016-02-28) 21 commits
>  . completion: cache the path to the repository
>  . completion: extract repository discovery from __gitdir()
>  . completion: don't guard git executions with __gitdir()
>  . completion: consolidate silencing errors from git commands
>  . completion: don't use __gitdir() for git commands
>  . completion: respect 'git -C <path>'
>  . completion: fix completion after 'git -C <path>'
>  . completion: don't offer commands when 'git --opt' needs an argument
>  . rev-parse: add '--absolute-git-dir' option
>  . completion: list short refs from a remote given as a URL
>  . completion: don't list 'HEAD' when trying refs completion outside of a repo
>  . completion: list refs from remote when remote's name matches a directory
>  . completion: respect 'git --git-dir=<path>' when listing remote refs
>  . completion: fix most spots not respecting 'git --git-dir=<path>'
>  . completion: ensure that the repository path given on the command line exists
>  . completion tests: add tests for the __git_refs() helper function
>  . completion tests: check __gitdir()'s output in the error cases
>  . completion tests: consolidate getting path of current working directory
>  . completion tests: make the $cur variable local to the test helper functions
>  . completion tests: don't add test cruft to the test repository
>  . completion: improve __git_refs()'s in-code documentation
> 
>  Will be rerolled.
>  ($gmane/287839)
> 
> 
> * az/p4-bare-no-rebase (2016-02-19) 1 commit
>  - git-p4.py: Don't try to rebase on submit from bare repository
> 
>  "git p4 submit" attempts to do a rebase, which would fail if done
>  in a bare repository.  Not doing this rebase would paper over the
>  failure, which is what this patch does, but it is unclear what the
>  side effect of not rebasing is.
> 
>  Needs a better explanation.
> 
> 
> * nd/icase (2016-02-15) 12 commits
>  - grep.c: reuse "icase" variable
>  - diffcore-pickaxe: support case insensitive match on non-ascii
>  - diffcore-pickaxe: "share" regex error handling code
>  - grep/pcre: support utf-8
>  - gettext: add is_utf8_locale()
>  - grep/pcre: prepare locale-dependent tables for icase matching
>  - grep/icase: avoid kwsset when -F is specified
>  - grep/icase: avoid kwsset on literal non-ascii strings
>  - test-regex: expose full regcomp() to the command line
>  - test-regex: isolate the bug test code
>  - grep: break down an "if" stmt in preparation for next changes
>  - grep: allow -F -i combination
> 
>  "git grep -i" has been taught to fold case in non-ascii locales.
> 
>  Needs review.
>  ($gmane/286137)
> 
> 
> * ec/annotate-deleted (2015-11-20) 1 commit
>  - annotate: skip checking working tree if a revision is provided
> 
>  Usability fix for annotate-specific "<file> <rev>" syntax with deleted
>  files.
> 
>  Waiting for review.
> 
> 
> * dg/subtree-rebase-test (2016-01-19) 1 commit
>  - contrib/subtree: Add a test for subtree rebase that loses commits
> 
>  Reviewed up to v5.
>  Will be rerolled.
>  ($gmane/284426)
> 
> 
> * js/am-3-merge-recursive-direct (2015-10-12) 2 commits
>  - am: make a direct call to merge_recursive
>  - merge_recursive_options: introduce the "gently" flag
> 
>  The merge_recursive_generic() function has been made a bit safer to
>  call from inside a process.  "git am -3" was taught to make a direct
>  call to the function when falling back to three-way merge.
> 
>  Being able to make a direct call would be good in general, but as a
>  performance thing, the change needs to be backed up by numbers.
> 
>  I haven't gone through the "gently" change with fine toothed comb;
>  I can see that the change avoids calling die(), but I haven't made
>  sure that the program states (e.g. what's in the in-core index) are
>  adjusted sensibly when it returns to the caller instead of dying,
>  or the codepaths that used to die() are free of resource leaks.
>  The original code certainly did not care the program states at the
>  point of dying exactly because it knew it is going to exit, but now
>  they have to care, and they need to be audited.
> 
>  Will be rerolled.
>  ($gmane/292205)
> 
> 
> * dk/gc-more-wo-pack (2016-01-13) 4 commits
>  - gc: clean garbage .bitmap files from pack dir
>  - t5304: ensure non-garbage files are not deleted
>  - t5304: test .bitmap garbage files
>  - prepare_packed_git(): find more garbage
> 
>  Follow-on to dk/gc-idx-wo-pack topic, to clean up stale
>  .bitmap and .keep files.
> 
>  Waiting for a reroll.
>  ($gmane/284368).
> 
> 
> * jc/diff-b-m (2015-02-23) 5 commits
>  . WIPWIP
>  . WIP: diff-b-m
>  - diffcore-rename: allow easier debugging
>  - diffcore-rename.c: add locate_rename_src()
>  - diffcore-break: allow debugging
> 
>  "git diff -B -M" produced incorrect patch when the postimage of a
>  completely rewritten file is similar to the preimage of a removed
>  file; such a resulting file must not be expressed as a rename from
>  other place.
> 
>  The fix in this patch is broken, unfortunately.
>  Will discard.
> 
> 
> * jc/merge-impossible-no-commit (2016-04-26) 2 commits
>  - merge: warn --no-commit merge when no new commit is created
>  - merge: do not contaminate option_commit with --squash
> 
>  "git merge --no-commit" silently succeeded when there is no need to
>  create any commit, either when you are more recent than the commit
>  you tried to merge, or you can fast-forward to the commit you tried
>  to merge.  The command gives a warning message in such cases.
> 
>  Just tying loose ends in a discussion.  Unless somebody else
>  champions this topic, I'll drop it.
> 
>  Will discard.
> 
> --------------------------------------------------
> [Cooking]
> 
> * nd/shallow-deepen (2016-06-13) 27 commits
>  - fetch, upload-pack: --deepen=N extends shallow boundary by N commits
>  - upload-pack: add get_reachable_list()
>  - upload-pack: split check_unreachable() in two, prep for get_reachable_list()
>  - t5500, t5539: tests for shallow depth excluding a ref
>  - clone: define shallow clone boundary with --shallow-exclude
>  - fetch: define shallow boundary with --shallow-exclude
>  - upload-pack: support define shallow boundary by excluding revisions
>  - refs: add expand_ref()
>  - t5500, t5539: tests for shallow depth since a specific date
>  - clone: define shallow clone boundary based on time with --shallow-since
>  - fetch: define shallow boundary with --shallow-since
>  - upload-pack: add deepen-since to cut shallow repos based on time
>  - shallow.c: implement a generic shallow boundary finder based on rev-list
>  - fetch-pack: use a separate flag for fetch in deepening mode
>  - fetch-pack.c: mark strings for translating
>  - fetch-pack: use a common function for verbose printing
>  - fetch-pack: use skip_prefix() instead of starts_with()
>  - upload-pack: move rev-list code out of check_non_tip()
>  - upload-pack: make check_non_tip() clean things up on error
>  - upload-pack: tighten number parsing at "deepen" lines
>  - upload-pack: use skip_prefix() instead of starts_with()
>  - upload-pack: move "unshallow" sending code out of deepen()
>  - upload-pack: remove unused variable "backup"
>  - upload-pack: move "shallow" sending code out of deepen()
>  - upload-pack: move shallow deepen code out of receive_needs()
>  - transport-helper.c: refactor set_helper_option()
>  - remote-curl.c: convert fetch_git() to use argv_array
> 
>  The existing "git fetch --depth=<n>" option was hard to use
>  correctly when making the history of an existing shallow clone
>  deeper.  A new option, "--deepen=<n>", has been added to make this
>  easier to use.  "git clone" also learned "--shallow-since=<date>"
>  and "--shallow-exclude=<tag>" options to make it easier to specify
>  "I am interested only in the recent N months worth of history" and
>  "Give me only the history since that version".
> 
>  Rerolled.
> 
> 
> * jk/avoid-unbounded-alloca (2016-06-07) 1 commit
>  - tree-diff: avoid alloca for large allocations
> 
>  Will merge to 'next'.
> 
> 
> * jk/send-pack-stdio (2016-06-10) 2 commits
>  - write_or_die: remove the unused write_or_whine() function
>  - send-pack: use buffered I/O to talk to pack-objects
> 
>  Code clean-up.
> 
>  Will merge to 'next'.
> 
> 
> * pb/commit-editmsg-path (2016-06-09) 1 commit
>  - builtin/commit.c: memoize git-path for COMMIT_EDITMSG
> 
>  Code clean-up.
> 
>  Will merge to 'next'.
> 
> 
> * wd/userdiff-css (2016-06-03) 1 commit
>   (merged to 'next' on 2016-06-06 at 536102f)
>  + userdiff: add built-in pattern for CSS
> 
>  Update the funcname definition to support css files.
> 
>  Will merge to 'master' after 2.9 final.
> 
> 
> * jc/attr-more (2016-06-09) 8 commits
>  - attr.c: outline the future plans by heavily commenting
>  - attr.c: always pass check[] to collect_some_attrs()
>  - attr.c: introduce empty_attr_check_elems()
>  - attr.c: correct ugly hack for git_all_attrs()
>  - attr.c: rename a local variable check
>  - fixup! d5ad6c13
>  - attr.c: pass struct git_attr_check down the callchain
>  - attr.c: add push_stack() helper
>  (this branch uses jc/attr; is tangled with sb/pathspec-label and sb/submodule-default-paths.)
> 
>  The beginning of long and tortuous journey to clean-up attribute
>  subsystem implementation.
> 
> 
> * jk/rev-list-count-with-bitmap (2016-06-03) 2 commits
>   (merged to 'next' on 2016-06-06 at dd9b30f)
>  + rev-list: disable bitmaps when "-n" is used with listing objects
>  + rev-list: "adjust" results of "--count --use-bitmap-index -n"
> 
>  "git rev-list --count" whose walk-length is limited with "-n"
>  option did not work well with the counting optimized to look at the
>  bitmap index.
> 
>  Will merge to 'master' after 2.9 final.
> 
> 
> * mh/ref-iterators (2016-06-03) 13 commits
>   (merged to 'next' on 2016-06-06 at c8e79dc)
>  + for_each_reflog(): reimplement using iterators
>  + dir_iterator: new API for iterating over a directory tree
>  + for_each_reflog(): don't abort for bad references
>  + do_for_each_ref(): reimplement using reference iteration
>  + refs: introduce an iterator interface
>  + ref_resolves_to_object(): new function
>  + entry_resolves_to_object(): rename function from ref_resolves_to_object()
>  + get_ref_cache(): only create an instance if there is a submodule
>  + remote rm: handle symbolic refs correctly
>  + delete_refs(): add a flags argument
>  + refs: use name "prefix" consistently
>  + do_for_each_ref(): move docstring to the header file
>  + refs: remove unnecessary "extern" keywords
>  (this branch is used by mh/ref-store; uses mh/split-under-lock; is tangled with mh/update-ref-errors.)
> 
>  The API to iterate over all the refs (i.e. for_each_ref(), etc.)
>  has been revamped.
> 
>  Will merge to 'master' after 2.9 final.
> 
> 
> * ew/mboxrd-format-am (2016-06-06) 3 commits
>  - am: support --patch-format=mboxrd
>  - mailsplit: support unescaping mboxrd messages
>  - pretty: support "mboxrd" output format
> 
>  Teach format-patch and mailsplit (hence "am") how a line that
>  happens to begin with "From " in the e-mail message is quoted with
>  ">", so that these lines can be restored to their original shape.
> 
> 
> * lf/receive-pack-auto-gc-to-client (2016-06-06) 1 commit
>  - receive-pack: send auto-gc output over sideband 2
> 
>  Allow messages that are generated by auto gc during "git push" on
>  the receiving end to be explicitly passed back to the sending end
>  over sideband, so that they are shown with "remote: " prefix to
>  avoid confusing the users.
> 
> 
> * mg/cherry-pick-multi-on-unborn (2016-06-06) 1 commit
>  - cherry-pick: allow to pick to unborn branches
> 
>  "git cherry-pick A" worked on an unborn branch, but "git
>  cherry-pick A..B" didn't.
> 
> 
> * mj/log-show-signature-conf (2016-06-06) 2 commits
>  - log: "--no-show-signature" commmand-line option
>  - log: add "log.showsignature" configuration variable
> 
>  "git log" learns log.showSignature configuration variable, and a
>  command line option "--no-show-signature" to countermand it.
> 
>  The order of the commits in the topic need to be reversed.
> 
> 
> * nd/i-t-a-commitable (2016-06-06) 3 commits
>  - commit: don't count i-t-a entries when checking if the new commit is empty
>  - Resurrect "diff-lib.c: adjust position of i-t-a entries in diff"
>  - diff.h: extend "flags" field to 64 bits because we're out of bits
> 
>  "rm .git/index && git add -N * && git commit" allows you to create
>  an empty commit without --allow-empty; attempt to forbid it.
> 
>  Breaks many tests by completely butchering "git commit", it seems.
> 
> 
> * sg/reflog-past-root (2016-06-06) 1 commit
>  - reflog: continue walking the reflog past root commits
> 
>  "git reflog" stopped upon seeing an entry that denotes a branch
>  creation event (aka "unborn"), which made it appear as if the
>  reflog was truncated.
> 
> 
> * tb/complete-status (2016-06-10) 3 commits
>  - completion: add git status
>  - completion: add __git_get_option_value helper
>  - completion: factor out untracked file modes into a variable
> 
>  The completion script (in contrib/) learned to complete "git
>  status" options.
> 
> 
> * tr/doc-tt (2016-06-08) 4 commits
>  - doc: change configuration variables format
>  - doc: more consistency in environment variables format
>  - doc: change environment variables format
>  - doc: clearer rule about formatting literals
> 
>  The documentation set has been updated so that literal commands,
>  configuration variables and environment variables are consistently
>  typeset in fixed-width font and bold in manpages.
> 
>  Will merge to 'next'.
> 
> 
> * vs/prompt-avoid-unset-variable (2016-06-06) 1 commit
>  - git-prompt.sh: Don't error on null ${ZSH,BASH}_VERSION, $short_sha
> 
>  The git-prompt scriptlet (in contrib/) was not friendly with those
>  who uses "set -u", which has been fixed.
> 
> 
> * rj/compat-regex-size-max-fix (2016-06-06) 1 commit
>  - regex: fix a SIZE_MAX macro redefinition warning
> 
>  A compilation fix.
> 
>  Will merge to 'next'.
> 
> 
> * bc/cocci-object-id (2016-06-06) 8 commits
>  - merge-recursive: convert merge_recursive_generic to object_id
>  - merge-recursive: convert leaf functions to use struct object_id
>  - merge-recursive: convert struct merge_file_info to object_id
>  - merge-recursive: convert struct stage_data to use object_id
>  - Rename struct diff_filespec's sha1_valid member.
>  - Convert struct diff_filespec to struct object_id
>  - Apply standard object_id Coccinelle transformations.
>  - Add basic Coccinelle transforms.
> 
>  Move from "unsigned char [20]" to "struct object_id" continues,
>  with help from an automated tool.
> 
> 
> * et/add-chmod-x (2016-06-07) 1 commit
>  - add: add --chmod=+x / --chmod=-x options
> 
>  "git update-index --add --chmod=+x file" may be usable as an escape
>  hatch, but not a friendly thing to force for people who do need to
>  use it regularly.  "git add --chmod=+x file" can be used instead.
> 
>  Will merge to 'next'.
> 
> 
> * mh/connect (2016-06-06) 10 commits
>  - connect: [host:port] is legacy for ssh
>  - connect: move ssh command line preparation to a separate function
>  - connect: actively reject git:// urls with a user part
>  - connect: change the --diag-url output to separate user and host
>  - connect: make parse_connect_url() return the user part of the url as a separate value
>  - connect: group CONNECT_DIAG_URL handling code
>  - connect: make parse_connect_url() return separated host and port
>  - connect: re-derive a host:port string from the separate host and port variables
>  - connect: call get_host_and_port() earlier
>  - connect: document why we sometimes call get_port after get_host_and_port
> 
>  Ok, folks, is everybody happy with this version?

$gmane/296609
$gmane/296610

Mike

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: What's cooking in git.git (Jun 2016, #04; Tue, 14)
  2016-06-14 22:08 What's cooking in git.git (Jun 2016, #04; Tue, 14) Junio C Hamano
  2016-06-15  2:36 ` Mike Hommey
@ 2016-06-15  7:35 ` Elia Pinto
  2016-06-16 12:36   ` Jeff King
  2016-06-15 10:12 ` Duy Nguyen
  2 siblings, 1 reply; 9+ messages in thread
From: Elia Pinto @ 2016-06-15  7:35 UTC (permalink / raw)
  To: Junio C Hamano, Eric Sunshine, Jeff King, Ramsay Jones,
	Torsten Bögershausen
  Cc: git

2016-06-15 0:08 GMT+02:00 Junio C Hamano <gitster@pobox.com>:
> Here are the topics that have been cooking.  Commits prefixed with
> '-' are only in 'pu' (proposed updates) while commits prefixed with
> '+' are in 'next'.  The ones marked with '.' do not appear in any of
> the integration branches, but I am still holding onto them.
>
> Git 2.9 has been tagged.  Let's wait for a few days to clean up
> possible fallout and then start a new cycle by rewinding the tip of
> 'next'.  I expect I'd eject a few premature topics out of 'next'
> while doing so.
>
> You can find the changes described here in the integration branches
> of the repositories listed at
>
>     http://git-blame.blogspot.com/p/git-public-repositories.html
>
> --------------------------------------------------
> [Graduated to "master"]
>
> * jc/t2300-setup (2016-06-01) 1 commit
>   (merged to 'next' on 2016-06-06 at 20f7f83)
>  + t2300: run git-sh-setup in an environment that better mimics the real life
>  (this branch is used by va/i18n-even-more.)
>
>  A test fix.
>
>
> * jk/diff-compact-heuristic (2016-06-10) 1 commit
>  - diff: disable compaction heuristic for now
>
>  It turns out that the earlier effort to update the heuristics may
>  want to use a bit more time to mature.  Turn it off by default.
>
>
> * jk/shell-portability (2016-06-01) 2 commits
>   (merged to 'next' on 2016-06-06 at 5de784e)
>  + t5500 & t7403: lose bash-ism "local"
>  + test-lib: add in-shell "env" replacement
>
>  test fixes.
>
> --------------------------------------------------
> [New Topics]
>
> * lv/status-say-working-tree-not-directory (2016-06-09) 1 commit
>  - Use "working tree" instead of "working directory" for git status
>
>  "git status" used to say "working directory" when it meant "working
>  tree".
>
>  Will merge to 'next'.
>
>
> * jk/parseopt-string-list (2016-06-13) 3 commits
>  - blame,shortlog: don't make local option variables static
>  - interpret-trailers: don't duplicate option strings
>  - parse_opt_string_list: stop allocating new strings
>  (this branch is used by jk/string-list-static-init.)
>
>  The command line argument parsing that uses OPT_STRING_LIST() often
>  made a copy of the argv[] element, which was unnecessary.
>
>  Will merge to 'next'.
>
>
> * jk/repack-keep-unreachable (2016-06-14) 3 commits
>  - repack: extend --keep-unreachable to loose objects
>  - repack: add --keep-unreachable option
>  - repack: document --unpack-unreachable option
>
>  "git repack" learned the "--keep-unreachable" option, which sends
>  loose unreachable objects to a pack instead of leaving them loose.
>  This helps heuristics based on the number of loose objects
>  (e.g. "gc --auto").
>
>  Will merge to 'next'.
>
>
> * lf/recv-sideband-cleanup (2016-06-13) 1 commit
>  - sideband.c: refactor recv_sideband()
>
>  Code simplification.  It however loses the atomicity of the output
>  9ac13ec9 (atomic write for sideband remote messages, 2006-10-11)
>  tried to add to an once-much-simpler codebase.
>
>  Expecting a reroll.
>
>
> * nd/test-lib-httpd-show-error-log-in-verbose (2016-06-13) 1 commit
>  - lib-httpd.sh: print error.log on error
>
>  Debugging aid.
>
>  Will merge to 'next'.
>
>
> * pc/occurred (2016-06-10) 2 commits
>  - config.c: fix misspelt "occurred" in an error message
>  - refs.h: fix misspelt "occurred" in a comment
>
>  Will merge to 'next'.
>
>
> * sb/submodule-clone-retry (2016-06-13) 2 commits
>  - submodule update: continue when a clone fails
>  - submodule--helper: initial clone learns retry logic
>  (this branch uses sb/submodule-recommend-shallowness.)
>
>  "git submodule update" that drives many "git clone" could
>  eventually hit flaky servers/network conditions on one of the
>  submodules; the command learned to retry the attempt.
>
>
> * jc/blame-reverse (2016-06-14) 2 commits
>  - blame: dwim "blame --reverse OLD" as "blame --reverse OLD.."
>  - blame: improve diagnosis for "--reverse NEW"
>
>
> * jc/deref-tag (2016-06-14) 1 commit
>  - blame, line-log: do not loop around deref_tag()
>
>  Code clean-up.
>
>  Will merge to 'next'.
>
>
> * jk/fetch-prune-doc (2016-06-14) 1 commit
>  - fetch: document that pruning happens before fetching
>
>  Will merge to 'next'.
>
>
> * km/fetch-do-not-free-remote-name (2016-06-14) 1 commit
>  - builtin/fetch.c: don't free remote->name after fetch
>
>  Will merge to 'next'.
>
>
> * nb/gnome-keyring-build (2016-06-14) 1 commit
>  - gnome-keyring: Don't hard-code pkg-config executable
>
>  Build improvements for gnome-keyring (in contrib/)
>
>  Will merge to 'next'.
>
>
> * pb/strbuf-read-file-doc (2016-06-14) 1 commit
>  - strbuf: describe the return value of strbuf_read_file
>
>  Will merge to 'next'.
>
> --------------------------------------------------
> [Stalled]
>
> * sb/bisect (2016-04-15) 22 commits
>  - SQUASH???
>  - bisect: get back halfway shortcut
>  - bisect: compute best bisection in compute_relevant_weights()
>  - bisect: use a bottom-up traversal to find relevant weights
>  - bisect: prepare for different algorithms based on find_all
>  - bisect: rename count_distance() to compute_weight()
>  - bisect: make total number of commits global
>  - bisect: introduce distance_direction()
>  - bisect: extract get_distance() function from code duplication
>  - bisect: use commit instead of commit list as arguments when appropriate
>  - bisect: replace clear_distance() by unique markers
>  - bisect: use struct node_data array instead of int array
>  - bisect: get rid of recursion in count_distance()
>  - bisect: make algorithm behavior independent of DEBUG_BISECT
>  - bisect: make bisect compile if DEBUG_BISECT is set
>  - bisect: plug the biggest memory leak
>  - bisect: add test for the bisect algorithm
>  - t6030: generalize test to not rely on current implementation
>  - t: use test_cmp_rev() where appropriate
>  - t/test-lib-functions.sh: generalize test_cmp_rev
>  - bisect: allow 'bisect run' if no good commit is known
>  - bisect: write about `bisect next` in documentation
>
>  The internal algorithm used in "git bisect" to find the next commit
>  to check has been optimized greatly.
>
>  Expecting a reroll.
>  ($gmane/291163)
>
>
> * sg/completion-updates (2016-02-28) 21 commits
>  . completion: cache the path to the repository
>  . completion: extract repository discovery from __gitdir()
>  . completion: don't guard git executions with __gitdir()
>  . completion: consolidate silencing errors from git commands
>  . completion: don't use __gitdir() for git commands
>  . completion: respect 'git -C <path>'
>  . completion: fix completion after 'git -C <path>'
>  . completion: don't offer commands when 'git --opt' needs an argument
>  . rev-parse: add '--absolute-git-dir' option
>  . completion: list short refs from a remote given as a URL
>  . completion: don't list 'HEAD' when trying refs completion outside of a repo
>  . completion: list refs from remote when remote's name matches a directory
>  . completion: respect 'git --git-dir=<path>' when listing remote refs
>  . completion: fix most spots not respecting 'git --git-dir=<path>'
>  . completion: ensure that the repository path given on the command line exists
>  . completion tests: add tests for the __git_refs() helper function
>  . completion tests: check __gitdir()'s output in the error cases
>  . completion tests: consolidate getting path of current working directory
>  . completion tests: make the $cur variable local to the test helper functions
>  . completion tests: don't add test cruft to the test repository
>  . completion: improve __git_refs()'s in-code documentation
>
>  Will be rerolled.
>  ($gmane/287839)
>
>
> * az/p4-bare-no-rebase (2016-02-19) 1 commit
>  - git-p4.py: Don't try to rebase on submit from bare repository
>
>  "git p4 submit" attempts to do a rebase, which would fail if done
>  in a bare repository.  Not doing this rebase would paper over the
>  failure, which is what this patch does, but it is unclear what the
>  side effect of not rebasing is.
>
>  Needs a better explanation.
>
>
> * nd/icase (2016-02-15) 12 commits
>  - grep.c: reuse "icase" variable
>  - diffcore-pickaxe: support case insensitive match on non-ascii
>  - diffcore-pickaxe: "share" regex error handling code
>  - grep/pcre: support utf-8
>  - gettext: add is_utf8_locale()
>  - grep/pcre: prepare locale-dependent tables for icase matching
>  - grep/icase: avoid kwsset when -F is specified
>  - grep/icase: avoid kwsset on literal non-ascii strings
>  - test-regex: expose full regcomp() to the command line
>  - test-regex: isolate the bug test code
>  - grep: break down an "if" stmt in preparation for next changes
>  - grep: allow -F -i combination
>
>  "git grep -i" has been taught to fold case in non-ascii locales.
>
>  Needs review.
>  ($gmane/286137)
>
>
> * ec/annotate-deleted (2015-11-20) 1 commit
>  - annotate: skip checking working tree if a revision is provided
>
>  Usability fix for annotate-specific "<file> <rev>" syntax with deleted
>  files.
>
>  Waiting for review.
>
>
> * dg/subtree-rebase-test (2016-01-19) 1 commit
>  - contrib/subtree: Add a test for subtree rebase that loses commits
>
>  Reviewed up to v5.
>  Will be rerolled.
>  ($gmane/284426)
>
>
> * js/am-3-merge-recursive-direct (2015-10-12) 2 commits
>  - am: make a direct call to merge_recursive
>  - merge_recursive_options: introduce the "gently" flag
>
>  The merge_recursive_generic() function has been made a bit safer to
>  call from inside a process.  "git am -3" was taught to make a direct
>  call to the function when falling back to three-way merge.
>
>  Being able to make a direct call would be good in general, but as a
>  performance thing, the change needs to be backed up by numbers.
>
>  I haven't gone through the "gently" change with fine toothed comb;
>  I can see that the change avoids calling die(), but I haven't made
>  sure that the program states (e.g. what's in the in-core index) are
>  adjusted sensibly when it returns to the caller instead of dying,
>  or the codepaths that used to die() are free of resource leaks.
>  The original code certainly did not care the program states at the
>  point of dying exactly because it knew it is going to exit, but now
>  they have to care, and they need to be audited.
>
>  Will be rerolled.
>  ($gmane/292205)
>
>
> * dk/gc-more-wo-pack (2016-01-13) 4 commits
>  - gc: clean garbage .bitmap files from pack dir
>  - t5304: ensure non-garbage files are not deleted
>  - t5304: test .bitmap garbage files
>  - prepare_packed_git(): find more garbage
>
>  Follow-on to dk/gc-idx-wo-pack topic, to clean up stale
>  .bitmap and .keep files.
>
>  Waiting for a reroll.
>  ($gmane/284368).
>
>
> * jc/diff-b-m (2015-02-23) 5 commits
>  . WIPWIP
>  . WIP: diff-b-m
>  - diffcore-rename: allow easier debugging
>  - diffcore-rename.c: add locate_rename_src()
>  - diffcore-break: allow debugging
>
>  "git diff -B -M" produced incorrect patch when the postimage of a
>  completely rewritten file is similar to the preimage of a removed
>  file; such a resulting file must not be expressed as a rename from
>  other place.
>
>  The fix in this patch is broken, unfortunately.
>  Will discard.
>
>
> * jc/merge-impossible-no-commit (2016-04-26) 2 commits
>  - merge: warn --no-commit merge when no new commit is created
>  - merge: do not contaminate option_commit with --squash
>
>  "git merge --no-commit" silently succeeded when there is no need to
>  create any commit, either when you are more recent than the commit
>  you tried to merge, or you can fast-forward to the commit you tried
>  to merge.  The command gives a warning message in such cases.
>
>  Just tying loose ends in a discussion.  Unless somebody else
>  champions this topic, I'll drop it.
>
>  Will discard.
>
> --------------------------------------------------
> [Cooking]
>
> * nd/shallow-deepen (2016-06-13) 27 commits
>  - fetch, upload-pack: --deepen=N extends shallow boundary by N commits
>  - upload-pack: add get_reachable_list()
>  - upload-pack: split check_unreachable() in two, prep for get_reachable_list()
>  - t5500, t5539: tests for shallow depth excluding a ref
>  - clone: define shallow clone boundary with --shallow-exclude
>  - fetch: define shallow boundary with --shallow-exclude
>  - upload-pack: support define shallow boundary by excluding revisions
>  - refs: add expand_ref()
>  - t5500, t5539: tests for shallow depth since a specific date
>  - clone: define shallow clone boundary based on time with --shallow-since
>  - fetch: define shallow boundary with --shallow-since
>  - upload-pack: add deepen-since to cut shallow repos based on time
>  - shallow.c: implement a generic shallow boundary finder based on rev-list
>  - fetch-pack: use a separate flag for fetch in deepening mode
>  - fetch-pack.c: mark strings for translating
>  - fetch-pack: use a common function for verbose printing
>  - fetch-pack: use skip_prefix() instead of starts_with()
>  - upload-pack: move rev-list code out of check_non_tip()
>  - upload-pack: make check_non_tip() clean things up on error
>  - upload-pack: tighten number parsing at "deepen" lines
>  - upload-pack: use skip_prefix() instead of starts_with()
>  - upload-pack: move "unshallow" sending code out of deepen()
>  - upload-pack: remove unused variable "backup"
>  - upload-pack: move "shallow" sending code out of deepen()
>  - upload-pack: move shallow deepen code out of receive_needs()
>  - transport-helper.c: refactor set_helper_option()
>  - remote-curl.c: convert fetch_git() to use argv_array
>
>  The existing "git fetch --depth=<n>" option was hard to use
>  correctly when making the history of an existing shallow clone
>  deeper.  A new option, "--deepen=<n>", has been added to make this
>  easier to use.  "git clone" also learned "--shallow-since=<date>"
>  and "--shallow-exclude=<tag>" options to make it easier to specify
>  "I am interested only in the recent N months worth of history" and
>  "Give me only the history since that version".
>
>  Rerolled.
>
>
> * jk/avoid-unbounded-alloca (2016-06-07) 1 commit
>  - tree-diff: avoid alloca for large allocations
>
>  Will merge to 'next'.
>
>
> * jk/send-pack-stdio (2016-06-10) 2 commits
>  - write_or_die: remove the unused write_or_whine() function
>  - send-pack: use buffered I/O to talk to pack-objects
>
>  Code clean-up.
>
>  Will merge to 'next'.
>
>
> * pb/commit-editmsg-path (2016-06-09) 1 commit
>  - builtin/commit.c: memoize git-path for COMMIT_EDITMSG
>
>  Code clean-up.
>
>  Will merge to 'next'.
>
>
> * wd/userdiff-css (2016-06-03) 1 commit
>   (merged to 'next' on 2016-06-06 at 536102f)
>  + userdiff: add built-in pattern for CSS
>
>  Update the funcname definition to support css files.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * jc/attr-more (2016-06-09) 8 commits
>  - attr.c: outline the future plans by heavily commenting
>  - attr.c: always pass check[] to collect_some_attrs()
>  - attr.c: introduce empty_attr_check_elems()
>  - attr.c: correct ugly hack for git_all_attrs()
>  - attr.c: rename a local variable check
>  - fixup! d5ad6c13
>  - attr.c: pass struct git_attr_check down the callchain
>  - attr.c: add push_stack() helper
>  (this branch uses jc/attr; is tangled with sb/pathspec-label and sb/submodule-default-paths.)
>
>  The beginning of long and tortuous journey to clean-up attribute
>  subsystem implementation.
>
>
> * jk/rev-list-count-with-bitmap (2016-06-03) 2 commits
>   (merged to 'next' on 2016-06-06 at dd9b30f)
>  + rev-list: disable bitmaps when "-n" is used with listing objects
>  + rev-list: "adjust" results of "--count --use-bitmap-index -n"
>
>  "git rev-list --count" whose walk-length is limited with "-n"
>  option did not work well with the counting optimized to look at the
>  bitmap index.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * mh/ref-iterators (2016-06-03) 13 commits
>   (merged to 'next' on 2016-06-06 at c8e79dc)
>  + for_each_reflog(): reimplement using iterators
>  + dir_iterator: new API for iterating over a directory tree
>  + for_each_reflog(): don't abort for bad references
>  + do_for_each_ref(): reimplement using reference iteration
>  + refs: introduce an iterator interface
>  + ref_resolves_to_object(): new function
>  + entry_resolves_to_object(): rename function from ref_resolves_to_object()
>  + get_ref_cache(): only create an instance if there is a submodule
>  + remote rm: handle symbolic refs correctly
>  + delete_refs(): add a flags argument
>  + refs: use name "prefix" consistently
>  + do_for_each_ref(): move docstring to the header file
>  + refs: remove unnecessary "extern" keywords
>  (this branch is used by mh/ref-store; uses mh/split-under-lock; is tangled with mh/update-ref-errors.)
>
>  The API to iterate over all the refs (i.e. for_each_ref(), etc.)
>  has been revamped.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * ew/mboxrd-format-am (2016-06-06) 3 commits
>  - am: support --patch-format=mboxrd
>  - mailsplit: support unescaping mboxrd messages
>  - pretty: support "mboxrd" output format
>
>  Teach format-patch and mailsplit (hence "am") how a line that
>  happens to begin with "From " in the e-mail message is quoted with
>  ">", so that these lines can be restored to their original shape.
>
>
> * lf/receive-pack-auto-gc-to-client (2016-06-06) 1 commit
>  - receive-pack: send auto-gc output over sideband 2
>
>  Allow messages that are generated by auto gc during "git push" on
>  the receiving end to be explicitly passed back to the sending end
>  over sideband, so that they are shown with "remote: " prefix to
>  avoid confusing the users.
>
>
> * mg/cherry-pick-multi-on-unborn (2016-06-06) 1 commit
>  - cherry-pick: allow to pick to unborn branches
>
>  "git cherry-pick A" worked on an unborn branch, but "git
>  cherry-pick A..B" didn't.
>
>
> * mj/log-show-signature-conf (2016-06-06) 2 commits
>  - log: "--no-show-signature" commmand-line option
>  - log: add "log.showsignature" configuration variable
>
>  "git log" learns log.showSignature configuration variable, and a
>  command line option "--no-show-signature" to countermand it.
>
>  The order of the commits in the topic need to be reversed.
>
>
> * nd/i-t-a-commitable (2016-06-06) 3 commits
>  - commit: don't count i-t-a entries when checking if the new commit is empty
>  - Resurrect "diff-lib.c: adjust position of i-t-a entries in diff"
>  - diff.h: extend "flags" field to 64 bits because we're out of bits
>
>  "rm .git/index && git add -N * && git commit" allows you to create
>  an empty commit without --allow-empty; attempt to forbid it.
>
>  Breaks many tests by completely butchering "git commit", it seems.
>
>
> * sg/reflog-past-root (2016-06-06) 1 commit
>  - reflog: continue walking the reflog past root commits
>
>  "git reflog" stopped upon seeing an entry that denotes a branch
>  creation event (aka "unborn"), which made it appear as if the
>  reflog was truncated.
>
>
> * tb/complete-status (2016-06-10) 3 commits
>  - completion: add git status
>  - completion: add __git_get_option_value helper
>  - completion: factor out untracked file modes into a variable
>
>  The completion script (in contrib/) learned to complete "git
>  status" options.
>
>
> * tr/doc-tt (2016-06-08) 4 commits
>  - doc: change configuration variables format
>  - doc: more consistency in environment variables format
>  - doc: change environment variables format
>  - doc: clearer rule about formatting literals
>
>  The documentation set has been updated so that literal commands,
>  configuration variables and environment variables are consistently
>  typeset in fixed-width font and bold in manpages.
>
>  Will merge to 'next'.
>
>
> * vs/prompt-avoid-unset-variable (2016-06-06) 1 commit
>  - git-prompt.sh: Don't error on null ${ZSH,BASH}_VERSION, $short_sha
>
>  The git-prompt scriptlet (in contrib/) was not friendly with those
>  who uses "set -u", which has been fixed.
>
>
> * rj/compat-regex-size-max-fix (2016-06-06) 1 commit
>  - regex: fix a SIZE_MAX macro redefinition warning
>
>  A compilation fix.
>
>  Will merge to 'next'.
>
>
> * bc/cocci-object-id (2016-06-06) 8 commits
>  - merge-recursive: convert merge_recursive_generic to object_id
>  - merge-recursive: convert leaf functions to use struct object_id
>  - merge-recursive: convert struct merge_file_info to object_id
>  - merge-recursive: convert struct stage_data to use object_id
>  - Rename struct diff_filespec's sha1_valid member.
>  - Convert struct diff_filespec to struct object_id
>  - Apply standard object_id Coccinelle transformations.
>  - Add basic Coccinelle transforms.
>
>  Move from "unsigned char [20]" to "struct object_id" continues,
>  with help from an automated tool.
>
>
> * et/add-chmod-x (2016-06-07) 1 commit
>  - add: add --chmod=+x / --chmod=-x options
>
>  "git update-index --add --chmod=+x file" may be usable as an escape
>  hatch, but not a friendly thing to force for people who do need to
>  use it regularly.  "git add --chmod=+x file" can be used instead.
>
>  Will merge to 'next'.
>
>
> * mh/connect (2016-06-06) 10 commits
>  - connect: [host:port] is legacy for ssh
>  - connect: move ssh command line preparation to a separate function
>  - connect: actively reject git:// urls with a user part
>  - connect: change the --diag-url output to separate user and host
>  - connect: make parse_connect_url() return the user part of the url as a separate value
>  - connect: group CONNECT_DIAG_URL handling code
>  - connect: make parse_connect_url() return separated host and port
>  - connect: re-derive a host:port string from the separate host and port variables
>  - connect: call get_host_and_port() earlier
>  - connect: document why we sometimes call get_port after get_host_and_port
>
>  Ok, folks, is everybody happy with this version?
>
>
> * aq/upload-pack-use-parse-options (2016-05-31) 1 commit
>   (merged to 'next' on 2016-06-06 at 505f1ee)
>  + upload-pack.c: use parse-options API
>
>  "git upload-pack" command has been updated to use the parse-options
>  API.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * jc/clear-pathspec (2016-06-02) 1 commit
>   (merged to 'next' on 2016-06-06 at 9e7e291)
>  + pathspec: rename free_pathspec() to clear_pathspec()
>
>  We usually call a function that clears the contents a data
>  structure X without freeing the structure itself clear_X(), and
>  call a function that does clear_X() and also frees it free_X().
>  free_pathspec() function has been renamed to clear_pathspec()
>  to avoid confusion.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * sb/submodule-recommend-shallowness (2016-05-27) 2 commits
>   (merged to 'next' on 2016-05-31 at 1ee161c)
>  + submodule update: learn `--[no-]recommend-shallow` option
>  + submodule-config: keep shallow recommendation around
>  (this branch is used by sb/submodule-clone-retry.)
>
>  An upstream project can make a recommendation to make only a
>  shallow clone for some submodules in the .gitmodules file it ship.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * tb/convert-peek-in-index (2016-06-07) 3 commits
>  - correct ce_compare_data() in a middle of a merge
>  - read-cache: factor out get_sha1_from_index() helper
>  - convert: unify the "auto" handling of CRLF
>
>  Needs review.
>
>
> * va/i18n-even-more (2016-06-07) 38 commits
>  - i18n: branch: mark comment when editing branch description for translation
>  - i18n: unmark die messages for translation
>  - i18n: submodule: escape shell variables inside eval_gettext
>  - i18n: submodule: join strings marked for translation
>  - i18n: init-db: join message pieces
>  - i18n: remote: allow translations to reorder message
>  - i18n: remote: mark URL fallback text for translation
>  - i18n: standardise messages
>  - i18n: sequencer: add period to error message
>  - i18n: merge: change command option help to lowercase
>  - i18n: merge: mark messages for translation
>  - i18n: notes: mark options for translation
>  - i18n: notes: mark strings for translation
>  - i18n: transport-helper.c: change N_() call to _()
>  - i18n: bisect: mark strings for translation
>  - t5523: use test_i18ngrep for negation
>  - t4153: fix negated test_i18ngrep call
>  - t9003: become resilient to GETTEXT_POISON
>  - tests: unpack-trees: update to use test_i18n* functions
>  - tests: use test_i18n* functions to suppress false positives
>  - i18n: setup: mark strings for translation
>  - i18n: rebase-interactive: mark comments of squash for translation
>  - i18n: rebase-interactive: mark here-doc strings for translation
>  - i18n: rebase-interactive: mark strings for translation
>  - i18n: git-sh-setup.sh: mark strings for translation
>  - t6030: update to use test_i18ncmp
>  - i18n: bisect: simplify error message for i18n
>  - i18n: rebase: mark placeholder for translation
>  - i18n: rebase: fix marked string to use eval_gettext variant
>  - merge-octupus: use die shell function from git-sh-setup.sh
>  - i18n: merge-octopus: mark messages for translation
>  - i18n: sequencer: mark string for translation
>  - i18n: sequencer: mark entire sentences for translation
>  - i18n: transport: mark strings for translation
>  - i18n: advice: internationalize message for conflicts
>  - i18n: advice: mark string about detached head for translation
>  - i18n: builtin/remote.c: fix mark for translation
>  - Merge branch 'jc/t2300-setup' into HEAD
>
>  More markings of messages for i18n, with updates to various tests
>  to pass GETTEXT_POISON tests.
>
>  One patch from the original submission dropped due to conflicts
>  with other topics in flight.
>
>
> * jg/dash-is-last-branch-in-worktree-add (2016-05-31) 1 commit
>   (merged to 'next' on 2016-06-02 at 3959ef6)
>  + worktree: allow "-" short-hand for @{-1} in add command
>
>  "git worktree add" learned that '-' can be used as a short-hand for
>  "@{-1}", the previous branch.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * dk/blame-move-no-reason-for-1-line-context (2016-05-29) 1 commit
>  - blame: require 0 context lines while finding moved lines with -M
>
>  "git blame -M" missed a single line that was moved within the file.
>
>  We may want to squash a test or two to this commit.  Volunteers?
>
>
> * nd/worktree-lock (2016-06-13) 6 commits
>  - worktree.c: find_worktree() search by path suffix
>  - worktree: add "unlock" command
>  - worktree: add "lock" command
>  - worktree.c: add is_worktree_locked()
>  - worktree.c: add is_main_worktree()
>  - worktree.c: add find_worktree()
>  (this branch uses nd/worktree-cleanup-post-head-protection.)
>
>  "git worktree prune" protected worktrees that are marked as
>  "locked" by creating a file in a known location.  "git worktree"
>  command learned a dedicated command pair to create and remoev such
>  a file, so that the users do not have to do this with editor.
>
>  Ok, folks, is everybody happy with this version?
>
>
> * et/pretty-format-c-auto (2016-05-27) 1 commit
>   (merged to 'next' on 2016-05-31 at 1e9c920)
>  + format_commit_message: honor `color=auto` for `%C(auto)`
>
>  %C(auto) in a custom format string that commands in `git log`
>  family takes unconditionally turned the color on, ignoring
>  --no-color or --color=auto with output not connected to a tty;
>  this was corrected to make the format truly behave as "auto".
>
>  Will merge to 'master' after 2.9 final.
>
>
> * ew/daemon-socket-keepalive (2016-05-25) 1 commit
>   (merged to 'next' on 2016-05-31 at c32acf1)
>  + daemon: enable SO_KEEPALIVE for all sockets
>
>  When "git daemon" is run without --[init-]timeout specified, a
>  connection from a client that silently goes offline can hang around
>  for a long time, wasting resources.  The socket-level KEEPALIVE has
>  been enabled to allow the OS to notice such failed connections.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * jk/upload-pack-hook (2016-06-02) 7 commits
>  - upload-pack: provide a hook for running pack-objects
>  - t1308: do not get fooled by symbolic links to the source tree
>  - config: add a notion of "scope"
>  - config: return configset value for current_config_ functions
>  - config: set up config_source for command-line config
>  - git_config_parse_parameter: refactor cleanup code
>  - git_config_with_options: drop "found" counting
>
>  Allow a custom "git upload-pack" replacement to respond to
>  "fetch/clone" request.
>
>  Still under discussion.
>  ($gmane/295705).
>
>
> * rs/xdiff-hunk-with-func-line (2016-06-09) 9 commits
>   (merged to 'next' on 2016-06-10 at 9ff9ba8)
>  + xdiff: fix merging of appended hunk with -W
>   (merged to 'next' on 2016-06-02 at 0c2e335)
>  + grep: -W: don't extend context to trailing empty lines
>  + t7810: add test for grep -W and trailing empty context lines
>  + xdiff: don't trim common tail with -W
>  + xdiff: -W: don't include common trailing empty lines in context
>  + xdiff: ignore empty lines before added functions with -W
>  + xdiff: handle appended chunks better with -W
>  + xdiff: factor out match_func_rec()
>  + t4051: rewrite, add more tests
>
>  "git show -W" (extend hunks to cover the entire function, delimited
>  by lines that match the "funcname" pattern) used to show the entire
>  file when a change added an entire function at the end of the file,
>  which has been fixed.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * sb/submodule-misc-cleanups (2016-05-25) 1 commit
>   (merged to 'next' on 2016-05-31 at 0d07b9c)
>  + submodule update: make use of the existing fetch_in_submodule function
>
>  Minor simplification.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * sb/submodule-default-paths (2016-06-14) 8 commits
>  - completion: clone can recurse into submodules
>  - clone: add --init-submodule=<pathspec> switch
>  - submodule update: add `--init-default-path` switch
>  - Merge branch 'sb/pathspec-label' into sb/submodule-default-paths
>  - Merge branch 'jc/attr' into sb/submodule-default-paths
>  - Merge branch 'sb/clone-shallow-passthru' into sb/submodule-default-paths
>  - Merge branch 'sb/submodule-deinit-all' into sb/submodule-default-paths
>  - Merge branch 'sb/submodule-parallel-update' into sb/submodule-default-paths
>  (this branch uses jc/attr and sb/pathspec-label; is tangled with jc/attr-more.)
>
>  Will hold.
>
>
> * ah/no-verify-signature-with-pull-rebase (2016-05-20) 1 commit
>   (merged to 'next' on 2016-05-31 at 30add83)
>  + pull: warn on --verify-signatures with --rebase
>
>  "git pull --rebase --verify-signature" learned to warn the user
>  that "--verify-signature" is a no-op.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * ep/http-curl-trace (2016-05-24) 2 commits
>  - imap-send.c: introduce the GIT_TRACE_CURL enviroment variable
>  - http.c: implement the GIT_TRACE_CURL environment variable
>
>  HTTP transport gained an option to produce more detailed debugging
>  trace.
>
>  Rerolled.  Is everybody happy with this version?
>
The refs is there
http://git.661346.n2.nabble.com/PATCH-v7-0-2-Implement-the-GIT-TRACE-CURL-environment-variable-td7657079.html

If  kindly someone who has reviewed and helped me to do the patch
could give an ack (or a nack eventually). Thanks in advance



>
> * jc/attr (2016-05-25) 18 commits
>   (merged to 'next' on 2016-05-31 at 5b2f08b)
>  + attr: support quoting pathname patterns in C style
>  + attr: expose validity check for attribute names
>  + attr: add counted string version of git_attr()
>  + attr: add counted string version of git_check_attr()
>  + attr: retire git_check_attrs() API
>  + attr: convert git_check_attrs() callers to use the new API
>  + attr: convert git_all_attrs() to use "struct git_attr_check"
>  + attr: (re)introduce git_check_attr() and struct git_attr_check
>  + attr: rename function and struct related to checking attributes
>  + attr.c: plug small leak in parse_attr_line()
>  + attr.c: tighten constness around "git_attr" structure
>  + attr.c: simplify macroexpand_one()
>  + attr.c: mark where #if DEBUG ends more clearly
>  + attr.c: complete a sentence in a comment
>  + attr.c: explain the lack of attr-name syntax check in parse_attr()
>  + attr.c: update a stale comment on "struct match_attr"
>  + attr.c: use strchrnul() to scan for one line
>  + commit.c: use strchrnul() to scan for one line
>  (this branch is used by jc/attr-more, sb/pathspec-label and sb/submodule-default-paths.)
>
>  The attributes API has been updated so that it can later be
>  optimized using the knowledge of which attributes are queried.
>
>
> * cc/apply-introduce-state (2016-06-06) 50 commits
>   (merged to 'next' on 2016-06-06 at 9f6bdcb)
>  + builtin/apply: remove misleading comment on lock_file field
>   (merged to 'next' on 2016-06-03 at 1ab0cf9)
>  + builtin/apply: move 'newfd' global into 'struct apply_state'
>  + builtin/apply: add 'lock_file' pointer into 'struct apply_state'
>  + builtin/apply: move applying patches into apply_all_patches()
>  + builtin/apply: move 'state' check into check_apply_state()
>  + builtin/apply: move 'symlink_changes' global into 'struct apply_state'
>  + builtin/apply: move 'fn_table' global into 'struct apply_state'
>  + builtin/apply: move 'state_linenr' global into 'struct apply_state'
>  + builtin/apply: move 'max_change' and 'max_len' into 'struct apply_state'
>  + builtin/apply: move 'ws_ignore_action' into 'struct apply_state'
>  + builtin/apply: move 'ws_error_action' into 'struct apply_state'
>  + builtin/apply: move 'applied_after_fixing_ws' into 'struct apply_state'
>  + builtin/apply: move 'squelch_whitespace_errors' into 'struct apply_state'
>  + builtin/apply: remove whitespace_option arg from set_default_whitespace_mode()
>  + builtin/apply: move 'whitespace_option' into 'struct apply_state'
>  + builtin/apply: move 'whitespace_error' global into 'struct apply_state'
>  + builtin/apply: move 'root' global into 'struct apply_state'
>  + builtin/apply: move 'p_value_known' global into 'struct apply_state'
>  + builtin/apply: move 'p_value' global into 'struct apply_state'
>  + builtin/apply: move 'has_include' global into 'struct apply_state'
>  + builtin/apply: move 'limit_by_name' global into 'struct apply_state'
>  + builtin/apply: move 'patch_input_file' global into 'struct apply_state'
>  + builtin/apply: move 'apply' global into 'struct apply_state'
>  + builtin/apply: move 'p_context' global into 'struct apply_state'
>  + builtin/apply: move 'fake_ancestor' global into 'struct apply_state'
>  + builtin/apply: move 'line_termination' global into 'struct apply_state'
>  + builtin/apply: move 'unsafe_paths' global into 'struct apply_state'
>  + builtin/apply: move 'no_add' global into 'struct apply_state'
>  + builtin/apply: move 'threeway' global into 'struct apply_state'
>  + builtin/apply: move 'summary' global into 'struct apply_state'
>  + builtin/apply: move 'numstat' global into 'struct apply_state'
>  + builtin/apply: move 'diffstat' global into 'struct apply_state'
>  + builtin/apply: move 'cached' global into 'struct apply_state'
>  + builtin/apply: move 'allow_overlap' global into 'struct apply_state'
>  + builtin/apply: move 'update_index' global into 'struct apply_state'
>  + builtin/apply: move 'apply_verbosely' global into 'struct apply_state'
>  + builtin/apply: move 'apply_with_reject' global into 'struct apply_state'
>  + builtin/apply: move 'apply_in_reverse' global into 'struct apply_state'
>  + builtin/apply: move 'check_index' global into 'struct apply_state'
>  + builtin/apply: move 'check' global into 'struct apply_state'
>  + builtin/apply: move 'unidiff_zero' global into 'struct apply_state'
>  + builtin/apply: move 'state' init into init_apply_state()
>  + builtin/apply: introduce 'struct apply_state' to start libifying
>  + builtin/apply: move 'read_stdin' global into cmd_apply()
>  + builtin/apply: move 'options' variable into cmd_apply()
>  + builtin/apply: extract line_by_line_fuzzy_match() from match_fragment()
>  + builtin/apply: avoid local variable shadowing 'len' parameter
>  + builtin/apply: avoid parameter shadowing 'linenr' global
>  + builtin/apply: avoid parameter shadowing 'p_value' global
>  + builtin/apply: make gitdiff_verify_name() return void
>
>  The "git apply" standalone program is being libified; this is the
>  first step to move many state variables into a structure that can
>  be explicitly (re)initialized to make the machinery callable more
>  than once.
>
>  The next step that moves some remaining state variables into the
>  structure and turns die()s into an error return that propagates up
>  to the caller is not queued yet but in flight.  It would be good to
>  review the above first and give the remainder of the series a solid
>  base to build on.
>
>  Will hold.
>
>
> * pb/bisect (2016-05-24) 3 commits
>  - bisect--helper: `write_terms` shell function in C
>  - bisect: rewrite `check_term_format` shell function in C
>  - bisect--helper: use OPT_CMDMODE instead of OPT_BOOL
>
>  Beginning of GSoC "git bisect" project.
>
>
> * sb/pathspec-label (2016-06-03) 6 commits
>   (merged to 'next' on 2016-06-03 at 362f097)
>  + pathspec: disable preload-index when attribute pathspec magic is in use
>  + pathspec: allow escaped query values
>   (merged to 'next' on 2016-05-31 at e72b604)
>  + pathspec: allow querying for attributes
>  + pathspec: move prefix check out of the inner loop
>  + pathspec: move long magic parsing out of prefix_pathspec
>  + Documentation: fix a typo
>  (this branch is used by sb/submodule-default-paths; uses jc/attr; is tangled with jc/attr-more.)
>
>  The pathspec mechanism learned ":(attr:X)$pattern" pathspec magic
>  to limit paths that match $pattern further by attribute settings.
>  The preload-index mechanism is disabled when the new pathspec magic
>  is in use (at least for now), because the attribute subsystem is
>  not thread-ready.
>
>  Will hold.
>
>
> * nd/worktree-cleanup-post-head-protection (2016-05-24) 6 commits
>  - worktree: simplify prefixing paths
>  - worktree: avoid 0{40}, too many zeroes, hard to read
>  - worktree.c: use is_dot_or_dotdot()
>  - git-worktree.txt: keep subcommand listing in alphabetical order
>  - worktree.c: rewrite mark_current_worktree() to avoid strbuf
>  - completion: support git-worktree
>  (this branch is used by nd/worktree-lock.)
>
>  Further preparatory clean-up for "worktree" feature.
>
>  Expecting a reroll.
>  ($gmane/294136, etc.)
>
>
> * mh/split-under-lock (2016-05-13) 33 commits
>   (merged to 'next' on 2016-06-03 at 2e71330)
>  + lock_ref_sha1_basic(): only handle REF_NODEREF mode
>  + commit_ref_update(): remove the flags parameter
>  + lock_ref_for_update(): don't resolve symrefs
>  + lock_ref_for_update(): don't re-read non-symbolic references
>  + refs: resolve symbolic refs first
>  + ref_transaction_update(): check refname_is_safe() at a minimum
>  + unlock_ref(): move definition higher in the file
>  + lock_ref_for_update(): new function
>  + add_update(): initialize the whole ref_update
>  + verify_refname_available(): adjust constness in declaration
>  + refs: don't dereference on rename
>  + refs: allow log-only updates
>  + delete_branches(): use resolve_refdup()
>  + ref_transaction_commit(): correctly report close_ref() failure
>  + ref_transaction_create(): disallow recursive pruning
>  + refs: make error messages more consistent
>  + lock_ref_sha1_basic(): remove unneeded local variable
>  + read_raw_ref(): move docstring to header file
>  + read_raw_ref(): improve docstring
>  + read_raw_ref(): rename symref argument to referent
>  + read_raw_ref(): clear *type at start of function
>  + read_raw_ref(): rename flags argument to type
>  + ref_transaction_commit(): remove local variable n
>  + rename_ref(): remove unneeded local variable
>  + commit_ref_update(): write error message to *err, not stderr
>  + refname_is_safe(): insist that the refname already be normalized
>  + refname_is_safe(): don't allow the empty string
>  + refname_is_safe(): use skip_prefix()
>  + remove_dir_recursively(): add docstring
>  + safe_create_leading_directories(): improve docstring
>  + read_raw_ref(): don't get confused by an empty directory
>  + commit_ref(): if there is an empty dir in the way, delete it
>  + t1404: demonstrate a bug resolving references
>  (this branch is used by mh/ref-iterators, mh/ref-store and mh/update-ref-errors.)
>
>  Further preparatory work on the refs API before the pluggable
>  backend series can land.
>
>  Will merge to 'master' after 2.9 final.
>
>
> * ew/fast-import-unpack-limit (2016-05-29) 2 commits
>   (merged to 'next' on 2016-05-29 at af32aba)
>  + fast-import: invalidate pack_id references after loosening
>   (merged to 'next' on 2016-05-11 at ffd4efb)
>  + fast-import: implement unpack limit
>
>  "git fast-import" learned the same performance trick to avoid
>  creating too small a packfile as "git fetch" and "git push" have,
>  using *.unpackLimit configuration.
>
>  Will hold.
>
>
> * jc/send-email-skip-backup (2016-04-12) 1 commit
>  - send-email: detect and offer to skip backup files
>
>  A careless invocation of "git send-email directory/" after editing
>  0001-change.patch with an editor often ends up sending both
>  0001-change.patch and its backup file, 0001-change.patch~, causing
>  embarrassment and a minor confusion.  Detect such an input and
>  offer to skip the backup files when sending the patches out.
>
>  Needs review.
>
>
> * kn/ref-filter-branch-list (2016-05-17) 17 commits
>  - branch: implement '--format' option
>  - branch: use ref-filter printing APIs
>  - branch, tag: use porcelain output
>  - ref-filter: allow porcelain to translate messages in the output
>  - ref-filter: add `:dir` and `:base` options for ref printing atoms
>  - ref-filter: make remote_ref_atom_parser() use refname_atom_parser_internal()
>  - ref-filter: introduce symref_atom_parser() and refname_atom_parser()
>  - ref-filter: introduce refname_atom_parser_internal()
>  - ref-filter: make "%(symref)" atom work with the ':short' modifier
>  - ref-filter: add support for %(upstream:track,nobracket)
>  - ref-filter: make %(upstream:track) prints "[gone]" for invalid upstreams
>  - ref-filter: introduce format_ref_array_item()
>  - ref-filter: move get_head_description() from branch.c
>  - ref-filter: modify "%(objectname:short)" to take length
>  - ref-filter: implement %(if:equals=<string>) and %(if:notequals=<string>)
>  - ref-filter: include reference to 'used_atom' within 'atom_value'
>  - ref-filter: implement %(if), %(then), and %(else) atoms
>
>  The code to list branches in "git branch" has been consolidated
>  with the more generic ref-filter API.
>
>  Rerolled.
>  Needs review.
>
>
> * dt/index-helper (2016-05-20) 20 commits
>  - index-helper: indexhelper.exitafter config
>  - trace: measure where the time is spent in the index-heavy operations
>  - index-helper: optionally automatically run
>  - index-helper: autorun mode
>  - index-helper: don't run if already running
>  - index-helper: kill mode
>  - watchman: add a config option to enable the extension
>  - unpack-trees: preserve index extensions
>  - update-index: enable/disable watchman support
>  - index-helper: use watchman to avoid refreshing index with lstat()
>  - watchman: support watchman to reduce index refresh cost
>  - read-cache: add watchman 'WAMA' extension
>  - index-helper: log warnings
>  - index-helper: add --detach
>  - daemonize(): set a flag before exiting the main process
>  - index-helper: add --strict
>  - index-helper: new daemon for caching index and related stuff
>  - pkt-line: add gentle version of packet_write
>  - read-cache: allow to keep mmap'd memory after reading
>  - read-cache.c: fix constness of verify_hdr()
>
>  A new "index-helper" daemon has been introduced to give newly
>  spawned Git process a quicker access to the data in the index, and
>  optionally interface with the watchman daemon to further reduce the
>  refresh cost.
>
>  Rerolled.
>  ($gmane/295106).
>
>
> * jc/bundle (2016-03-03) 6 commits
>  - index-pack: --clone-bundle option
>  - Merge branch 'jc/index-pack' into jc/bundle
>  - bundle v3: the beginning
>  - bundle: keep a copy of bundle file name in the in-core bundle header
>  - bundle: plug resource leak
>  - bundle doc: 'verify' is not about verifying the bundle
>
>  The beginning of "split bundle", which could be one of the
>  ingredients to allow "git clone" traffic off of the core server
>  network to CDN.
>
>
> * jc/merge-drop-old-syntax (2015-04-29) 1 commit
>  - merge: drop 'git merge <message> HEAD <commit>' syntax
>
>  Stop supporting "git merge <message> HEAD <commit>" syntax that has
>  been deprecated since October 2007, and issues a deprecation
>  warning message since v2.5.0.
>
>  It has been reported that git-gui still uses the deprecated syntax,
>  which needs to be fixed before this final step can proceed.
>  ($gmane/282594)
>
> --------------------------------------------------
> [Discarded]
>
> * mh/connect-leak (2016-04-28) 1 commit
>  . git_connect(): fix memory leak with CONNECT_DIAG_URL
>
>  Is already made obsolete with a patch in flight under discussion.
>  ($gmane/292962)
> --
> To unsubscribe from this list: send the line "unsubscribe git" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: What's cooking in git.git (Jun 2016, #04; Tue, 14)
  2016-06-14 22:08 What's cooking in git.git (Jun 2016, #04; Tue, 14) Junio C Hamano
  2016-06-15  2:36 ` Mike Hommey
  2016-06-15  7:35 ` Elia Pinto
@ 2016-06-15 10:12 ` Duy Nguyen
  2016-06-15 18:45   ` Junio C Hamano
  2 siblings, 1 reply; 9+ messages in thread
From: Duy Nguyen @ 2016-06-15 10:12 UTC (permalink / raw)
  To: Junio C Hamano; +Cc: Git Mailing List

On Wed, Jun 15, 2016 at 5:08 AM, Junio C Hamano <gitster@pobox.com> wrote:
> * nd/i-t-a-commitable (2016-06-06) 3 commits
>  - commit: don't count i-t-a entries when checking if the new commit is empty
>  - Resurrect "diff-lib.c: adjust position of i-t-a entries in diff"
>  - diff.h: extend "flags" field to 64 bits because we're out of bits
>
>  "rm .git/index && git add -N * && git commit" allows you to create
>  an empty commit without --allow-empty; attempt to forbid it.
>
>  Breaks many tests by completely butchering "git commit", it seems.

Not surprising. I did run some basic tests, but not the test suite. It
was more an excuse to bring up the topic again. Please drop it. I will
probably resend (with more or less the same idea, since you haven't
given a loud and clear "NO").

> * nd/worktree-cleanup-post-head-protection (2016-05-24) 6 commits
>  - worktree: simplify prefixing paths
>  - worktree: avoid 0{40}, too many zeroes, hard to read
>  - worktree.c: use is_dot_or_dotdot()
>  - git-worktree.txt: keep subcommand listing in alphabetical order
>  - worktree.c: rewrite mark_current_worktree() to avoid strbuf
>  - completion: support git-worktree
>  (this branch is used by nd/worktree-lock.)
>
>  Further preparatory clean-up for "worktree" feature.
>
>  Expecting a reroll.
>  ($gmane/294136, etc.)

Hmm.. I think what's in 'pu' (which is v2, $gmane/295260) is ok now.
-- 
Duy

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: What's cooking in git.git (Jun 2016, #04; Tue, 14)
  2016-06-15  2:36 ` Mike Hommey
@ 2016-06-15 18:32   ` Junio C Hamano
  2016-06-16  4:16     ` Mike Hommey
  0 siblings, 1 reply; 9+ messages in thread
From: Junio C Hamano @ 2016-06-15 18:32 UTC (permalink / raw)
  To: Mike Hommey; +Cc: git

Mike Hommey <mh@glandium.org> writes:

> On Tue, Jun 14, 2016 at 03:08:04PM -0700, Junio C Hamano wrote:

>> * mh/connect (2016-06-06) 10 commits
>>  - connect: [host:port] is legacy for ssh
>> ...
>>  - connect: document why we sometimes call get_port after get_host_and_port
>> 
>>  Ok, folks, is everybody happy with this version?
>
> $gmane/296609
> $gmane/296610

Oh, I have seen these, and I know you two are happy.

But I am having a hard time coming up with a few-line summary for
this topic.  I can write the beginning part, i.e. "Git-URL parsing
routine has been rewritten", but the concluding part of the sentence
cannot be "... has been rewritten for no good reason." if I were to
mark the topic as "Will merge to 'next'".  The best I can come up
with is "... has been rewritten (hopefully) without changing the
benaviour.", but that is not a strong-enough justificaiton to make
the change to the codebase, either.

In short, while the update may not introduce new bugs, why would we
want to have this change in the first place?

By the way, please do not quote the whole thing when you are
responding to a tiny part of the original message.

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: What's cooking in git.git (Jun 2016, #04; Tue, 14)
  2016-06-15 10:12 ` Duy Nguyen
@ 2016-06-15 18:45   ` Junio C Hamano
  0 siblings, 0 replies; 9+ messages in thread
From: Junio C Hamano @ 2016-06-15 18:45 UTC (permalink / raw)
  To: Duy Nguyen; +Cc: Git Mailing List

Duy Nguyen <pclouds@gmail.com> writes:

>> * nd/worktree-cleanup-post-head-protection (2016-05-24) 6 commits
>>  - worktree: simplify prefixing paths
>>  - worktree: avoid 0{40}, too many zeroes, hard to read
>>  - worktree.c: use is_dot_or_dotdot()
>>  - git-worktree.txt: keep subcommand listing in alphabetical order
>>  - worktree.c: rewrite mark_current_worktree() to avoid strbuf
>>  - completion: support git-worktree
>>  (this branch is used by nd/worktree-lock.)
>>
>>  Further preparatory clean-up for "worktree" feature.
>>
>>  Expecting a reroll.
>>  ($gmane/294136, etc.)
>
> Hmm.. I think what's in 'pu' (which is v2, $gmane/295260) is ok now.

Yes, thanks for spotting.  I should have updated the status text
when I picked up the reroll.

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: What's cooking in git.git (Jun 2016, #04; Tue, 14)
  2016-06-15 18:32   ` Junio C Hamano
@ 2016-06-16  4:16     ` Mike Hommey
  0 siblings, 0 replies; 9+ messages in thread
From: Mike Hommey @ 2016-06-16  4:16 UTC (permalink / raw)
  To: Junio C Hamano; +Cc: git

On Wed, Jun 15, 2016 at 11:32:39AM -0700, Junio C Hamano wrote:
> Mike Hommey <mh@glandium.org> writes:
> 
> > On Tue, Jun 14, 2016 at 03:08:04PM -0700, Junio C Hamano wrote:
> 
> >> * mh/connect (2016-06-06) 10 commits
> >>  - connect: [host:port] is legacy for ssh
> >> ...
> >>  - connect: document why we sometimes call get_port after get_host_and_port
> >> 
> >>  Ok, folks, is everybody happy with this version?
> >
> > $gmane/296609
> > $gmane/296610
> 
> Oh, I have seen these, and I know you two are happy.
> 
> But I am having a hard time coming up with a few-line summary for
> this topic.  I can write the beginning part, i.e. "Git-URL parsing
> routine has been rewritten", but the concluding part of the sentence
> cannot be "... has been rewritten for no good reason." if I were to
> mark the topic as "Will merge to 'next'".  The best I can come up
> with is "... has been rewritten (hopefully) without changing the
> benaviour.", but that is not a strong-enough justificaiton to make
> the change to the codebase, either.
> 
> In short, while the update may not introduce new bugs, why would we
> want to have this change in the first place?

My original motivation was to avoid having to copy code from connect.c
into git-cinnabar, which is what I'm currently doing[1]. Things derailed
a little, and we got ourselves somewhat in the middle of a refactor,
that I'm willing to push a little further (like, refactor things such
that host_end only happens once). My hope is that this makes the code
more maintainable.

Mike

1. https://github.com/glandium/git-cinnabar/blob/master/connect.c

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: What's cooking in git.git (Jun 2016, #04; Tue, 14)
  2016-06-15  7:35 ` Elia Pinto
@ 2016-06-16 12:36   ` Jeff King
  2016-06-16 21:14     ` Junio C Hamano
  0 siblings, 1 reply; 9+ messages in thread
From: Jeff King @ 2016-06-16 12:36 UTC (permalink / raw)
  To: Elia Pinto
  Cc: Junio C Hamano, Eric Sunshine, Ramsay Jones,
	Torsten Bögershausen, git

On Wed, Jun 15, 2016 at 09:35:20AM +0200, Elia Pinto wrote:

> > * ep/http-curl-trace (2016-05-24) 2 commits
> >  - imap-send.c: introduce the GIT_TRACE_CURL enviroment variable
> >  - http.c: implement the GIT_TRACE_CURL environment variable
> >
> >  HTTP transport gained an option to produce more detailed debugging
> >  trace.
> >
> >  Rerolled.  Is everybody happy with this version?
> >
> The refs is there
> http://git.661346.n2.nabble.com/PATCH-v7-0-2-Implement-the-GIT-TRACE-CURL-environment-variable-td7657079.html
> 
> If  kindly someone who has reviewed and helped me to do the patch
> could give an ack (or a nack eventually). Thanks in advance

I gave another look at what is queued in pu, and I think it is OK. I
still find the output a little verbose, but I think we should ship it
and see how it fares in practice while debugging. I don't think its
exact format needs to be set in stone, so we can tweak it later if we
choose.

-Peff

PS Please trim your quotes to just the relevant bits.

^ permalink raw reply	[flat|nested] 9+ messages in thread

* Re: What's cooking in git.git (Jun 2016, #04; Tue, 14)
  2016-06-16 12:36   ` Jeff King
@ 2016-06-16 21:14     ` Junio C Hamano
  0 siblings, 0 replies; 9+ messages in thread
From: Junio C Hamano @ 2016-06-16 21:14 UTC (permalink / raw)
  To: Jeff King
  Cc: Elia Pinto, Eric Sunshine, Ramsay Jones, Torsten Bögershausen, git

Jeff King <peff@peff.net> writes:

> On Wed, Jun 15, 2016 at 09:35:20AM +0200, Elia Pinto wrote:
>
>> > * ep/http-curl-trace (2016-05-24) 2 commits
>> >  - imap-send.c: introduce the GIT_TRACE_CURL enviroment variable
>> >  - http.c: implement the GIT_TRACE_CURL environment variable
>> >
>> >  HTTP transport gained an option to produce more detailed debugging
>> >  trace.
>> >
>> >  Rerolled.  Is everybody happy with this version?
>> >
>> The refs is there
>> http://git.661346.n2.nabble.com/PATCH-v7-0-2-Implement-the-GIT-TRACE-CURL-environment-variable-td7657079.html
>> 
>> If  kindly someone who has reviewed and helped me to do the patch
>> could give an ack (or a nack eventually). Thanks in advance
>
> I gave another look at what is queued in pu, and I think it is OK. I
> still find the output a little verbose, but I think we should ship it
> and see how it fares in practice while debugging. I don't think its
> exact format needs to be set in stone, so we can tweak it later if we
> choose.

Thanks, let's push it forwared then.

>
> -Peff
>
> PS Please trim your quotes to just the relevant bits.

^ permalink raw reply	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2016-06-16 21:14 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-06-14 22:08 What's cooking in git.git (Jun 2016, #04; Tue, 14) Junio C Hamano
2016-06-15  2:36 ` Mike Hommey
2016-06-15 18:32   ` Junio C Hamano
2016-06-16  4:16     ` Mike Hommey
2016-06-15  7:35 ` Elia Pinto
2016-06-16 12:36   ` Jeff King
2016-06-16 21:14     ` Junio C Hamano
2016-06-15 10:12 ` Duy Nguyen
2016-06-15 18:45   ` Junio C Hamano

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.