Skip to main content

Merge errors

If a conflict or model inconsistency is detected during a merge, an error is displayed. There are two points where an error occurs:

  • When the merge starts
  • During the merge

Details of each are shown below.

Errors at the start of a merge

  • An error occurs if there are uncommitted changes in the current branch (own).
  • Conflicts are detected by the mechanism of Git itself to prevent uncommitted data from being overwritten, and an error is displayed.

Errors during a merge

  • An error occurs if an error is detected during a merge.
  • In this case, NDMerge will stop the merge process.
  • Errors during a merge can be broadly divided into two types:
  • Editing conflict errors
  • Model inconsistency errors
  • For the messages for each error, see here.

Conflict errors due to editing

  • If a conflict occurs due to edits to an individual model, an error will occur.
  • The conditions that result in a conflict vary depending on what is being merged. The conflict conditions for each target are shown below.
TargetContents
FileSchema version conflicts between files (Note 1)
Entity or relationshipField value changes conflict
Deleting a model and changing the field value of that model conflict
Deleting a parent model and changing the field value of a child model conflict
Interaction modelChanges to interaction elements conflict (Note 2)
Product line modelEdits to feature models conflict
Feature assignments (feature expressions) conflict
Configuration changes conflict
Constraints between features conflict
ProfileProfile changes conflict (Note 3)
ProjectChanges to project information (summary, category, etc.) conflict
Changes to trace view settings conflict (applies to series settings information and list information not included in trace coverage calculation)
  • Note 1: If there is an update to the schema version stored on a file-by-file basis, it is treated as a conflict.
  • Note 2: If there is one or more changes to a lifeline or message, it is treated as a change. In addition, in an interaction model (sequence diagram), the coordinate information of shapes is also treated as design data, so changes to coordinates are also subject to conflicts.
  • Note 3: Profile elements include metamodels, view definitions, resources such as images, and the contents of class diagrams. If there is one or more additions, deletions, or changes to these, it is treated as a change.

Errors due to model inconsistencies

  • As a result of merging without conflicts, an error occurs if there are any of the following model inconsistencies.
  • Owned relationships become circular references
  • There are multiple parents