| /******************************************************************************* |
| * 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); |
| } |