* What's cooking in git.git (Apr 2012, #05; Thu, 12)
@ 2012-04-12 22:41 Junio C Hamano
2012-04-15 11:10 ` Clemens Buchacher
0 siblings, 1 reply; 12+ messages in thread
From: Junio C Hamano @ 2012-04-12 22:41 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'.
This issue describes the state of my tree in preparation for opening the
post 1.7.10 cycle. The 'next' branch has been rewound.
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]
* mh/ref-api (2012-04-10) 13 commits
- do_for_each_ref(): only iterate over the subtree that was requested
- refs: store references hierarchically
- sort_ref_dir(): simplify logic
- refs.c: rename ref_array -> ref_dir
- struct ref_entry: nest the value part in a union
- check_refname_component(): return 0 for zero-length components
- free_ref_entry(): new function
- names_conflict(): simplify implementation
- repack_without_ref(): reimplement using do_for_each_ref_in_array()
- do_for_each_ref_in_arrays(): new function
- do_for_each_ref_in_array(): new function
- refs: manage current_ref within do_one_ref()
- refs.c: reorder definitions more logically
Allows walking only a sub-hierarchy in refs/*.
Will merge to 'next'.
* jc/maint-blame-minimal (2012-04-11) 1 commit
- blame: accept --need-minimal
"git blame" started missing quite a few changes from the origin since we
stopped using the diff minimalization by default in v1.7.2 era.
Will merge to 'next'.
* jk/repack-no-explode-objects-from-old-pack (2012-04-11) 1 commit
- gc: do not explode objects which will be immediately pruned
Will merge to 'next'.
* ld/git-p4-tags-and-labels (2012-04-11) 2 commits
- git p4: import/export of labels to/from p4
- git p4: Fixing script editor checks
(this branch uses pw/git-p4.)
* lt/octopus-simplify (2012-04-12) 1 commit
- Make 'git merge' simplify parents earlier
Octopus merge strategy did not reduce heads that are recorded in the final
commit. This was done off-list.
* mr/fetch-call-a-non-branch-a-ref (2012-04-11) 1 commit
- fetch: Only call a new ref a "branch" if it's under refs/heads/.
The change itself may be sensible, but it exposes a funny in the vicinity
about recursive submodule fetching behaviour.
* nh/empty-rebase (2012-04-11) 3 commits
- git-cherry-pick: add test to validate new options
- git-cherry-pick: add --keep-redundant-commits option
- git-cherry-pick: add allow-empty option
Waiting for a reroll.
* sl/test-wc-l-line-count (2012-04-11) 1 commit
- tests: modernise style: more uses of test_line_count
Will merge to 'next'.
* zj/upstream-error-message (2012-04-11) 5 commits
- i18n: mark @{upstream} error messages for translation
- Be more specific if upstream branch is not fetched
- Provide better message for barnhc_wiht_tpyo@{u}
- Provide branch name in error message when using @{u}
- t1507: add additional tests for @{upstream}
Waiting for a reroll.
* fc/completion-tests (2012-04-12) 1 commit
- tests: add initial bash completion tests
Will merge to 'next'.
--------------------------------------------------
[Stalled]
* nl/http-proxy-more (2012-04-12) 6 commits
- fixup? 6e17b8c
- http: rename HTTP_REAUTH to HTTP_AUTH_RETRY
- http: Avoid limit of retrying request only twice
- http: handle proxy authentication failure (error 407)
- http: handle proxy proactive authentication
- http: try http_proxy env var when http.proxy config option is not set
The code to talk to http proxies learn to use the same credential
API used to talk to the final http destinations.
Kicked back to 'pu', as it breaks the proxied codepath quite badly.
* lp/maint-diff-three-dash-with-graph (2012-03-20) 3 commits
- t4202: add test for "log --graph --stat -p" separator lines
- log --graph: fix break in graph lines
- log --graph --stat: three-dash separator should come after graph lines
With a review from Zbigniew, I have been expecting that this would be
rerolled, but that didn't happen.
Waiting for a reroll.
* cn/apply-fix-ws-can-lengthen-lines (2012-03-11) 1 commit
. apply: reallocate the postimage buffer when needed
Attempts to address an ancient bug that dates back to the addition
of an oddball "tab-in-indent" whitespace breakage class that wants
to have longer lines than the original when fixing things up; broken
and results in double-frees.
Will discard shortly if nothing happens.
* nd/columns (2012-03-13) 12 commits
- column: support grouping entries
- column: support "denser" mode
- ls-files: support --column
- tag: add --column
- column: support piping stdout to external git-column process
- status: add --column
- branch: add --column
- help: reuse print_columns() for help -a
- column: add dense layout support
- column: add columnar layout
- Stop starting pager recursively
- Add column layout skeleton and git-column
Modulo minor nits, looked nicer than the previous round and getting closer
to completion but nothing has happened recently.
Will discard shortly if nothing happens.
* ss/git-svn-prompt-sans-terminal (2012-01-04) 3 commits
- fixup! 15eaaf4
- git-svn, perl/Git.pm: extend Git::prompt helper for querying users
- perl/Git.pm: "prompt" helper to honor GIT_ASKPASS and SSH_ASKPASS
The bottom one has been replaced with a rewrite based on comments
from Ævar. The second one needs more work, both in perl/Git.pm and
prompt.c, to give precedence to tty over SSH_ASKPASS when terminal
is available.
Will discard shortly if nothing happens.
* jc/split-blob (2012-04-03) 7 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
- varint: make it available outside the context of pack
(this branch is tangled with jc/index-v4.)
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 almost two months 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" fanboys, 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]
* jh/apply-free-patch (2012-04-11) 9 commits
- apply: document buffer ownership rules across functions
- apply: tighten constness of line buffer
- apply: drop unused macro
- apply: free unused fragments for submodule patch
- apply: free patch->result
- apply: release memory for fn_table
- apply: free patch->{def,old,new}_name fields
- apply: rename free_patch() to free_patch_list()
- apply: do not leak patches and fragments
Valgrind reports quite a lot of discarded memory inside apply.
Will merge to 'next'.
* nd/threaded-index-pack (2012-04-11) 3 commits
- index-pack: support multithreaded delta resolving
- index-pack: split second pass obj handling into own function
- compat/win32/pthread.h: Add an pthread_key_delete() implementation
* bw/submodule-sed-solaris (2012-04-09) 1 commit
(merged to 'next' on 2012-04-12 at 3bf1d83)
+ Avoid bug in Solaris xpg4/sed as used in submodule
* cb/http-multi-curl-auth (2012-04-10) 2 commits
- fix http auth with multiple curl handles
- http auth fails with multiple curl handles
Fixes http authentication breakage when we keep multiple HTTP requests in
flight using curl-multi.
I haven't looked at Peff's follow-up deeply yet. Perhaps a reroll is
coming?
* jk/rebase-i-submodule-conflict-only (2012-04-09) 1 commit
- rebase -i continue: don't skip commits that only change submodules
Giving "--continue" to a conflicted "rebase -i" session skipped a commit
that only results in changes to submodules.
Will merge to 'next'.
* ms/remote-usage-string (2012-04-09) 1 commit
- remote: update builtin usage
As an independent follow-up, we may want to rethink how the overall usage
string and subcommand usage strings are maintained.
Will merge to 'next'.
* pw/fast-import-dataref-parsing (2012-04-10) 1 commit
- fast-import: tighten parsing of datarefs
Will merge to 'next'.
* pw/git-p4 (2012-04-09) 3 commits
- git p4: use "git p4" directly in tests
- git p4: update name in script
- git-p4: move to toplevel
(this branch is used by ld/git-p4-tags-and-labels.)
Will merge to 'next'.
* rl/show-empty-prefix (2012-04-10) 1 commit
- rev-parse --show-prefix: add in trailing newline
Will merge to 'next'.
* tr/xdiff-fast-hash (2012-04-09) 1 commit
- xdiff: load full words in the inner loop of xdl_hash_record
Will merge to 'next'.
* jc/index-v4 (2012-04-04) 10 commits
- update-index: upgrade/downgrade on-disk index version
- read-cache.c: write prefix-compressed names in the index
- read-cache.c: read prefix-compressed names in index on-disk version v4
- read-cache.c: move code to copy incore to ondisk cache to a helper function
- read-cache.c: move code to copy ondisk to incore cache to a helper function
- read-cache.c: report the header version we do not understand
- read-cache.c: make create_from_disk() report number of bytes it consumed
- read-cache.c: allow unaligned mapping of the index file
- cache.h: hide on-disk index details
- varint: make it available outside the context of pack
(this branch is tangled with jc/split-blob.)
Trivially shrinks the on-disk size of the index file to save both I/O and
checksum overhead. The "v4" format represented here may not be what we
eventually want to have, but the preparatory refactoring steps and the way
how backward compatibility is retained should give plenty to learn to GSoC
student-hopefuls.
Will merge to 'next', if nobody objects.
* jk/add-p-skip-conflicts (2012-04-05) 1 commit
(merged to 'next' on 2012-04-12 at e65ceb1)
+ add--interactive: ignore unmerged entries in patch mode
Excludes conflicted paths from "add -p" processing, as it is not prepared
to handle them.
* bw/spawn-via-shell-path (2012-04-03) 1 commit
(merged to 'next' on 2012-04-12 at 0ff833b)
+ Use SHELL_PATH from build system in run_command.c:prepare_shell_cmd
"sh" on the user's PATH may be utterly broken on some systems;
consistently use SHELL_PATH even from inside run-command API.
* jc/commit-unedited-template (2012-04-03) 5 commits
(merged to 'next' on 2012-04-12 at a2e153b)
+ Documentation/git-commit: rephrase the "initial-ness" of templates
+ git-commit.txt: clarify -t requires editing message
+ commit: rephrase the error when user did not touch templated log message
+ commit: do not trigger bogus "has templated message edited" check
+ t7501: test the right kind of breakage
When "git commit --template F" errors out because the user did not touch
the message, it claimed that it aborts due to "empty message", which was
utterly wrong.
* jc/push-upstream-sanity (2012-04-05) 1 commit
(merged to 'next' on 2012-04-12 at 288e1ad)
+ push: error out when the "upstream" semantics does not make sense
Fix broken 'push to upstream' implementation. "git push $there" without
refspec, when the current branch is set to push to a remote different from
$there, used to push to $there using the upstream information to a remote
unreleated to $there.
* jk/http-backend-keep-committer-ident-env (2012-03-30) 1 commit
(merged to 'next' on 2012-04-12 at b2d0136)
+ http-backend: respect existing GIT_COMMITTER_* variables
The smart-http backend used to always override GIT_COMMITTER_* variables
with REMOTE_USER and REMOTE_ADDR.
* mk/gitweb-diff-hl (2012-04-11) 8 commits
- gitweb: Refinement highlightning in combined diffs
- gitweb: Highlight interesting parts of diff
- gitweb: Push formatting diff lines to print_diff_chunk()
- gitweb: Use print_diff_chunk() for both side-by-side and inline diffs
- gitweb: Extract print_sidebyside_diff_lines()
- gitweb: Pass esc_html_hl_regions() options to esc_html()
- gitweb: esc_html_hl_regions(): Don't create empty <span> elements
- gitweb: Use descriptive names in esc_html_hl_regions()
Will merge to 'next'.
* it/fetch-pack-many-refs (2012-04-10) 4 commits
- remote-curl: main test case for the OS command line overflow
- fetch-pack: test cases for the new --stdin option
- remote-curl: send the refs to fetch-pack on stdin
- fetch-pack: new --stdin option to read refs from stdin
Will merge to 'next'.
* jn/debian-customizes-default-editor (2012-04-10) 2 commits
- var doc: advertise current DEFAULT_PAGER and DEFAULT_EDITOR settings
- var doc: default editor and pager are configurable at build time
Will merge to 'next'.
* rs/commit-list-sort-in-batch (2012-04-11) 3 commits
- revision: insert unsorted, then sort in prepare_revision_walk()
- commit: use mergesort() in commit_list_sort_by_date()
- add mergesort() for linked lists
Will merge to 'next'.
* hv/submodule-recurse-push (2012-03-30) 3 commits
- push: teach --recurse-submodules the on-demand option
- Refactor submodule push check to use string list instead of integer
- Teach revision walking machinery to walk multiple times sequencially
Will merge to 'next'.
* jk/branch-quiet (2012-03-26) 2 commits
(merged to 'next' on 2012-04-12 at 7d0a438)
+ teach "git branch" a --quiet option
+ checkout: suppress tracking message with "-q"
Even with "-q"uiet option, "checkout" used to report setting up tracking.
Also "branch" learns "-q"uiet option to squelch informational message.
* jk/run-command-eacces (2012-04-05) 2 commits
(merged to 'next' on 2012-04-12 at ef3782e)
+ run-command: treat inaccessible directories as ENOENT
+ compat/mingw.[ch]: Change return type of exec functions to int
When PATH contains an unreadable directory, alias expansion code did not
kick in, and failed with an error that said "git-subcmd" was not found.
* jb/am-include (2012-03-28) 1 commit
(merged to 'next' on 2012-04-12 at ddbf96d)
+ am: support --include option
* jc/am-report-3way (2012-03-28) 1 commit
(merged to 'next' on 2012-04-12 at cf5d599)
+ am -3: list the paths that needed 3-way fallback
* rs/combine-diff-zero-context-at-the-beginning (2012-03-25) 1 commit
(merged to 'next' on 2012-04-12 at b4d92e3)
+ combine-diff: fix loop index underflow
Fixes an age old corner case bug in combine diff (only triggered with -U0
and the hunk at the beginning of the file needs to be shown).
* sl/autoconf (2012-03-26) 3 commits
(merged to 'next' on 2012-04-12 at 68f346d)
+ configure: be more idiomatic
+ configure: avoid some code repetitions thanks to m4_{push,pop}def
+ configure: move definitions of private m4 macros before AC_INIT invocation
Updates our configure.ac to follow a better "autoconf" style.
* wk/gitweb-snapshot-use-if-modified-since (2012-03-30) 3 commits
(merged to 'next' on 2012-04-12 at 611d318)
+ gitweb: add If-Modified-Since handling to git_snapshot().
+ gitweb: refactor If-Modified-Since handling
+ gitweb: add `status` headers to git_feed() responses.
Makes 'snapshot' request to "gitweb" honor If-Modified-Since: header,
based on the commit date.
* jk/diff-no-rename-empty (2012-03-23) 4 commits
(merged to 'next' on 2012-04-12 at d1d95c5)
+ merge-recursive: don't detect renames of empty files
+ teach diffcore-rename to optionally ignore empty content
+ make is_empty_blob_sha1 available everywhere
+ drop casts from users EMPTY_TREE_SHA1_BIN
Forbids rename detection logic from matching two empty files as renames
during merge-recursive to prevent mismerges.
* th/difftool-diffall (2012-04-04) 8 commits
- difftool: print list of valid tools with '--tool-help'
- difftool: teach difftool to handle directory diffs
- difftool: eliminate setup_environment function
- difftool: stop appending '.exe' to git
- difftool: remove explicit change of PATH
- difftool: exit(0) when usage is printed
- difftool: add '--no-gui' option
- difftool: parse options using Getopt::Long
Rolls the two-directory-diff logic from diffall script (in contrib/) into
"git difftool" framework.
Still being reworked.
* jc/maint-clean-nested-worktree-in-subdir (2012-03-15) 2 commits
(merged to 'next' on 2012-04-12 at 280a6e5)
+ clean: preserve nested git worktree in subdirectories
+ remove_dir_recursively(): Add flag for skipping removal of toplevel dir
(this branch is tangled with jh/notes-merge-in-git-dir-worktree.)
Originally merged to 'next' on 2012-03-20
"git clean -d -f" (not "-d -f -f") is supposed to protect nested working
trees of independent git repositories that exist in the current project
working tree from getting removed, but the protection applied only to such
working trees that are at the top-level of the current project by mistake.
* ct/advise-push-default (2012-04-12) 3 commits
(merged to 'next' on 2012-04-12 at b0613cd)
+ Fix httpd tests that broke when non-ff push advice changed
+ clean up struct ref's nonfastforward field
+ push: Provide situational hints for non-fast-forward errors
Breaks down the cases in which "git push" fails due to non-ff into three
categories, and gives separate advise messages. This should be a good
change regardless of mm/push-default-switch-warning topic.
* nl/rebase-i-cheat-sheet (2012-03-20) 1 commit
(merged to 'next' on 2012-04-12 at cd76fcb)
+ rebase -i: remind that the lines are top-to-bottom
Originally merged to 'next' on 2012-03-20
* da/difftool-test (2012-03-19) 1 commit
(merged to 'next' on 2012-04-11 at f245c01)
+ t7800: Test difftool passing arguments to diff
Makes sure "difftool" options can be given in any order.
Will merge to 'master'.
* jh/notes-merge-in-git-dir-worktree (2012-03-15) 4 commits
(merged to 'next' on 2012-04-11 at 6042ef5)
+ notes-merge: Don't remove .git/NOTES_MERGE_WORKTREE; it may be the user's cwd
+ notes-merge: use opendir/readdir instead of using read_directory()
+ t3310: illustrate failure to "notes merge --commit" inside $GIT_DIR/
+ remove_dir_recursively(): Add flag for skipping removal of toplevel dir
(this branch is tangled with jc/maint-clean-nested-worktree-in-subdir.)
Originally merged to 'next' on 2012-03-20
Running "notes merge --commit" failed to perform correctly when run
from any directory inside $GIT_DIR/. When "notes merge" stops with
conflicts, $GIT_DIR/NOTES_MERGE_WORKTREE is the place a user edits
to resolve it.
Will merge to 'master'.
* jn/diffstat-tests (2012-03-13) 7 commits
(merged to 'next' on 2012-04-11 at 7365e41)
+ diffstat summary line varies by locale: miscellany
+ test: use numstat instead of diffstat in binary-diff test
+ test: use --numstat instead of --stat in "git stash show" tests
+ test: test cherry-pick functionality and output separately
+ test: modernize funny-names test style
+ test: use numstat instead of diffstat in funny-names test
+ test: use test_i18ncmp when checking --stat output
Originally merged to 'next' on 2012-03-20
Some tests checked the "diff --stat" output when they do not have to,
which unnecessarily made things harder to verify under GETTEXT_POISON.
Will merge to 'master'.
* tr/maint-word-diff-regex-sticky (2012-03-14) 3 commits
(merged to 'next' on 2012-04-11 at 24d14de)
+ diff: tweak a _copy_ of diff_options with word-diff
+ diff: refactor the word-diff setup from builtin_diff_cmd
+ t4034: diff.*.wordregex should not be "sticky" in --word-diff
Originally merged to 'next' on 2012-03-20
The regexp configured with wordregex was incorrectly reused across
files.
Will merge to 'master'.
* zj/test-cred-helper-nicer-prove (2012-03-15) 2 commits
(merged to 'next' on 2012-04-11 at 9169614)
+ t0303: resurrect commit message as test documentation
+ t0303: immediately bail out w/o GIT_TEST_CREDENTIAL_HELPER
Originally merged to 'next' on 2012-03-20
Minor improvement to t0303.
Will merge to 'master'.
* jc/commit-hook-authorship (2012-03-11) 3 commits
(merged to 'next' on 2012-04-11 at 15ec4d4)
+ commit: pass author/committer info to hooks
+ t7503: does pre-commit-hook learn authorship?
+ ident.c: add split_ident_line() to parse formatted ident line
(this branch is tangled with jc/run-hook-env-1.)
Originally merged to 'next' on 2012-03-12
"git commit --author=$name" did not tell the name that was being
recorded in the resulting commit to hooks, even though it does do so
when the end user overrode the authorship via the "GIT_AUTHOR_NAME"
environment variable.
Will merge to 'master'.
* jc/run-hook-env-1 (2012-03-11) 3 commits
- run_hook(): enhance the interface to pass arbitrary environment
+ t7503: does pre-commit-hook learn authorship?
+ ident.c: add split_ident_line() to parse formatted ident line
(this branch is tangled with jc/commit-hook-authorship.)
Not urgent.
Updates run_hook() API to be much less specific to "commit". It would
only be useful if people start doing more interesting things with hooks.
* jc/diff-algo-cleanup (2012-02-19) 2 commits
(merged to 'next' on 2012-04-11 at f2c6b9a)
+ xdiff: PATIENCE/HISTOGRAM are not independent option bits
+ xdiff: remove XDL_PATCH_* macros
Originally merged to 'next' on 2012-03-15
Resurrects the preparatory clean-up patches from another topic that was
discarded, as this would give a saner foundation to build on diff.algo
configuration option series.
Will merge to 'master'.
* rs/unpack-trees-leakfix (2012-04-10) 2 commits
(merged to 'next' on 2012-04-12 at 6958b54)
+ unpack-trees: plug minor memory leak
+ unpack-trees: don't perform any index operation if we're not merging
Originally merged to 'next' on 2012-03-07
* mm/push-default-switch-warning (2012-03-09) 1 commit
- push: start warning upcoming default change for push.default
This resurrects an ancient patch I wrote during a discussion we had in the
1.6.3-1.6.4 era. This should probably come after ct/advise-push-default
topic and at that point the advise messages need to be rephrased, taking
the future default change into account.
Will kick back to 'pu'.
* jc/fmt-merge-msg-people (2012-03-13) 1 commit
(merged to 'next' on 2012-04-12 at 4c2031c)
+ fmt-merge-msg: show those involved in a merged series
The "fmt-merge-msg" command learns to list the primary contributors
involved in the side topic you are merging.
* nd/stream-more (2012-03-07) 7 commits
(merged to 'next' on 2012-04-11 at b17684d)
+ update-server-info: respect core.bigfilethreshold
+ fsck: use streaming API for writing lost-found blobs
+ show: use streaming API for showing blobs
+ parse_object: avoid putting whole blob in core
+ cat-file: use streaming API to print blobs
+ Add more large blob test cases
+ streaming: make streaming-write-entry to be more reusable
Originally merged to 'next' on 2012-03-07
Use API to read blob data in smaller chunks in more places to
reduce the memory footprint. In general, looked fairly good.
Will merge to 'master'.
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
2012-04-12 22:41 What's cooking in git.git (Apr 2012, #05; Thu, 12) Junio C Hamano
@ 2012-04-15 11:10 ` Clemens Buchacher
0 siblings, 0 replies; 12+ messages in thread
From: Clemens Buchacher @ 2012-04-15 11:10 UTC (permalink / raw)
To: Junio C Hamano; +Cc: git
On Thu, Apr 12, 2012 at 03:41:55PM -0700, Junio C Hamano wrote:
>
> * cb/http-multi-curl-auth (2012-04-10) 2 commits
> - fix http auth with multiple curl handles
> - http auth fails with multiple curl handles
>
> Fixes http authentication breakage when we keep multiple HTTP requests in
> flight using curl-multi.
>
> I haven't looked at Peff's follow-up deeply yet. Perhaps a reroll is
> coming?
I think Peff's follow-up is based on the commits you already have in
cb/http-multi-curl-auth.
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
@ 2012-04-16 6:26 Michal Kiedrowicz
2012-04-16 14:57 ` Linus Torvalds
0 siblings, 1 reply; 12+ messages in thread
From: Michal Kiedrowicz @ 2012-04-16 6:26 UTC (permalink / raw)
To: Junio C Hamano; +Cc: Linus Torvalds, git
Junio C Hamano <gitster@pobox.com> wrote:
> * lt/octopus-simplify (2012-04-12) 1 commit
> - Make 'git merge' simplify parents earlier
>
> Octopus merge strategy did not reduce heads that are recorded in the
> final commit. This was done off-list.
Heh, this seems to fix the issue I reported in [1], except... it
doesn't work for the testcase I posted :). The problem is that this
commit makes Git 'fast-forward' to the first commit from remoteheads,
not from the reduced heads. See:
$ git init /tmp/merge
Initialized empty Git repository in /tmp/merge/.git/
$ cd /tmp/merge
$ echo a>>a && git add a && git commit -m first
[master (root-commit) 7422615] first
1 file changed, 1 insertion(+)
create mode 100644 a
$ echo a>>a && git add a && git commit -m second
[master 0ba02e5] second
1 file changed, 1 insertion(+)
$ echo a>>a && git add a && git commit -m third
[master 9bd11ac] third
1 file changed, 1 insertion(+)
$ git checkout master~2
HEAD is now at 7422615... first
# This is OK:
$ git merge master master~1
Updating 7422615..9bd11ac
Fast-forward
a | 2 ++
1 file changed, 2 insertions(+)
$ git checkout master~2
Previous HEAD position was 9bd11ac... third
HEAD is now at 7422615... first
# This is not OK:
$ git merge master~1 master
Updating 7422615..0ba02e5
Fast-forward
a | 1 +
1 file changed, 1 insertion(+)
Ths following patch fixes that.
[1] http://permalink.gmane.org/gmane.comp.version-control.git/190625
Signed-off-by: Michał Kiedrowicz <michal.kiedrowicz@gmail.com>
(if this fix need a signed-off)
---
diff --git a/builtin/merge.c b/builtin/merge.c
index f5947b9..075c99b 100644
--- a/builtin/merge.c
+++ b/builtin/merge.c
@@ -1388,13 +1388,13 @@ int cmd_merge(int argc, const char **argv, const char *prefix)
if (verbosity >= 0)
printf(_("Updating %s..%s\n"),
hex,
- find_unique_abbrev(remoteheads->item->object.sha1,
+ find_unique_abbrev(parents->item->object.sha1,
DEFAULT_ABBREV));
strbuf_addstr(&msg, "Fast-forward");
if (have_message)
strbuf_addstr(&msg,
" (no commit created; -m option ignored)");
- commit = remoteheads->item;
+ commit = parents->item;
if (!commit) {
ret = 1;
goto done;
^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
2012-04-16 6:26 Michal Kiedrowicz
@ 2012-04-16 14:57 ` Linus Torvalds
2012-04-16 17:29 ` Junio C Hamano
2012-04-16 17:36 ` Junio C Hamano
0 siblings, 2 replies; 12+ messages in thread
From: Linus Torvalds @ 2012-04-16 14:57 UTC (permalink / raw)
To: Michal Kiedrowicz; +Cc: Junio C Hamano, git
On Sun, Apr 15, 2012 at 11:26 PM, Michal Kiedrowicz
<michal.kiedrowicz@gmail.com> wrote:
>
> Heh, this seems to fix the issue I reported in [1], except... it
> doesn't work for the testcase I posted :). The problem is that this
> commit makes Git 'fast-forward' to the first commit from remoteheads,
> not from the reduced heads.
Ack, good catch.
Thinking some more about this thing, I think we have a similar issue
with the "Already up-to-date." thing.
It too had the "only one remote-head" test, which is wrong - what if
you try to do a octopus merge with *two* commits that are different,
and are both in the past? It will fail the "Already up-to-date" test,
and then do a "fast-forward" to the first remote parent, if I read the
code right..
So I think the "Already up-to-date" case should also be fixed, and in
fact it becomes much more natural now that we have finalized the
parents: we just check whether the one remaining parent is the same as
HEAD.
So Ack on Michal's patch, but I think we also should do the appended
equivalent thing for the fast-forward test on top of it (it's
white-space damaged, sorry).
Trivially tested with
git merge HEAD^ HEAD^^
which did the wrong thing before, and now works.
Linus
---
builtin/merge.c | 3 +--
1 file changed, 1 insertion(+), 2 deletions(-)
diff --git a/builtin/merge.c b/builtin/merge.c
index 016a4dbee3b5..28fb5c9d6ada 100644
--- a/builtin/merge.c
+++ b/builtin/merge.c
@@ -1370,8 +1370,7 @@ int cmd_merge(int argc, const char **argv, const
char *prefix)
if (!common)
; /* No common ancestors found. We need a real merge. */
- else if (!remoteheads->next && !common->next &&
- common->item == remoteheads->item) {
+ else if (!parents->next && parents->item == head_commit) {
/*
* If head can reach all the merge then we are up to date.
* but first the most common case of merging one remote.
^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
2012-04-16 14:57 ` Linus Torvalds
@ 2012-04-16 17:29 ` Junio C Hamano
2012-04-16 17:50 ` Linus Torvalds
2012-04-16 17:36 ` Junio C Hamano
1 sibling, 1 reply; 12+ messages in thread
From: Junio C Hamano @ 2012-04-16 17:29 UTC (permalink / raw)
To: Linus Torvalds; +Cc: Michal Kiedrowicz, git
Linus Torvalds <torvalds@linux-foundation.org> writes:
> Trivially tested with
>
> git merge HEAD^ HEAD^^
>
> which did the wrong thing before, and now works.
>
> Linus
>
> ---
> builtin/merge.c | 3 +--
> 1 file changed, 1 insertion(+), 2 deletions(-)
>
> diff --git a/builtin/merge.c b/builtin/merge.c
> index 016a4dbee3b5..28fb5c9d6ada 100644
> --- a/builtin/merge.c
> +++ b/builtin/merge.c
> @@ -1370,8 +1370,7 @@ int cmd_merge(int argc, const char **argv, const
> char *prefix)
>
> if (!common)
> ; /* No common ancestors found. We need a real merge. */
> - else if (!remoteheads->next && !common->next &&
> - common->item == remoteheads->item) {
> + else if (!parents->next && parents->item == head_commit) {
When everybody in remote_heads is an ancestor of the current HEAD,
finalize_parents() would have reduced parents to a single element list
with HEAD on it, and we are "already up-to-date". Ok.
I wonder if use of remoteheads later in the same function are correct,
though. We equate "!remoteheads->next" and "We are not doing octopus",
for example.
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
2012-04-16 14:57 ` Linus Torvalds
2012-04-16 17:29 ` Junio C Hamano
@ 2012-04-16 17:36 ` Junio C Hamano
2012-04-16 18:02 ` Linus Torvalds
1 sibling, 1 reply; 12+ messages in thread
From: Junio C Hamano @ 2012-04-16 17:36 UTC (permalink / raw)
To: Michal Kiedrowicz, Linus Torvalds; +Cc: git
Linus Torvalds <torvalds@linux-foundation.org> writes:
> So Ack on Michal's patch, but I think we also should do the appended
> equivalent thing for the fast-forward test on top of it (it's
> white-space damaged, sorry).
>
> Trivially tested with
>
> git merge HEAD^ HEAD^^
>
> which did the wrong thing before, and now works.
And it seems to break 6028 ("merge -s ours" and "merge -s subtree"
up-to-date) X-<....
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
2012-04-16 17:29 ` Junio C Hamano
@ 2012-04-16 17:50 ` Linus Torvalds
2012-04-16 22:03 ` Junio C Hamano
0 siblings, 1 reply; 12+ messages in thread
From: Linus Torvalds @ 2012-04-16 17:50 UTC (permalink / raw)
To: Junio C Hamano; +Cc: Michal Kiedrowicz, git
On Mon, Apr 16, 2012 at 10:29 AM, Junio C Hamano <gitster@pobox.com> wrote:
>
> I wonder if use of remoteheads later in the same function are correct,
> though. We equate "!remoteheads->next" and "We are not doing octopus",
> for example.
I do think it would generally be a great idea to never use
"remoteheads" at all. An octopus merge that has been simplified to
just two parents isn't really an octopus merge any more.
So I think you're probably right - we should try to avoid using
remoteheads entirely, and any use is suspect
Linus
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
2012-04-16 17:36 ` Junio C Hamano
@ 2012-04-16 18:02 ` Linus Torvalds
2012-04-16 18:33 ` Linus Torvalds
0 siblings, 1 reply; 12+ messages in thread
From: Linus Torvalds @ 2012-04-16 18:02 UTC (permalink / raw)
To: Junio C Hamano; +Cc: Michal Kiedrowicz, git
On Mon, Apr 16, 2012 at 10:36 AM, Junio C Hamano <gitster@pobox.com> wrote:
>
> And it seems to break 6028 ("merge -s ours" and "merge -s subtree"
> up-to-date) X-<....
Ugh. I don't even get that far - I get to t3410, which breaks.
(This is with both Michal's and my patch applied)
Oddly, running that test in verbose mode seems to imply that it's the
*rebase* that succeeds, not the merges in that test. Maybe I'm reading
the test results wrong, I didn't really try to understand the test
itself ;(
Linus
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
2012-04-16 18:02 ` Linus Torvalds
@ 2012-04-16 18:33 ` Linus Torvalds
2012-04-16 21:32 ` Michał Kiedrowicz
0 siblings, 1 reply; 12+ messages in thread
From: Linus Torvalds @ 2012-04-16 18:33 UTC (permalink / raw)
To: Junio C Hamano; +Cc: Michal Kiedrowicz, git
On Mon, Apr 16, 2012 at 11:02 AM, Linus Torvalds
<torvalds@linux-foundation.org> wrote:
>
> Oddly, running that test in verbose mode seems to imply that it's the
> *rebase* that succeeds, not the merges in that test. Maybe I'm reading
> the test results wrong, I didn't really try to understand the test
> itself ;(
Yes, it's the rebase that succeeds. "git log -g" in the trash
directory shows that we ended up successfully rebasing J2:
commit 5fc34ec1a8ed96664198fefc74121cd052b10861
Reflog: HEAD@{1} (C O Mitter <committer@example.com>)
Reflog message: rebase -i (pick): Merge made by the 'recursive' strategy.
Author: A U Thor <author@example.com>
Date: Thu Apr 7 15:28:13 2005 -0700
J2
while a successful test will fail that.
However, I don't actually see what changed.
Oh - one thing to note is that the *patch* of that successful rebase
is empty. That may be the big clue: we successfully finish the merge
without noticing that it didn't change any state, and we should have
failed it as an empty commit. Hmm?
Linus
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
2012-04-16 18:33 ` Linus Torvalds
@ 2012-04-16 21:32 ` Michał Kiedrowicz
2012-04-17 1:22 ` Linus Torvalds
0 siblings, 1 reply; 12+ messages in thread
From: Michał Kiedrowicz @ 2012-04-16 21:32 UTC (permalink / raw)
To: Linus Torvalds; +Cc: Junio C Hamano, git
Linus Torvalds <torvalds@linux-foundation.org> wrote:
> On Mon, Apr 16, 2012 at 11:02 AM, Linus Torvalds
> <torvalds@linux-foundation.org> wrote:
> >
> > Oddly, running that test in verbose mode seems to imply that it's the
> > *rebase* that succeeds, not the merges in that test. Maybe I'm reading
> > the test results wrong, I didn't really try to understand the test
> > itself ;(
>
> Yes, it's the rebase that succeeds. "git log -g" in the trash
> directory shows that we ended up successfully rebasing J2:
>
> commit 5fc34ec1a8ed96664198fefc74121cd052b10861
> Reflog: HEAD@{1} (C O Mitter <committer@example.com>)
> Reflog message: rebase -i (pick): Merge made by the 'recursive' strategy.
> Author: A U Thor <author@example.com>
> Date: Thu Apr 7 15:28:13 2005 -0700
>
> J2
>
> while a successful test will fail that.
>
> However, I don't actually see what changed.
>
> Oh - one thing to note is that the *patch* of that successful rebase
> is empty. That may be the big clue: we successfully finish the merge
> without noticing that it didn't change any state, and we should have
> failed it as an empty commit. Hmm?
>
> Linus
So, the difference is that `git merge --no-ff HEAD^` used to work, now
it doesn't because we reduce_heads() only if we allow fast-forward (and
even though there is just one remote we merge with, parents contains
two commits). So what about that trivial patch instead (discarding our
previous patches)?
---
diff --git a/builtin/merge.c b/builtin/merge.c
index 08e01e8..27e0026 100644
--- a/builtin/merge.c
+++ b/builtin/merge.c
@@ -1346,6 +1346,8 @@ int cmd_merge(int argc, const char **argv, const char *prefix)
allow_trivial = 0;
}
+ remoteheads = reduce_heads(remoteheads);
+
if (!remoteheads->next)
common = get_merge_bases(head_commit, remoteheads->item, 1);
else {
^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
2012-04-16 17:50 ` Linus Torvalds
@ 2012-04-16 22:03 ` Junio C Hamano
0 siblings, 0 replies; 12+ messages in thread
From: Junio C Hamano @ 2012-04-16 22:03 UTC (permalink / raw)
To: Linus Torvalds; +Cc: Michal Kiedrowicz, git
Linus Torvalds <torvalds@linux-foundation.org> writes:
> On Mon, Apr 16, 2012 at 10:29 AM, Junio C Hamano <gitster@pobox.com> wrote:
>>
>> I wonder if use of remoteheads later in the same function are correct,
>> though. We equate "!remoteheads->next" and "We are not doing octopus",
>> for example.
>
> I do think it would generally be a great idea to never use
> "remoteheads" at all. An octopus merge that has been simplified to
> just two parents isn't really an octopus merge any more.
>
> So I think you're probably right - we should try to avoid using
> remoteheads entirely, and any use is suspect
I am still looking at the codepaths involved. It looks feasible, but
would affect quite a lot of them to deal with many corner cases, I am
afraid.
One of the worst is the "traditional merge format" where format-merge-msg
is called outside "git merge" to prepare the merge message created by "git
pull". We haven't reduced heads at that stage yet, so the message fed to
us will list what happened on the redundant branches.
^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: What's cooking in git.git (Apr 2012, #05; Thu, 12)
2012-04-16 21:32 ` Michał Kiedrowicz
@ 2012-04-17 1:22 ` Linus Torvalds
0 siblings, 0 replies; 12+ messages in thread
From: Linus Torvalds @ 2012-04-17 1:22 UTC (permalink / raw)
To: Michał Kiedrowicz; +Cc: Junio C Hamano, git
2012/4/16 Michał Kiedrowicz <michal.kiedrowicz@gmail.com>:
>
> So, the difference is that `git merge --no-ff HEAD^` used to work, now
> it doesn't because we reduce_heads() only if we allow fast-forward (and
> even though there is just one remote we merge with, parents contains
> two commits). So what about that trivial patch instead (discarding our
> previous patches)?
Yes, I suspect this might work.
And I like how reducing the remoteheads should also automatically fix
the case of the commit messages containing redundant information when
you give the same branch multiple times (assuming you have the whole
merge log thing enabled).
Linus
^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2012-04-17 1:23 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-04-12 22:41 What's cooking in git.git (Apr 2012, #05; Thu, 12) Junio C Hamano
2012-04-15 11:10 ` Clemens Buchacher
-- strict thread matches above, loose matches on Subject: below --
2012-04-16 6:26 Michal Kiedrowicz
2012-04-16 14:57 ` Linus Torvalds
2012-04-16 17:29 ` Junio C Hamano
2012-04-16 17:50 ` Linus Torvalds
2012-04-16 22:03 ` Junio C Hamano
2012-04-16 17:36 ` Junio C Hamano
2012-04-16 18:02 ` Linus Torvalds
2012-04-16 18:33 ` Linus Torvalds
2012-04-16 21:32 ` Michał Kiedrowicz
2012-04-17 1:22 ` Linus Torvalds
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).