From mboxrd@z Thu Jan 1 00:00:00 1970 From: Junio C Hamano Subject: What's cooking in git.git (Aug 2012, #07; Wed, 22) Date: Wed, 22 Aug 2012 14:03:52 -0700 Message-ID: <7vsjbe63lz.fsf@alter.siamese.dyndns.org> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii To: git@vger.kernel.org X-From: git-owner@vger.kernel.org Wed Aug 22 23:04:14 2012 Return-path: Envelope-to: gcvg-git-2@plane.gmane.org Received: from vger.kernel.org ([209.132.180.67]) by plane.gmane.org with esmtp (Exim 4.69) (envelope-from ) id 1T4I5w-0007Nu-SW for gcvg-git-2@plane.gmane.org; Wed, 22 Aug 2012 23:04:09 +0200 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933349Ab2HVVEC (ORCPT ); Wed, 22 Aug 2012 17:04:02 -0400 Received: from b-pb-sasl-quonix.pobox.com ([208.72.237.35]:54952 "EHLO smtp.pobox.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933330Ab2HVVD4 (ORCPT ); Wed, 22 Aug 2012 17:03:56 -0400 Received: from smtp.pobox.com (unknown [127.0.0.1]) by b-sasl-quonix.pobox.com (Postfix) with ESMTP id 88174886A; Wed, 22 Aug 2012 17:03:55 -0400 (EDT) DKIM-Signature: v=1; a=rsa-sha1; c=relaxed; d=pobox.com; h=from:to :subject:date:message-id:mime-version:content-type; s=sasl; bh=j xMPditHhl6hFFoivFPD56o+i+g=; b=nieWSNVQcxvPa5gN0I7DAcVyg4NhS6KXx 10hf6qKICGhvuNZpPFE+oV2vVH2GI2USFWhQaL2HVZj+yvqNnL/c9XKoZx0uQX9Z wHktxzlUm70c6GLzLuc6ZjH21EGQCJorzkeV2Dxu0CJV2VHrB/YyUdO8ZvayiYuw Ykevipz9ZQ= DomainKey-Signature: a=rsa-sha1; c=nofws; d=pobox.com; h=from:to:subject :date:message-id:mime-version:content-type; q=dns; s=sasl; b=n+U qkTu4UUmFiskrnS1gYmKSqESzlvvgSfRAUExi9GjDz06b0m9syWcbZFTryux+kkv IU4lGX/ICbvhX94YD/ph+FLuOj8mV9razQzg8+CoHc7WoVTZ662qYeG7vluHVUlb MDTM6sgY6rU+4w/S5osOBHDMLHyJTKNt/DcAgLgE= Received: from b-pb-sasl-quonix.pobox.com (unknown [127.0.0.1]) by b-sasl-quonix.pobox.com (Postfix) with ESMTP id 746568869; Wed, 22 Aug 2012 17:03:55 -0400 (EDT) Received: from pobox.com (unknown [98.234.214.94]) (using TLSv1 with cipher DHE-RSA-AES128-SHA (128/128 bits)) (No client certificate requested) by b-sasl-quonix.pobox.com (Postfix) with ESMTPSA id F2EFA8868; Wed, 22 Aug 2012 17:03:53 -0400 (EDT) X-master-at: 851f7e689efa034701bf41c3be06c927480eaae9 X-next-at: ff27e03d9aa951d799461ff03a3f103000d7ce88 User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/23.2 (gnu/linux) X-Pobox-Relay-ID: E17E30E4-EC9C-11E1-AF20-BAB72E706CDE-77302942!b-pb-sasl-quonix.pobox.com Sender: git-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: git@vger.kernel.org Archived-At: Here are the topics that have been cooking. Commits prefixed with '-' are only in 'pu' (proposed updates) while commits prefixed with '+' are in 'next'. As promised (threatened ;-), the first batch of topics for the next release are now part of 'master'. They are mostly innocuous documentation updates, test clean-ups, and all should eventually go to the maintenance track. In addition, the update to git-svn to make it work better with subversion 1.7 is also included. I'm planning to keep this cycle reasonably short and aim for tagging the result as 1.8.0 at the end of 9th week, on October 21st, after which I'd disappear for a few weeks. http://tinyurl.com/gitCal is where you can always find my rough tagging schedule at. 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 -------------------------------------------------- [New Topics] * er/doc-fast-import-done (2012-08-22) 1 commit - fast-import: document the --done option Parked in 'pu' in case ESR responds with "Sorry, forgot to sign-off". * nd/am-i18n-fix (2012-08-22) 1 commit - am: quote string for translation before passing to eval_gettextln "git am" wasn't marked up for i18n properly. Will merge to 'next', and eventually to maint-1.7.11 track. -------------------------------------------------- [Graduated to "master"] * hv/coding-guidelines (2012-08-15) 1 commit (merged to 'next' on 2012-08-20 at 4984865) + Documentation/CodingGuidelines: spell out more shell guidelines (Originally merged to 'next' on 2012-08-18) In earlier days, "imitate the style in the neibouring code" was sufficient to keep the coherent style, but over time some parts of the codebase have drifted enough to make it ineffective. * jc/doc-git-updates (2012-08-17) 1 commit (merged to 'next' on 2012-08-20 at ab1db71) + Documentation: update the introductory section (Originally merged to 'next' on 2012-08-18) * jc/maint-abbrev-option-cli (2012-08-16) 1 commit (merged to 'next' on 2012-08-20 at 54d1a5a) + gitcli: describe abbreviation of long options (Originally merged to 'next' on 2012-08-18) We did not document that many commands take unique prefix abbreviations of long options (e.g. "--option" may be the only flag that the command accepts that begin with "--opt", in which case you can give "--opt") anywhere easy to find for new people. * jc/maint-rev-list-topo-doc (2012-08-15) 1 commit (merged to 'next' on 2012-08-20 at 0f669d2) + rev-list docs: clarify --topo-order description (Originally merged to 'next' on 2012-08-18) It was unclear what "--topo-order" was really about in the documentation. It is not just about "children before parent", but also about "don't mix lineages". * jc/tag-doc (2012-08-06) 1 commit (merged to 'next' on 2012-08-20 at 9eb658e) + Documentation: do not mention .git/refs/* directories (Originally merged to 'next' on 2012-08-18) Our documentation used to assume having files in .git/refs/* directories was the only to have branches and tags, but that is not true for quite some time. * jc/test-prereq (2012-08-04) 8 commits (merged to 'next' on 2012-08-20 at dd44c4a) + t3910: use the UTF8_NFD_TO_NFC test prereq + test-lib: provide UTF8 behaviour as a prerequisite + t0050: use the SYMLINKS test prereq + t0050: use the CASE_INSENSITIVE_FS test prereq + test-lib: provide case insensitivity as a prerequisite + test: allow prerequisite to be evaluated lazily + test: rename $satisfied to $satisfied_prereq (Originally merged to 'next' on 2012-08-04) Teaches the test framework to probe rarely used prerequistes lazily, and make use of it for detecting SYMLINKS, CASE_INSENSITIVE_FS and NKD/NKC MacOS x gotcha. * jk/check-docs-update (2012-08-08) 8 commits (merged to 'next' on 2012-08-20 at d51021d) + check-docs: get documented command list from Makefile + check-docs: drop git-help special-case + check-docs: list git-gui as a command + check-docs: factor out command-list + command-list: mention git-credential-* helpers + command-list: add git-sh-i18n + check-docs: update non-command documentation list + check-docs: mention gitweb specially (Originally merged to 'next' on 2012-08-18) Simplify "make check-docs" implementation and update its coverage. * js/gitweb-path-info-unquote (2012-08-15) 1 commit (merged to 'next' on 2012-08-20 at a4aa740) + gitweb: URL-decode $my_url/$my_uri when stripping PATH_INFO (Originally merged to 'next' on 2012-08-15) Stripping of PATH_INFO in gitweb did not take url style quoting into account, failing to notice directories with funny characters e.g. SP in their paths. * mk/test-seq (2012-08-04) 1 commit (merged to 'next' on 2012-08-20 at c373e0e) + tests: Introduce test_seq (this branch is used by ab/diff-write-incomplete-line.) (Originally merged to 'next' on 2012-08-06) Add a compatibility/utility function to the test framework. * mm/die-with-dashdash-help (2012-08-03) 1 commit (merged to 'next' on 2012-08-20 at ebe0e1a) + setup: clarify error messages for file/revisions ambiguity (Originally merged to 'next' on 2012-08-09) Reword error messages. * ms/git-svn-1.7 (2012-08-02) 20 commits (merged to 'next' on 2012-08-21 at ae8aff9) + git-svn: remove ad-hoc canonicalizations + git-svn: canonicalize newly-minted URLs + git-svn: introduce add_path_to_url function + git-svn: canonicalize earlier + git-svn: replace URL escapes with canonicalization + git-svn: attempt to mimic SVN 1.7 URL canonicalization + t9107: fix typo + t9118: workaround inconsistency between SVN versions + Git::SVN{,::Ra}: canonicalize earlier + git-svn: path canonicalization uses SVN API + Git::SVN::Utils: remove irrelevant comment + git-svn: add join_paths() to safely concatenate paths + git-svn: factor out _collapse_dotdot function + git-svn: use SVN 1.7 to canonicalize when possible + git-svn: move canonicalization to Git::SVN::Utils + use Git::SVN{,::RA}->url accessor globally + use Git::SVN->path accessor globally + Git::SVN::Ra: use accessor for URLs + Git::SVN: use accessor for URLs internally + Git::SVN: use accessors internally for path A series by Michael Schwern via Eric to update git-svn to revamp the way URLs are internally passed around, to make it work with SVN 1.7. * mv/pull-r-for-rebase (2012-08-17) 1 commit (merged to 'next' on 2012-08-20 at 9743071) + man: git pull -r is a short for --rebase (Originally merged to 'next' on 2012-08-18) A minor documentation update. * nd/index-errno (2012-08-06) 1 commit (merged to 'next' on 2012-08-20 at 34076c6) + read_index_from: remove bogus errno assignments (Originally merged to 'next' on 2012-08-06) Assignments to errno before calling system functions that used to matter in the old code were left behind after the code structure changed sufficiently to make them useless. * pg/maint-apply-remove-unused-variable (2012-08-05) 1 commit (merged to 'next' on 2012-08-20 at 260975b) + apply: delete unused deflate_origlen from patch struct (Originally merged to 'next' on 2012-08-05) Remove an unused field. * tr/maint-send-email-2047 (2012-07-31) 1 commit (merged to 'next' on 2012-08-20 at cf5ee1c) + send-email: improve RFC2047 quote parsing (Originally merged to 'next' on 2012-08-09) "git send-email" did not unquote encoded words that appear on the header correctly, and lost "_" from strings. * tr/merge-recursive-flush (2012-08-03) 1 commit (merged to 'next' on 2012-08-20 at 00aeb19) + merge-recursive: eliminate flush_buffer() in favor of write_in_full() (Originally merged to 'next' on 2012-08-09) Remove unnecessary code. * tr/void-diff-setup-done (2012-08-03) 1 commit (merged to 'next' on 2012-08-20 at 2f21f63) + diff_setup_done(): return void (Originally merged to 'next' on 2012-08-09) Remove unnecessary code. -------------------------------------------------- [Stalled] * jc/add-delete-default (2012-08-13) 1 commit - git add: notice removal of tracked paths by default "git add dir/" updated modified files and added new files, but does not notice removed files, which may be "Huh?" to some users. They can of course use "git add -A dir/", but why should they? Resurrected from graveyard, as I thought it was a worthwhile thing to do in the longer term; waiting for comments. * tx/relative-in-the-future (2012-08-16) 2 commits - date: show relative dates in the future - date: refactor the relative date logic from presentation Not my itch; rewritten an earlier submission by Tom Xue into somewhat more maintainable form, though it breaks existing i18n. Anybody interested in fixing it up? Otherwise may discard. * pw/p4-submit-conflicts (2012-08-16) 12 commits - git p4: add submit --prepare-p4-only option - git p4: add submit --dry-run option - git p4: accept -v for --verbose - git p4: revert deleted files after submit cancel - git p4: rearrange submit template construction - git p4: test clean-up after failed submit, fix added files - git p4: standardize submit cancel due to unchanged template - git p4: move conflict prompt into run, use [c]ontinue and [q]uit - git p4: remove submit failure options [a]pply and [w]rite - git p4: gracefully fail if some commits could not be applied - git p4 test: use p4d -L option to suppress log messages - git p4 test: remove bash-ism of combined export/assignment Waiting for the dust to settle. * mz/rebase-range (2012-07-18) 7 commits . rebase (without -p): correctly calculate patches to rebase . rebase -p: don't request --left-right only to ignore left side . rebase -p: use --cherry-mark for todo file . git-rebase--interactive.sh: look up subject in add_pick_line . git-rebase--interactive: group all $preserve_merges code . git-rebase--interactive.sh: extract function for adding "pick" line . git-rebase--am.sh: avoid special-casing --keep-empty Expecting a reroll. Performance concerns from Windows folks. Also the series lacks proper sign-offs. * jl/submodule-rm (2012-07-05) 2 commits - rm: remove submodules from the index and the .gitmodules file - rm: don't fail when removing populated submodules Expecting a reroll. * mb/remote-default-nn-origin (2012-07-11) 6 commits - Teach get_default_remote to respect remote.default. - Test that plain "git fetch" uses remote.default when on a detached HEAD. - Teach clone to set remote.default. - Teach "git remote" about remote.default. - Teach remote.c about the remote.default configuration setting. - Rename remote.c's default_remote_name static variables. When the user does not specify what remote to interact with, we often attempt to use 'origin'. This can now be customized via a configuration variable. Expecting a reroll. "The first remote becomes the default" bit is better done as a separate step. * jc/split-blob (2012-04-03) 6 commits - chunked-object: streaming checkout - chunked-object: fallback checkout codepaths - bulk-checkin: support chunked-object encoding - bulk-checkin: allow the same data to be multiply hashed - new representation types in the packstream - packfile: use varint functions Not ready. I finished the streaming checkout codepath, but as explained in 127b177 (bulk-checkin: support chunked-object encoding, 2011-11-30), these are still early steps of a long and painful journey. At least pack-objects and fsck need to learn the new encoding for the series to be usable locally, and then index-pack/unpack-objects needs to learn it to be used remotely. Given that I heard a lot of noise that people want large files, and that I was asked by somebody at GitTogether'11 privately for an advice on how to pay developers (not me) to help adding necessary support, I am somewhat dissapointed that the original patch series that was sent long time ago still remains here without much comments and updates from the developer community. I even made the interface to the logic that decides where to split chunks easily replaceable, and I deliberately made the logic in the original patch extremely stupid to entice others, especially the "bup" fanbois, to come up with a better logic, thinking that giving people an easy target to shoot for, they may be encouraged to help out. The plan is not working :-<. -------------------------------------------------- [Cooking] * lt/commit-tree-guess-utf-8 (2012-08-21) 1 commit - commit/commit-tree: correct latin1 to utf-8 Teaches "git commit" and "git commit-tree" the "we are told to use utf-8 in log message, but this does not look like utf-8---attempt to pass it through convert-from-latin1-to-utf8 and see if it makes sense" heuristics "git mailinfo" already uses. Will merge to 'next'. * kk/maint-for-each-ref-multi-sort (2012-08-21) 2 commits - for-each-ref: Fix sort with multiple keys - t6300: test sort with multiple keys "git for-each-ref" did not currectly support more than one --sort option. Will merge to 'next'. * fa/remote-svn (2012-08-22) 16 commits - Add a test script for remote-svn - remote-svn: add marks-file regeneration - Add a svnrdump-simulator replaying a dump file for testing - remote-svn: add incremental import - remote-svn: Activate import/export-marks for fast-import - Create a note for every imported commit containing svn metadata - vcs-svn: add fast_export_note to create notes - Allow reading svn dumps from files via file:// urls - remote-svn, vcs-svn: Enable fetching to private refs - When debug==1, start fast-import with "--stats" instead of "--quiet" - Add documentation for the 'bidi-import' capability of remote-helpers - Connect fast-import to the remote-helper via pipe, adding 'bidi-import' capability - Add argv_array_detach and argv_array_free_detached - Add svndump_init_fd to allow reading dumps from arbitrary FDs - Add git-remote-testsvn to Makefile - Implement a remote helper for svn in C (this branch is used by fa/vcs-svn.) * fa/vcs-svn (2012-08-22) 4 commits - vcs-svn: remove repo_tree - vcs-svn/svndump: rewrite handle_node(), begin|end_revision() - vcs-svn/svndump: restructure node_ctx, rev_ctx handling - svndump: move struct definitions to .h (this branch uses fa/remote-svn.) * nd/i18n-parseopt-help (2012-08-22) 66 commits - Use imperative form in help usage to describe an action - Reduce translations by using same terminologies - i18n: write-tree: mark parseopt strings for translation - i18n: verify-tag: mark parseopt strings for translation - i18n: verify-pack: mark parseopt strings for translation - i18n: update-server-info: mark parseopt strings for translation - i18n: update-ref: mark parseopt strings for translation - i18n: update-index: mark parseopt strings for translation - i18n: tag: mark parseopt strings for translation - i18n: symbolic-ref: mark parseopt strings for translation - i18n: show-ref: mark parseopt strings for translation - i18n: show-branch: mark parseopt strings for translation - i18n: shortlog: mark parseopt strings for translation - i18n: rm: mark parseopt strings for translation - i18n: revert, cherry-pick: mark parseopt strings for translation - i18n: rev-parse: mark parseopt strings for translation - i18n: reset: mark parseopt strings for translation - i18n: rerere: mark parseopt strings for translation - i18n: status: mark parseopt strings for translation - i18n: replace: mark parseopt strings for translation - i18n: remote: mark parseopt strings for translation - i18n: read-tree: mark parseopt strings for translation - i18n: push: mark parseopt strings for translation - i18n: prune: mark parseopt strings for translation - i18n: prune-packed: mark parseopt strings for translation - i18n: pack-refs: mark parseopt strings for translation - i18n: pack-objects: mark parseopt strings for translation - i18n: notes: mark parseopt strings for translation - i18n: name-rev: mark parseopt strings for translation - i18n: mv: mark parseopt strings for translation - i18n: mktree: mark parseopt strings for translation - i18n: merge: mark parseopt strings for translation - i18n: merge-file: mark parseopt strings for translation - i18n: merge-base: mark parseopt strings for translation - i18n: ls-tree: mark parseopt strings for translation - i18n: ls-files: mark parseopt strings for translation - i18n: log: mark parseopt strings for translation - i18n: init-db: mark parseopt strings for translation - i18n: help: mark parseopt strings for translation - i18n: hash-object: mark parseopt strings for translation - i18n: grep: mark parseopt strings for translation - i18n: gc: mark parseopt strings for translation - i18n: fsck: mark parseopt strings for translation - i18n: format-patch: mark parseopt strings for translation - i18n: for-each-ref: mark parseopt strings for translation - i18n: fmt-merge-msg: mark parseopt strings for translation - i18n: fetch: mark parseopt strings for translation - i18n: fast-export: mark parseopt strings for translation - i18n: describe: mark parseopt strings for translation - i18n: config: mark parseopt strings for translation - i18n: count-objects: mark parseopt strings for translation - i18n: commit: mark parseopt strings for translation - i18n: column: mark parseopt strings for translation - i18n: clone: mark parseopt strings for translation - i18n: clean: mark parseopt strings for translation - i18n: cherry: mark parseopt strings for translation - i18n: checkout: mark parseopt strings for translation - i18n: checkout-index: mark parseopt strings for translation - i18n: check-attr: mark parseopt strings for translation - i18n: cat-file: mark parseopt strings for translation - i18n: branch: mark parseopt strings for translation - i18n: blame: mark parseopt strings for translation - i18n: add: mark parseopt strings for translation - i18n: bisect--helper: mark parseopt strings for translation - i18n: archive: mark parseopt strings for translation - i18n: mark "style" in OPT_COLUMN() for translation A lot of i18n mark-up for the help text from "git -h". Will merge to 'next'. * tr/maint-parseopt-avoid-empty (2012-08-20) 1 commit - gettext: do not translate empty string A workaround to avoid doing _(""), which translates to magic string in the .po files. Will merge to 'next'. * jk/config-warn-on-inaccessible-paths (2012-08-21) 4 commits - warn_on_inaccessible(): a helper to warn on inaccessible paths - attr: warn on inaccessible attribute files - gitignore: report access errors of exclude files - config: warn on inaccessible files When looking for $HOME/.gitconfig etc., it is OK if we cannot read them because they do not exist, but unable to read existing ones need to be diagnosed. Will merge to 'next'. * nd/i18n-poison-test-updates (2012-08-21) 6 commits - Fix tests under GETTEXT_POISON on parseopt - Fix tests under GETTEXT_POISON on pack-object - Fix tests under GETTEXT_POISON on git-apply - Fix tests under GETTEXT_POISON on diffstat - Fix tests under GETTEXT_POISON on git-stash - Fix tests under GETTEXT_POISON on relative dates Updates to tests that can be broken with gettext-poison builds. * jc/daemon-access-hook (2012-08-15) 1 commit (merged to 'next' on 2012-08-20 at c8f5b2e) + daemon: --access-hook option Allow an external command to tell git-daemon to decline service based on the client address, repository path, etc. Will merge to 'master' as part of the third batch. * jc/send-email-reconfirm (2012-08-14) 1 commit (merged to 'next' on 2012-08-20 at dffdef6) + send-email: validate & reconfirm interactive responses Validate interactive input to "git send-email" to avoid common mistakes such as saying "y" to sender mail address whose prompt is given with a correctly guessed default. Will merge to 'master' as part of the third batch. * ef/win32-cred-helper (2012-08-16) 1 commit (merged to 'next' on 2012-08-20 at bd5c651) + contrib: add win32 credential-helper Credential helper for Win32 to allow access to the keychain of the logged-in user. Will merge to 'master' as part of the second batch. * rr/precompose-utf8-cleanup (2012-08-20) 2 commits (merged to 'next' on 2012-08-20 at a883c2a) + precompose-utf8: do not call checks for non-ascii "utf8" + cleanup precompose_utf8 A style and code cleanup. Will merge to 'master' as part of the second batch. * mh/maint-config-doc-proxy-command (2012-08-18) 2 commits (merged to 'next' on 2012-08-20 at a484625) + git-config doc: unconfuse an example + git-config.txt: fix example A minor documentation update. Will merge to 'master' as part of the second batch. * ph/stash-rerere (2012-08-17) 2 commits (merged to 'next' on 2012-08-20 at ae37111) + stash: invoke rerere in case of conflict + test: git-stash conflict sets up rerere "git stash" internally used "git merge-recursive" backend, which did not trigger "rerere" upon conflicts unlike other mergy operations. Will merge to 'master' as part of the third batch. * hv/submodule-path-unmatch (2012-08-14) 1 commit (merged to 'next' on 2012-08-20 at cbe6483) + Let submodule command exit with error status if path does not exist As the title says. Will merge to 'master' as part of the second batch. * bc/receive-pack-stdout-protection (2012-08-06) 2 commits (merged to 'next' on 2012-08-20 at b1b0d18) + receive-pack: do not leak output from auto-gc to standard output + t/t5400: demonstrate breakage caused by informational message from prune (Originally merged to 'next' on 2012-08-07) When "git push" triggered the automatic gc on the receiving end, a message from "git prune" that said it was removing cruft leaked to the standard output, breaking the communication protocol. Will merge to 'master' as part of the second batch. * bc/prune-info (2012-08-07) 1 commit (merged to 'next' on 2012-08-20 at 1bc9e66) + prune.c: only print informational message in show_only or verbose mode Teach "git prune" without "-v" to be silent about leftover temporary files. Will merge to 'master' as part of the second batch. * jk/docs-docbook-monospace-display (2012-08-07) 1 commit (merged to 'next' on 2012-08-20 at 0ed30dc) + docs: monospace listings in docbook output (Originally merged to 'next' on 2012-08-18) The documentation in the TeXinfo format was using indented output for materials meant to be examples that are better typeset in monospace. Will merge to 'master' as part of the second batch. * jc/maint-protect-sh-from-ifs (2012-08-08) 1 commit (merged to 'next' on 2012-08-20 at 8b00562) + sh-setup: protect from exported IFS When the user exports a non-default IFS without HT, scripts that rely on being able to parse "ls-files -s | while read a b c..." start to fail. Protect them from such a misconfiguration. Will merge to 'master' as part of the second batch. * mg/rebase-i-onto-reflog-in-full (2012-08-10) 1 commit (merged to 'next' on 2012-08-20 at f671bd2) + rebase -i: use full onto sha1 in reflog The reflog entries left by "git rebase" and "git rebase -i" were inconsistent. Will merge to 'master' as part of the second batch. * mz/empty-rebase-test (2012-08-09) 1 commit (merged to 'next' on 2012-08-20 at 53e2419) + add tests for 'git rebase --keep-empty' Will merge to 'master' as part of the second batch. * jc/capabilities (2012-08-13) 3 commits (merged to 'next' on 2012-08-20 at 1976e47) + fetch-pack: mention server version with verbose output + parse_feature_request: make it easier to see feature values + fetch-pack: do not ask for unadvertised capabilities (this branch uses jk/version-string.) Some capabilities were asked by fetch-pack even when upload-pack did not advertise that they are available. Fix fetch-pack not to do so. Will merge to 'master' as part of the second batch. * pw/p4-use-client-spec-branch-detection (2012-08-20) 5 commits - git p4: make branch detection work with --use-client-spec - git p4: do wildcard decoding in stripRepoPath - git p4: set self.branchPrefixes in initialization - git p4 test: add broken --use-client-spec --detect-branches tests - git p4 test: move client_view() function to library Will merge to 'next' and soon to 'master'. * jc/maint-push-refs-all (2012-08-07) 2 commits - get_fetch_map(): tighten checks on dest refs - fetch/push: allow refs/*:refs/* Allows pushing and fetching refs/stash. Need to send it out to the list for review. * jk/version-string (2012-08-10) 3 commits (merged to 'next' on 2012-08-20 at 6d207bb) + do not send client agent unless server does first + send-pack: fix capability-sending logic + include agent identifier in capability string (this branch is used by jc/capabilities.) (Originally merged to 'next' on 2012-08-10) Leftover bits from the "git version" code restructuring, that give us an ability to expose the Git version over the wire in the protocol exchange. But we do so carefully only to the other end that understands it. Will merge to 'master' as part of the third batch. * js/grep-patterntype-config (2012-08-03) 1 commit (merged to 'next' on 2012-08-20 at 39a0431) + grep: add a grep.patternType configuration setting (Originally merged to 'next' on 2012-08-09) "grep" learned to use a non-standard pattern type by default if a configuration variable tells it to. Will merge to 'master' as part of the second batch. * ab/diff-write-incomplete-line (2012-08-05) 1 commit (merged to 'next' on 2012-08-20 at e28b804) + Fix '\ No newline...' annotation in rewrite diffs (Originally merged to 'next' on 2012-08-07) The output from "git diff -B" for a file that ends with an incomplete line did not put "\ No newline..." on a line of its own. Will merge to 'master' as part of the second batch. * tg/index-v5 (2012-08-17) 13 commits - p0002-index.sh: add perf test for the index formats - update-index.c: rewrite index when index-version is given - Write resolve-undo data for index-v5 - Write index-v5 cache-tree data - Write index-v5 - Read cache-tree in index-v5 - Read resolve-undo data - Read index-v5 - Make in-memory format aware of stat_crc - Add documentation of the index-v5 file format - t2104: Don't fail for index versions other than [23] - read-cache.c: Re-read index if index file changed - Move index v2 specific functions to their own file A GSoC project, queued here primarily to give people an easier access to the state of the last posted version. * jc/maint-sane-execvp-notdir (2012-07-31) 1 commit (merged to 'next' on 2012-08-20 at 0d76cf2) + sane_execvp(): ignore non-directory on $PATH (Originally merged to 'next' on 2012-08-09) "git foo" errored out with "Not a directory" when the user had a non directory on $PATH, and worse yet it masked an alias "foo" to run. Will merge to 'master' as part of the third batch. * cw/cherry-pick-allow-empty-message (2012-08-06) 1 commit (merged to 'next' on 2012-08-20 at 0dc0590) + cherry-pick: add --allow-empty-message option (Originally merged to 'next' on 2012-08-09) "git cherry-pick" by default stops when it sees a commit without any log message. The "--allow-empty-message" option can be used to silently proceed. Will merge to 'master' as part of the third batch. * jc/maint-t7406-rev-parse-max-count-huh (2012-07-30) 1 commit (merged to 'next' on 2012-08-20 at 3e2598a) + t7406: fix misleading "rev-parse --max-count=1 HEAD" (Originally merged to 'next' on 2012-07-30) Test clean-up, with no behaviour change. Will merge to 'master' as part of the second batch. * jk/maint-diff-nul40-as-sentinel (2012-07-29) 1 commit + diff: do not use null sha1 as a sentinel value (this branch is used by jk/maint-null-in-trees.) "git diff" had a confusion between taking data from a path in the working tree and taking data from an object that happens to have name 0{40} recorded in a tree. * mz/cherry-code-cleanup (2012-07-29) 3 commits (merged to 'next' on 2012-08-20 at bfb0457) + cherry: remove redundant check for merge commit + cherry: don't set ignored rev_info options + remove unnecessary parameter from get_patch_ids() Minor code clean-up on the cherry-pick codepath. Will merge to 'master' as part of the second batch. * jc/maint-config-exit-status (2012-07-30) 1 commit (merged to 'next' on 2012-08-20 at e18ddd8) + config: "git config baa" should exit with status 1 (Originally merged to 'next' on 2012-07-30) The exit status code from "git config" was way overspecified while being incorrect. Update the implementation to give the documented status for a case that was documented, and introduce a new code for "all other errors". Will merge to 'master' as part of the third batch. * jk/maint-null-in-trees (2012-07-29) 2 commits (merged to 'next' on 2012-08-20 at 5bc2c49) + fsck: detect null sha1 in tree entries + do not write null sha1s to on-disk index (this branch uses jk/maint-diff-nul40-as-sentinel.) (Originally merged to 'next' on 2012-07-30) We do not want a link to 0{40} object stored anywhere in our objects. Will merge to 'master' as part of the second batch. * sz/submodule-force-update (2012-07-25) 1 commit - Make 'git submodule update --force' always check out submodules. We may want a documentation update and a few tests. Kicked back to 'pu'. * da/difftool-updates (2012-08-21) 13 commits (merged to 'next' on 2012-08-21 at 332afe4) + difftool: silence warning (merged to 'next' on 2012-08-20 at 2fecd90) + Add Code Compare v2.80.4 as a merge / diff tool for Windows + mergetool,difftool: Document --tool-help consistently + difftool: Disable --symlinks on cygwin + difftool: Handle compare() returning -1 + difftool: Wrap long lines for readability + difftool: Check all return codes from compare() + difftool: Handle finding mergetools/ in a path with spaces + difftool: Use symlinks when diffing against the worktree + difftool: Call the temp directory "git-difftool" + difftool: Move option values into a hash + difftool: Eliminate global variables + difftool: Simplify print_tool_help() (Originally merged to 'next' on 2012-08-10) "git difftool --dir-diff" learned to use symbolic links to prepare temporary copy of the working tree when available. Will merge to 'master' as part of the second batch. * jk/no-more-pre-exec-callback (2012-06-05) 1 commit - pager: drop "wait for output to run less" hack (Originally merged to 'next' on 2012-07-23) Will defer until the end of the 2012, waiting for older "less" to go extinct. * mm/push-default-switch-warning (2012-06-24) 1 commit (merged to 'next' on 2012-08-20 at 553e6c0) + push: start warning upcoming default change for push.default (Originally merged to 'next' on 2012-06-26) In the next major release, we will switch "git push [$there]" that does not say what to push from the traditional "matching" to the updated "simple" semantics, that pushes the current branch to the branch with the same name only when the current branch is set to integrate with that remote branch (all other cases will error out). Will merge to 'master' as part of the second batch. -------------------------------------------------- [Discarded] * jc/sanitize-nkd-lazy-iconv-open (2012-07-31) 1 commit . macos: lazily initialize iconv Teach the code that works around NKD/NKC gotcha on MacOS to call iconv_open() only when it is necessary, in the hope of avoiding set-up overhead. It turns out that there was no noticeable improvements.