Resolve Conflicts in Projects Using System Composer Three-Way Merge Tool
This example shows how to use the System Composer Three-Way Merge Tool to investigate and resolve conflicts in System Composer™ architecture models.
In this example, the RobotArchitectureProject
is under Git™ source control with conflicting and non-conflicting changes. The Three-Way Merge tool automatically merges non-conflicting changes before you open the merge report. This example demonstrates how to:
Review the automatic merge choices.
Apply your merge choices to the target file.
Decide how to resolve any remaining conflicts.
After you resolve the conflicts, you commit the resolved architecture to source control.
System Composer Architecture Changes and Conflicts
The RobotArchitectureProject
is under Git source control. When you attempt to merge the changes of a colleague on the main
Git branch into your taskBranch
, the operation results in conflicts.
To resolve the conflicts using the Three-Way Merge tool, examine your local file (Mine), the conflicting revision (Theirs), and the common ancestor of these two files (Base).
Theirs - Your colleague updated the
Motion
component and updated the query used in theComponent View
view.Mine - You updated the name of the
Motion
component, added a new property to thesimpleProfile.sysConnector
stereotype, and updated the query in theComponent View
.
Open System Composer Three-Way Merge Tool
After opening the project, in the project Files view, look for conflicted files. Observe that the RobotArchitecture
file shows a red warning icon in the Git column, which indicates there is at lease one conflict.
To see a detailed report of the conflict(s), right-click the RobotArchitecture
file and select View Conflicts.
View Changes
The Three-Way Merge tool shows the changes to the two System Composer architectures that cause this file conflict.
The Theirs , Base , and Mine trees show the differences between the conflicting revision (Theirs ) , your revision (Mine ), and the base ancestor (Base ) of these files.
The Target tree shows the file into which you merge changes. The tool replaces your local file when you click accept.
The summary table in the bottom right corner shows that the merge tool automatically resolved non-conflicting differences. The table also shows that you must resolve the remaining changes.
To resolve the remaining changes, follow these steps.
Examine a difference by clicking a row in one of the trees. The Merge tool displays the change for each model in an editor, for example, the System Composer canvas, to the right of the Three-Way Merge window.
On the Merge tab, in the Highlight section, choose the models to display by clicking Top Model or Bottom Model.
Resolve Conflicts
The Merge tool automatically merges non-conflicted differences before opening the Three-Way Merge report. In this example, 26 differences were already merged.
The merge tool cannot automatically resolve the conflicted differences. You must choose which design to keep in the target file in the Target tree.
To resolve conflicts, follow these steps.
1. Use the Next button to navigate to the first conflict.
Examine the first change at the top of the Theirs tree by clicking the Motion Component
row. This conflict is caused by the change of the component name. You can adjust the automatic choices using the radio buttons in the Target tree. You can review and adjust all automatic merge choices.
2. To resolve the component name change difference in targetFile
, in the Target tree, select the Mine column for Architecture Property Name
and Simulink Property Name
.
3. On the toolstrip, click Next to review the next conflict. The Component View
is conflicted because you and your colleague changed the color and the query of the view.
For the
Color
parameter of theComponent View
, you can resolve the issue by selecting the Base change forColor
to accept the default color for the view.For the
Component Selection Query
parameter of theComponent View
, you can resolve the issue by selecting the Theirs change forComponent Selection Query
to accept the query your colleague used inComponent View
.
4. On the toolstrip, use the Next button to navigate to the next conflict. The Motion Component
is conflicted in the Component View
because you and your colleague changed the component name of the Motion
component and this change propagated to the view.
To stay consistent with the change selected in step 2, select your change by selecting the Mine change for
Architecture Property Name
andSimulink Property Name
to keepMotion Trajectory
as the name of the component.
5. Check the summary table to verify you resolved all conflicts.
In this example, the summary table shows that you successfully resolved all conflicts.
If you resolved all conflicts in the current view but the summary table title indicates that you have remaining changes, disable the filters to view and resolve the remaining conflicts. On the Merge tab, in the Filter section, turn the filters off.
Accept Changes
1. After you resolve all filtered and unfiltered changes, click Accept & Close. The merge tool closes the report and the models, accepts the merge result in targetFile
, and marks the conflict as resolved in the source control tool.
2. Before you commit the resolved model file to source control, perform a final review by comparing the merge changes against the current branch.
In the project Files view, right-click the model and select Compare > Compare to Ancestor.
See Also
System Composer Three-Way Merge Tool | Resolve Conflicts in Project Using Simulink Three-Way Merge