Class 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 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 mapping
        mappings - 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 class ResourceMapping
        Parameters:
        mapping - the given resource mapping
        Returns:
        true if this mapping contains all the resources of the given mapping, and false 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 class ResourceMapping
        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 class ResourceMapping
        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 class ResourceMapping
        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 class ResourceMapping
        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 be null, in which case the implementor can assume that only the local resources are of interest to the client.
        monitor - a progress monitor, or null 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.