Package org.eclipse.emf.compare.merge
Class ResourceChangeAdapter
- java.lang.Object
- 
- org.eclipse.emf.common.notify.impl.AdapterImpl
- 
- org.eclipse.emf.compare.merge.ResourceChangeAdapter
 
 
- 
- All Implemented Interfaces:
- Adapter,- Adapter.Internal
 
 public class ResourceChangeAdapter extends AdapterImpl This adapter is supposed to be installed on aComparison'sResourceSets and theirResources to react to content changes. Participants can then react to such changes to jointly decide whether a resource must be marked for deletion. The same instance of adapter should be used for all the resources of a comparison'sResourceSets. EMFCompare installs such an adapter on the comparison to make it easy to retrieve.
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static interfaceResourceChangeAdapter.IResourceChangeParticipantA participant in a Resource content change, useful to indicate whether an empty resource must actually be deleted or not, and which other resources need to be deleted/undeleted along.- 
Nested classes/interfaces inherited from interface org.eclipse.emf.common.notify.AdapterAdapter.Internal
 
- 
 - 
Field Summary- 
Fields inherited from class org.eclipse.emf.common.notify.impl.AdapterImpltarget
 
- 
 - 
Constructor SummaryConstructors Constructor Description ResourceChangeAdapter(Comparison comparison, IComparisonScope scope)Constructor.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddParticipant(ResourceChangeAdapter.IResourceChangeParticipant participant)Register the given participant.protected org.eclipse.emf.compare.merge.ResourceChangeAdapter.ResourceMatchgetResourceMatch(Resource resource)Returns the MatchResource corresponding to the givenresource.protected ResourceSetgetResourceSetOnOtherSide(Resource r)Get the resource set on the other side of the given resource.booleanisAdapterForType(Object type)booleanisEmptyAndMissingOnOtherSide(Resource resource)Indicate whether a resource is empty and is only on its side of the comparison (i.e. if it should be deleted unless a special restriction prevents it).booleanmustDelete(Resource r)Indicate whether a given Resource needs to be deleted.voidnotifyChanged(Notification msg)voidremoveParticipant(ResourceChangeAdapter.IResourceChangeParticipant participant)Unregister the given participant, has no action if the participant was not previously registered.protected voidresourceAdded(Resource resource)Callback invoked when a resource has just been added to a resource set.protected voidresourceContentsChanged(Resource resource, Notification msg)React to a Resource contents change to determine if this change involves the deletion of one or several resources.- 
Methods inherited from class org.eclipse.emf.common.notify.impl.AdapterImplgetTarget, setTarget, unsetTarget
 
- 
 
- 
- 
- 
Constructor Detail- 
ResourceChangeAdapterpublic ResourceChangeAdapter(Comparison comparison, IComparisonScope scope) Constructor.- Parameters:
- comparison- The comparison, cannot be- null.
- scope- The scope, cannot be- null. Moreover, the left and right notifiers of the scope must be- ResourceSets.
 
 
- 
 - 
Method Detail- 
notifyChangedpublic void notifyChanged(Notification msg) - Specified by:
- notifyChangedin interface- Adapter
- Overrides:
- notifyChangedin class- AdapterImpl
 
 - 
isAdapterForTypepublic boolean isAdapterForType(Object type) - Specified by:
- isAdapterForTypein interface- Adapter
- Overrides:
- isAdapterForTypein class- AdapterImpl
 
 - 
addParticipantpublic void addParticipant(ResourceChangeAdapter.IResourceChangeParticipant participant) Register the given participant.- Parameters:
- participant- The participant, must not be- null
 
 - 
removeParticipantpublic void removeParticipant(ResourceChangeAdapter.IResourceChangeParticipant participant) Unregister the given participant, has no action if the participant was not previously registered.- Parameters:
- participant- The participant to unregister
 
 - 
mustDeletepublic boolean mustDelete(Resource r) Indicate whether a given Resource needs to be deleted.- Parameters:
- r- The resource
- Returns:
- trueif the given resource has been marked for deletion.
 
 - 
resourceAddedprotected void resourceAdded(Resource resource) Callback invoked when a resource has just been added to a resource set. By default, it walks over the interested participants and creates all the associated resources that these participants declare as associated to the given resource.- Parameters:
- resource- The newly added resource
 
 - 
getResourceSetOnOtherSideprotected ResourceSet getResourceSetOnOtherSide(Resource r) Get the resource set on the other side of the given resource.- Parameters:
- r- The resource, which must be either on the left or on the right of the comparison.
- Returns:
- The ResourceSet on the other side, never null.
- Throws:
- IllegalArgumentException- If the given resource is neither on the left nor on the right.
 
 - 
resourceContentsChangedprotected void resourceContentsChanged(Resource resource, Notification msg) React to a Resource contents change to determine if this change involves the deletion of one or several resources. A Resource must be deleted if:- Their contents is nullor empty;
- It is not matched on the other side of the comparison;
- Every participant is OK to delete it.
 - Parameters:
- resource- The resource the contents of which have changed
- msg- The notification of the change
 
- Their contents is 
 - 
isEmptyAndMissingOnOtherSidepublic boolean isEmptyAndMissingOnOtherSide(Resource resource) Indicate whether a resource is empty and is only on its side of the comparison (i.e. if it should be deleted unless a special restriction prevents it).- Parameters:
- resource- The resource
- Returns:
- trueif the resource is empty and is not matched on the other side of the comparison.
 
 - 
getResourceMatchprotected org.eclipse.emf.compare.merge.ResourceChangeAdapter.ResourceMatch getResourceMatch(Resource resource) Returns the MatchResource corresponding to the givenresource.- Parameters:
- resource- Resource for which we need a MatchResource.
- Returns:
- The MatchResource corresponding to the given resource,nullif the resource is not in any side of this comparison (package, profiles, ...).
 
 
- 
 
-