Hi Holger, all,

just to add that I effectively integrated this into the
GitFileTree-MergeDriver, including adding the "mcmerge" merge tool inside
the git configuration (where it is only used if you run the command `git
merge-tool --tool=mcmerge`).

With this, you still keep the ability to interactively solve conflicts on
smalltalk source code with another merge tool, such as meld.

Thanks for finding a nice way of resolving metadata conflicts in `git
cherry-pick` and `git rebase`!

Regards,

Thierry

2016-10-04 9:29 GMT+02:00 Holger Freyther <hol...@freyther.de>:

> Good Morning,
>
> Thierry Goubier has merged a change to use the Pharo "merge" as a tool for
> "git mergetool" and in this mail I explain how to configure it, give a
> small example and explain my usecases for it. I am not sure the merge is
> fully working and would like people to test and review (code and merge
> results).
>
>
> Configuration:
>
> edit ~/.gitconfig and put something like:
>
> [mergetool "mcmerge"]
>         cmd = /path/to/GitFileTree-MergeDriver/merge --mergetool $BASE
> $LOCAL $REMOTE $MERGED
>
>
>
> Usage:
>
> $ git mergetool --tool=mcmerge
>
>
>
>
> Use case:
>
> When using git merge to merge n branches, the GitFileTree-MergeDriver will
> be consulted to merge the configured files. The same tools are not used
> when git cherry-pick and git rebase fail to merge. In these case a manual
> call of "git mergetool" is required.
>
> The following cases might be something you encounter.
>
> If you maintain a stable branch but want to backport a specific bugfix
> from a master branch you might use "git cherry-pick <FIX_FROM_MASTER>" and
> end with a merge conflict on the metadata. Using git mergetool
> --tool=mcmerge will help you to resolve it.
>
> You try to contribute to a project that is using git for hosting and have
> either been asked to modify your commits or the master version has been
> updated while your code was under review. In this case you would issue "git
> rebase origin/master". Metadata merge conflicts can be resolved with git
> mergetool.
>
> For work I was creating a bugfix but when thinking of deployment I noticed
> that I need to deploy in two phases. Roll-out the initial part of the fix
> and once it runs everywhere start rolling out the actual bugfix. What I did
> was splitting my bugfix branch in two, merge the first part  into
> repository. After it has been merged other changes were made before the
> update was deployed. To continue to work on the second part of the bugfix I
> rebased it and have used git mergetool to merge the metadata.
>
>
> cheers
>         holger
>

Reply via email to