Understanding Merging
Merging is the process of combining the changes in two distinct branches. A merge operation takes changes
that have occurred in the source branch and integrates them into the target
branch. Merging integrates all types of changes in the source branch including
name changes, file edits, file additions, and file delete and undelete changes. If items have been
modified in both the source and target branches, you will be prompted to
resolve conflicts.
Merging can be conducted through Source Control Explorer, or from the command line using the Merge Command.
What Occurs During a Merge Operation
During a merge operation, the following actions occur:
- The merge will identify any added files or folders in the source
branch and try to add the corresponding items in the target branch.
Note A namespace collision can occur if the item being added from the source branch
shares an identical name with an item that has been added to the target branch. Team Foundation does not handle the resolution of this type of conflict;
however, an error message is logged.
- The merge will review the history for each item in the
source branch that also exists in the target branch. For each item, changes
that were made in the source branch that do not exist in the target branch will
be merged to the target branch. If the item has already been modified on the
target branch, a conflict will be detected.
Note During a merge operation, you have
the choice of merging either specific versions of items, or all changes.
How to Merge Changes
Merge operations can be performed from either the Source Control Explorer or the
command line using the Merge Command.
Merge History
The Team Foundation source control server keeps a historical
record of all merges that have occurred. You can review this information from
the command line using the Merges Command.