use of org.eclipse.emf.compare.Diff in project tdq-studio-se by Talend.
the class ExampleLauncher method compare.
public static void compare() {
// Load the two input models
ResourceSet resourceSet1 = new ResourceSetImpl();
ResourceSet resourceSet2 = new ResourceSetImpl();
// String xmi1 = "path/to/first/model.xmi";
// String xmi2 = "path/to/second/model.xmi";
load(fileName1, resourceSet1);
load(fileName2, resourceSet2);
// Configure EMF Compare
IEObjectMatcher matcher = DefaultMatchEngine.createDefaultEObjectMatcher(UseIdentifiers.NEVER);
IComparisonFactory comparisonFactory = new DefaultComparisonFactory(new DefaultEqualityHelperFactory());
IMatchEngine.Factory matchEngineFactory = new MatchEngineFactoryImpl(matcher, comparisonFactory);
matchEngineFactory.setRanking(20);
IMatchEngine.Factory.Registry matchEngineRegistry = new MatchEngineFactoryRegistryImpl();
matchEngineRegistry.add(matchEngineFactory);
EMFCompare comparator = EMFCompare.builder().setMatchEngineFactoryRegistry(matchEngineRegistry).build();
// Compare the two models
IComparisonScope scope = new DefaultComparisonScope(resourceSet1, resourceSet2, null);
Comparison compare = comparator.compare(scope);
comparator.compare(scope);
EList<Diff> differences = compare.getDifferences();
ICompareEditingDomain editingDomain = EMFCompareEditingDomain.create(scope.getLeft(), scope.getRight(), null);
AdapterFactory adapterFactory = new ComposedAdapterFactory(ComposedAdapterFactory.Descriptor.Registry.INSTANCE);
EMFCompareConfiguration configuration = new EMFCompareConfiguration(new CompareConfiguration());
CompareEditorInput input = new ComparisonScopeEditorInput(configuration, editingDomain, adapterFactory, comparator, scope);
// CompareUI.openCompareDialog(input); // or CompareUI.openCompareEditor(input);
CompareUI.openCompareEditor(input);
}
use of org.eclipse.emf.compare.Diff in project tdq-studio-se by Talend.
the class FileMetadataTableComparisonLevel method compareWithReloadObject.
@Override
protected boolean compareWithReloadObject() throws ReloadCompareException {
Map<ResourceSet, List<Resource>> rsJrxmlMap = removeJrxmlsFromResourceSet();
EMFCompare comparator = createDefaultEMFCompare();
MetadataTable tempOldTable = (MetadataTable) getTempTableFromOldFile();
if (tempOldTable == null) {
return false;
}
IComparisonScope scope = new DefaultComparisonScope(tempOldTable, (MetadataTable) selectedObj, null);
Comparison compare = comparator.compare(scope);
addJrxmlsIntoResourceSet(rsJrxmlMap);
EList<Diff> differences = compare.getDifferences();
for (Diff diff : differences) {
// ignore the move Kind
if (diff.getKind() == DifferenceKind.MOVE) {
continue;
}
if (diff instanceof ReferenceChange) {
ReferenceChange refChange = (ReferenceChange) diff;
if (diff.getKind() == DifferenceKind.ADD) {
handleRemoveElement(refChange);
} else if (diff.getKind() == DifferenceKind.DELETE) {
handleAddElement(refChange);
}
}
}
tempMetadataTable.getFeature().clear();
return true;
}
use of org.eclipse.emf.compare.Diff in project InformationSystem by ObeoNetwork.
the class ExportAsSQLScriptsAction method areDatabaseDifferences.
/**
* Checks whether the given {@link Comparison} is between two {@link DataBase}.
* @param comparison
* @return
*/
private boolean areDatabaseDifferences(Comparison comparison) {
for (Diff diff : comparison.getDifferences()) {
Match parentMatch = diff.getMatch();
while (ComparePackage.Literals.MATCH.isInstance(parentMatch.eContainer())) {
parentMatch = (Match) parentMatch.eContainer();
}
// Should be DataBase
EObject left = parentMatch.getLeft();
// Should be DataBase
EObject right = parentMatch.getRight();
if (left != null && left.eClass().getEPackage() == DatabasePackage.eINSTANCE || right != null && right.eClass().getEPackage() == DatabasePackage.eINSTANCE) {
return true;
}
}
return false;
}
use of org.eclipse.emf.compare.Diff in project statecharts by Yakindu.
the class EdgeChangePostProcessor method postProcessEdgeDeletion.
/**
* In this case by default following dependencies are created:<br>
* <br>
* EdgeDeletion <-requires-- OutgoingTransitionDeletion --requires->
* IncomingTransitionDeletion<br>
* <br>
* Needs to be changed into:<br>
* <br>
* EdgeDeletion --requires-> OutgoingTransitionDeletion --requires->
* IncomingTransitionDeletion<br>
*
* @param edgeChange
*/
private void postProcessEdgeDeletion(EdgeChange edgeChange) {
Set<Diff> requiredOutgoingTransitionDeletions = new HashSet<Diff>();
for (Diff requireds : edgeChange.getRequiredBy()) {
if (requireds instanceof ReferenceChange) {
ReferenceChange requiredRefChange = (ReferenceChange) requireds;
// to add the corresponding change in incoming transition refs
if (requiredRefChange.getReference() == SGraphPackage.Literals.VERTEX__OUTGOING_TRANSITIONS && requiredRefChange.getKind() == DifferenceKind.DELETE) {
requiredOutgoingTransitionDeletions.add(requiredRefChange);
}
}
}
edgeChange.getRequires().addAll(requiredOutgoingTransitionDeletions);
}
use of org.eclipse.emf.compare.Diff in project statecharts by Yakindu.
the class EdgeChangePostProcessor method postProcessEdgeAddition.
/**
* In this case by default following dependencies are created:<br>
* <br>
* EdgeDeletion --requires-> OutgoingTransitionDeletion <-requires--
* IncomingTransitionDeletion<br>
* <br>
* Needs to be changed into:<br>
* <br>
* EdgeDeletion --requires-> IncomingTransitionDeletion --requires->
* OutgoingTransitionDeletion<br>
*
* @param edgeChange
*/
private void postProcessEdgeAddition(EdgeChange edgeChange) {
Set<Diff> requiredIncomingTransitionAdditions = new HashSet<Diff>();
for (Diff requireds : edgeChange.getRequires()) {
if (requireds instanceof ReferenceChange) {
ReferenceChange requiredRefChange = (ReferenceChange) requireds;
// to add the corresponding change in incoming transition refs
if (requiredRefChange.getReference() == SGraphPackage.Literals.VERTEX__OUTGOING_TRANSITIONS && requiredRefChange.getKind() == DifferenceKind.ADD) {
requiredIncomingTransitionAdditions.addAll(findRequiredIncomingTransitionRefChange(requiredRefChange, DifferenceKind.ADD));
}
}
}
edgeChange.getRequires().addAll(requiredIncomingTransitionAdditions);
}
Aggregations