Class CompositeResourceMapping
- java.lang.Object
-
- org.eclipse.core.runtime.PlatformObject
-
- org.eclipse.core.resources.mapping.ResourceMapping
-
- org.eclipse.core.resources.mapping.CompositeResourceMapping
-
- All Implemented Interfaces:
IAdaptable
public final class CompositeResourceMapping extends ResourceMapping
A resource mapping that obtains the traversals for its model object from a set of child mappings.This class is not intended to be subclasses by clients.
- Since:
- 3.2
-
-
Constructor Summary
Constructors Constructor Description CompositeResourceMapping(String providerId, Object modelObject, ResourceMapping[] mappings)
Create a composite mapping that obtains its traversals from a set of sub-mappings.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
contains(ResourceMapping mapping)
Return whether this resource mapping contains all the resources of the given mapping.ResourceMapping[]
getMappings()
Return the resource mappings contained in this composite.Object
getModelObject()
Returns the application model element associated with this resource mapping.String
getModelProviderId()
Returns the id of the model provider that generated this resource mapping.IProject[]
getProjects()
Returns the projects that contain the resources that constitute this application model.ResourceTraversal[]
getTraversals(ResourceMappingContext context, IProgressMonitor monitor)
Returns one or more traversals that can be used to access all the physical resources that constitute the logical resource.-
Methods inherited from class org.eclipse.core.resources.mapping.ResourceMapping
accept, equals, findMarkers, getModelProvider, hashCode
-
Methods inherited from class org.eclipse.core.runtime.PlatformObject
getAdapter
-
-
-
-
Constructor Detail
-
CompositeResourceMapping
public CompositeResourceMapping(String providerId, Object modelObject, ResourceMapping[] mappings)
Create a composite mapping that obtains its traversals from a set of sub-mappings.- Parameters:
modelObject
- the model object for this mappingmappings
- the sub-mappings from which the traversals are obtained
-
-
Method Detail
-
contains
public boolean contains(ResourceMapping mapping)
Description copied from class:ResourceMapping
Return whether this resource mapping contains all the resources of the given mapping.This method always returns
false
when the given resource mapping's model provider id does not match that the of the receiver.- Overrides:
contains
in classResourceMapping
- Parameters:
mapping
- the given resource mapping- Returns:
true
if this mapping contains all the resources of the given mapping, andfalse
otherwise.
-
getMappings
public ResourceMapping[] getMappings()
Return the resource mappings contained in this composite.- Returns:
- Return the resource mappings contained in this composite.
-
getModelObject
public Object getModelObject()
Description copied from class:ResourceMapping
Returns the application model element associated with this resource mapping.- Specified by:
getModelObject
in classResourceMapping
- Returns:
- the application model element associated with this resource mapping.
-
getModelProviderId
public String getModelProviderId()
Description copied from class:ResourceMapping
Returns the id of the model provider that generated this resource mapping.- Specified by:
getModelProviderId
in classResourceMapping
- Returns:
- the model provider id
-
getProjects
public IProject[] getProjects()
Description copied from class:ResourceMapping
Returns the projects that contain the resources that constitute this application model.- Specified by:
getProjects
in classResourceMapping
- Returns:
- the projects
-
getTraversals
public ResourceTraversal[] getTraversals(ResourceMappingContext context, IProgressMonitor monitor) throws CoreException
Description copied from class:ResourceMapping
Returns one or more traversals that can be used to access all the physical resources that constitute the logical resource. A traversal is simply a set of resources and the depth to which they are to be traversed. This method returns an array of traversals in order to provide flexibility in describing the traversals that constitute a model element.Subclasses should, when possible, include all resources that are or may be members of the model element. For instance, a model element should return the same list of resources regardless of the existence of the files on the file system. For example, if a logical resource called "form" maps to "/p1/form.xml" and "/p1/form.java" then whether form.xml or form.java existed, they should be returned by this method.
In some cases, it may not be possible for a model element to know all the resources that may constitute the element without accessing the state of the model element in another location (e.g. a repository). This method is provided with a context which, when provided, gives access to the members of corresponding remote containers and the contents of corresponding remote files. This gives the model element the opportunity to deduce what additional resources should be included in the traversal.
- Specified by:
getTraversals
in classResourceMapping
- Parameters:
context
- gives access to the state of remote resources that correspond to local resources for the purpose of determining traversals that adequately cover the model element resources given the state of the model element in another location. This parameter may benull
, in which case the implementor can assume that only the local resources are of interest to the client.monitor
- a progress monitor, ornull
if progress reporting is not desired- Returns:
- a set of traversals that cover the resources that constitute the model element
- Throws:
CoreException
- if the traversals could not be obtained.
-
-