blob: a5ebf5ffd9b5a26f6cbac9bc6b640dfdc6ef2325 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2008-2011 Chair for Applied Software Engineering,
* Technische Universitaet Muenchen.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Otto von Wesendonk - initial API and implementation
******************************************************************************/
package org.eclipse.emf.emfstore.internal.client.model.changeTracking.merging;
import org.eclipse.emf.emfstore.internal.client.model.changeTracking.merging.conflict.VisualConflict;
import org.eclipse.emf.emfstore.internal.common.model.ModelElementIdToEObjectMapping;
/**
* Allows to hook in for custom conflict treatment.
* Conflicting changes are determined by the ConflictDetector, which can be
* exchanged as well.
*
* @author wesendon
*/
public interface ConflictHandler {
/**
* Constant for the extension point id of conflict handlers.
*/
String EXTENSION_POINT_ID = "org.eclipse.emfstore.client.changeTracking.merging.conflictHandler"; //$NON-NLS-1$
/**
* Called after a conflict has been created and before it is
* added to list of all existing conflicts.
*
* @param conflict
* a {@link VisualConflict} instance that has been created by a {@link DecisionManager}
* @param idToEObjectMapping
* mapping from IDs to EObjects
*
* @return the possibly modified conflict instance that will be
* added to the list of conflicts
*/
VisualConflict handle(VisualConflict conflict, ModelElementIdToEObjectMapping idToEObjectMapping);
}