ec167793d8
This is an attempt to address the issue raised on #git channel recently by Carl Worth. After a conflicted automerge, "git diff" shows a combined diff to give you how the tentative automerge result differs from what came from each branch. During a complex merge, it is tempting to be able to resolve a few paths at a time, mark them "I've dealt with them" with git-update-index to unclutter the next "git diff" output, and keep going. However, when the final result does not compile or otherwise found to be a mismerge, the workflow to fix the mismerged paths suddenly changes to "git diff HEAD -- path" (to get a diff from our HEAD before merging) and "git diff MERGE_HEAD -- path" (to get a diff from theirs), and it cannot show the combined anymore. With git-unresolve <paths>..., the versions from our branch and their branch for specified blobs are placed in stage #2 and stage #3, without touching the working tree files. This gives you the combined diff back for easier review, along with "diff --ours" and "diff --theirs". One thing it does not do is to place the base in stage #1; this means "diff --base" would behave differently between the run immediately after a conflicted three-way merge, and the run after an update-index by mistake followed by a git-unresolve. We could theoretically run merge-base between HEAD and MERGE_HEAD to find which tree to place in stage #1, but reviewing "diff --base" is not that useful so.... Signed-off-by: Junio C Hamano <junkio@cox.net>
137 lines
1.8 KiB
Plaintext
137 lines
1.8 KiB
Plaintext
GIT-VERSION-FILE
|
|
git
|
|
git-add
|
|
git-am
|
|
git-annotate
|
|
git-apply
|
|
git-applymbox
|
|
git-applypatch
|
|
git-archimport
|
|
git-bisect
|
|
git-branch
|
|
git-cat-file
|
|
git-check-ref-format
|
|
git-checkout
|
|
git-checkout-index
|
|
git-cherry
|
|
git-cherry-pick
|
|
git-clean
|
|
git-clone
|
|
git-clone-pack
|
|
git-commit
|
|
git-commit-tree
|
|
git-convert-objects
|
|
git-count-objects
|
|
git-cvsexportcommit
|
|
git-cvsimport
|
|
git-cvsserver
|
|
git-daemon
|
|
git-diff
|
|
git-diff-files
|
|
git-diff-index
|
|
git-diff-stages
|
|
git-diff-tree
|
|
git-describe
|
|
git-fetch
|
|
git-fetch-pack
|
|
git-findtags
|
|
git-fmt-merge-msg
|
|
git-format-patch
|
|
git-fsck-objects
|
|
git-get-tar-commit-id
|
|
git-grep
|
|
git-hash-object
|
|
git-http-fetch
|
|
git-http-push
|
|
git-imap-send
|
|
git-index-pack
|
|
git-init-db
|
|
git-local-fetch
|
|
git-log
|
|
git-lost-found
|
|
git-ls-files
|
|
git-ls-remote
|
|
git-ls-tree
|
|
git-mailinfo
|
|
git-mailsplit
|
|
git-merge
|
|
git-merge-base
|
|
git-merge-index
|
|
git-merge-tree
|
|
git-merge-octopus
|
|
git-merge-one-file
|
|
git-merge-ours
|
|
git-merge-recursive
|
|
git-merge-resolve
|
|
git-merge-stupid
|
|
git-mktag
|
|
git-mktree
|
|
git-name-rev
|
|
git-mv
|
|
git-pack-redundant
|
|
git-pack-objects
|
|
git-parse-remote
|
|
git-patch-id
|
|
git-peek-remote
|
|
git-prune
|
|
git-prune-packed
|
|
git-pull
|
|
git-push
|
|
git-read-tree
|
|
git-rebase
|
|
git-receive-pack
|
|
git-relink
|
|
git-repack
|
|
git-repo-config
|
|
git-request-pull
|
|
git-rerere
|
|
git-reset
|
|
git-resolve
|
|
git-rev-list
|
|
git-rev-parse
|
|
git-revert
|
|
git-rm
|
|
git-send-email
|
|
git-send-pack
|
|
git-sh-setup
|
|
git-shell
|
|
git-shortlog
|
|
git-show
|
|
git-show-branch
|
|
git-show-index
|
|
git-ssh-fetch
|
|
git-ssh-pull
|
|
git-ssh-push
|
|
git-ssh-upload
|
|
git-status
|
|
git-stripspace
|
|
git-svnimport
|
|
git-symbolic-ref
|
|
git-tag
|
|
git-tar-tree
|
|
git-unpack-file
|
|
git-unpack-objects
|
|
git-unresolve
|
|
git-update-index
|
|
git-update-ref
|
|
git-update-server-info
|
|
git-upload-pack
|
|
git-var
|
|
git-verify-pack
|
|
git-verify-tag
|
|
git-whatchanged
|
|
git-write-tree
|
|
git-core-*/?*
|
|
test-date
|
|
test-delta
|
|
common-cmds.h
|
|
*.tar.gz
|
|
*.dsc
|
|
*.deb
|
|
git-core.spec
|
|
*.exe
|
|
*.[ao]
|
|
*.py[co]
|
|
config.mak
|
|
git-blame
|