/*******************************************************************************
* Copyright (c) 2012, 2014 Obeo.
* 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:
* Obeo - initial API and implementation
*******************************************************************************/
package org.eclipse.emf.compare.rcp.ui.internal.contentmergeviewer.accessor.factory.impl;
import org.eclipse.emf.common.notify.AdapterFactory;
import org.eclipse.emf.compare.Diff;
import org.eclipse.emf.compare.ReferenceChange;
import org.eclipse.emf.compare.rcp.ui.contentmergeviewer.accessor.legacy.ITypedElement;
import org.eclipse.emf.compare.rcp.ui.internal.contentmergeviewer.accessor.impl.ContainmentReferenceChangeAccessorImpl;
import org.eclipse.emf.compare.rcp.ui.mergeviewer.IMergeViewer.MergeViewerSide;
/**
* A specific {@link org.eclipse.emf.compare.rcp.ui.contentmergeviewer.accessor.factory.IAccessorFactory} for
* containment {@link ReferenceChange} objects.
*
* @author <a href="mailto:mikael.barbero@obeo.fr">Mikael Barbero</a>
* @since 4.0
*/
public class ContainmentReferenceChangeAccessorFactory extends AbstractAccessorFactory {
/**
* {@inheritDoc}
*
* @see org.eclipse.emf.compare.rcp.ui.contentmergeviewer.accessor.factory.IAccessorFactory#isFactoryFor(java.lang.Object)
*/
public boolean isFactoryFor(Object target) {
final boolean isFactoryFor;
if (target instanceof ReferenceChange) {
isFactoryFor = ((ReferenceChange)target).getReference().isContainment();
} else if (target instanceof Diff) {
Diff primeRefining = ((Diff)target).getPrimeRefining();
isFactoryFor = primeRefining instanceof ReferenceChange
&& ((ReferenceChange)primeRefining).getReference().isContainment();
} else {
isFactoryFor = false;
}
return isFactoryFor;
}
/**
* {@inheritDoc}
*
* @see org.eclipse.emf.compare.rcp.ui.contentmergeviewer.accessor.factory.IAccessorFactory#createLeft(org.eclipse.emf.common.notify.AdapterFactory,
* java.lang.Object)
*/
public ITypedElement createLeft(AdapterFactory adapterFactory, Object target) {
ReferenceChange referenceChange = getAppropriateReferenceChange(target);
return new ContainmentReferenceChangeAccessorImpl(adapterFactory, referenceChange,
MergeViewerSide.LEFT);
}
/**
* {@inheritDoc}
*
* @see org.eclipse.emf.compare.rcp.ui.contentmergeviewer.accessor.factory.IAccessorFactory#createRight(org.eclipse.emf.common.notify.AdapterFactory,
* java.lang.Object)
*/
public ITypedElement createRight(AdapterFactory adapterFactory, Object target) {
ReferenceChange referenceChange = getAppropriateReferenceChange(target);
return new ContainmentReferenceChangeAccessorImpl(adapterFactory, referenceChange,
MergeViewerSide.RIGHT);
}
/**
* {@inheritDoc}
*
* @see org.eclipse.emf.compare.rcp.ui.contentmergeviewer.accessor.factory.IAccessorFactory#createAncestor(org.eclipse.emf.common.notify.AdapterFactory,
* java.lang.Object)
*/
public ITypedElement createAncestor(AdapterFactory adapterFactory, Object target) {
ReferenceChange referenceChange = getAppropriateReferenceChange(target);
return new ContainmentReferenceChangeAccessorImpl(adapterFactory, referenceChange,
MergeViewerSide.ANCESTOR);
}
/**
* Returns the appropriate reference change. If the given object has a prime refining that is a reference
* change, returns this reference change. If the given object is a reference change, returns it.
* Otherwise, returns null.
*
* @param target
* the given object.
* @return the appropriate reference change.
*/
private ReferenceChange getAppropriateReferenceChange(Object target) {
final ReferenceChange referenceChange;
if (target instanceof ReferenceChange) {
referenceChange = (ReferenceChange)target;
} else if (((Diff)target).getPrimeRefining() instanceof ReferenceChange) {
referenceChange = (ReferenceChange)((Diff)target).getPrimeRefining();
} else {
referenceChange = null;
}
return referenceChange;
}
}