/******************************************************************************* * Copyright (c) 2000, 2010 IBM Corporation and others. * 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: * IBM Corporation - initial API and implementation * Serge Beauchamp (Freescale Semiconductor) - [252996] add addFilter/removeFilter/getFilters *******************************************************************************/ package org.eclipse.core.resources; import org.eclipse.core.filesystem.IFileInfo; import org.eclipse.core.runtime.*; /** * Interface for resources which may contain other resources (termed its <em>members</em>). While * the workspace itself is not considered a container in this sense, the workspace root resource is * a container. * <p> * Containers implement the <code>IAdaptable</code> interface; extensions are managed by the * platform's adapter manager. * </p> * * @see Platform#getAdapterManager() * @see IProject * @see IFolder * @see IWorkspaceRoot * @noimplement This interface is not intended to be implemented by clients. * @noextend This interface is not intended to be extended by clients. */ public interface IContainer extends IResource, IAdaptable { /*==================================================================== * Constants defining which members are wanted: *====================================================================*/ /** * Member constant (bit mask value 1) indicating that phantom member resources are to be * included. * * @see IResource#isPhantom() * @since 2.0 */ public static final int INCLUDE_PHANTOMS= 1; /** * Member constant (bit mask value 2) indicating that team private members are to be included. * * @see IResource#isTeamPrivateMember() * @since 2.0 */ public static final int INCLUDE_TEAM_PRIVATE_MEMBERS= 2; /** * Member constant (bit mask value 4) indicating that derived resources are to be excluded. * * @see IResource#isDerived() * @since 3.1 */ public static final int EXCLUDE_DERIVED= 4; /** * Member constant (bit mask value 8) indicating that hidden resources are to be included. * * @see IResource#isHidden() * @since 3.4 */ public static final int INCLUDE_HIDDEN= 8; /** * Returns whether a resource of some type with the given path exists relative to this resource. * The supplied path may be absolute or relative; in either case, it is interpreted as relative * to this resource. Trailing separators are ignored. If the path is empty this container is * checked for existence. * * @param path the path of the resource * @return <code>true</code> if a resource of some type with the given path exists relative to * this resource, and <code>false</code> otherwise * @see IResource#exists() */ public boolean exists(IPath path); /** * Finds and returns the member resource (project, folder, or file) with the given name in this * container, or <code>null</code> if no such resource exists. * * <p> * N.B. Unlike the methods which traffic strictly in resource handles, this method infers the * resulting resource's type from the resource existing at the calculated path in the workspace. * </p> * * @param name the string name of the member resource * @return the member resource, or <code>null</code> if no such resource exists */ public IResource findMember(String name); /** * Finds and returns the member resource (project, folder, or file) with the given name in this * container, or <code>null</code> if there is no such resource. * <p> * If the <code>includePhantoms</code> argument is <code>false</code>, only a member resource * with the given name that exists will be returned. If the <code>includePhantoms</code> * argument is <code>true</code>, the method also returns a resource if the workspace is keeping * track of a phantom with that name. * </p> * <p> * Note that no attempt is made to exclude team-private member resources as with * <code>members</code>. * </p> * <p> * N.B. Unlike the methods which traffic strictly in resource handles, this method infers the * resulting resource's type from the existing resource (or phantom) in the workspace. * </p> * * @param name the string name of the member resource * @param includePhantoms <code>true</code> if phantom resources are of interest; * <code>false</code> if phantom resources are not of interest * @return the member resource, or <code>null</code> if no such resource exists * @see #members() * @see IResource#isPhantom() */ public IResource findMember(String name, boolean includePhantoms); /** * Finds and returns the member resource identified by the given path in this container, or * <code>null</code> if no such resource exists. The supplied path may be absolute or relative; * in either case, it is interpreted as relative to this resource. Trailing separators and the * path's device are ignored. If the path is empty this container is returned. Parent references * in the supplied path are discarded if they go above the workspace root. * <p> * Note that no attempt is made to exclude team-private member resources as with * <code>members</code>. * </p> * <p> * N.B. Unlike the methods which traffic strictly in resource handles, this method infers the * resulting resource's type from the resource existing at the calculated path in the workspace. * </p> * * @param path the path of the desired resource * @return the member resource, or <code>null</code> if no such resource exists */ public IResource findMember(IPath path); /** * Finds and returns the member resource identified by the given path in this container, or * <code>null</code> if there is no such resource. The supplied path may be absolute or * relative; in either case, it is interpreted as relative to this resource. Trailing separators * and the path's device are ignored. If the path is empty this container is returned. Parent * references in the supplied path are discarded if they go above the workspace root. * <p> * If the <code>includePhantoms</code> argument is <code>false</code>, only a resource that * exists at the given path will be returned. If the <code>includePhantoms</code> argument is * <code>true</code>, the method also returns a resource if the workspace is keeping track of a * phantom member resource at the given path. * </p> * <p> * Note that no attempt is made to exclude team-private member resources as with * <code>members</code>. * </p> * <p> * N.B. Unlike the methods which traffic strictly in resource handles, this method infers the * resulting resource's type from the existing resource (or phantom) at the calculated path in * the workspace. * </p> * * @param path the path of the desired resource * @param includePhantoms <code>true</code> if phantom resources are of interest; * <code>false</code> if phantom resources are not of interest * @return the member resource, or <code>null</code> if no such resource exists * @see #members(boolean) * @see IResource#isPhantom() */ public IResource findMember(IPath path, boolean includePhantoms); /** * Returns the default charset for resources in this container. * <p> * This is a convenience method, fully equivalent to: * * <pre> * getDefaultCharset(true); * </pre> * * </p> * <p> * Note that this method does not check whether the result is a supported charset name. Callers * should be prepared to handle <code>UnsupportedEncodingException</code> where this charset is * used. * </p> * * @return the name of the default charset encoding for this container * @exception CoreException if this method fails * @see IContainer#getDefaultCharset(boolean) * @see IFile#getCharset() * @since 3.0 */ public String getDefaultCharset() throws CoreException; /** * Returns the default charset for resources in this container. * <p> * If checkImplicit is <code>false</code>, this method will return the charset defined by * calling #setDefaultCharset, provided this container exists, or <code>null</code> otherwise. * </p> * <p> * If checkImplicit is <code>true</code>, this method uses the following algorithm to determine * the charset to be returned: * <ol> * <li>the one explicitly set by calling #setDefaultCharset (with a non-null argument) on this * container, if any, and this container exists, or</li> * <li>the parent's default charset, if this container has a parent (is not the workspace root), * or</li> * <li>the charset returned by ResourcesPlugin#getEncoding.</li> * </ol> * </p> * <p> * Note that this method does not check whether the result is a supported charset name. Callers * should be prepared to handle <code>UnsupportedEncodingException</code> where this charset is * used. * </p> * * @return the name of the default charset encoding for this container, or <code>null</code> * @exception CoreException if this method fails * @see IFile#getCharset() * @since 3.0 */ public String getDefaultCharset(boolean checkImplicit) throws CoreException; /** * Returns a handle to the file identified by the given path in this container. * <p> * This is a resource handle operation; neither the resource nor the result need exist in the * workspace. The validation check on the resource name/path is not done when the resource * handle is constructed; rather, it is done automatically as the resource is created. * <p> * The supplied path may be absolute or relative; in either case, it is interpreted as relative * to this resource and is appended to this container's full path to form the full path of the * resultant resource. A trailing separator is ignored. The path of the resulting resource must * have at least two segments. * </p> * * @param path the path of the member file * @return the (handle of the) member file * @see #getFolder(IPath) */ public IFile getFile(IPath path); /** * Returns a handle to the folder identified by the given path in this container. * <p> * This is a resource handle operation; neither the resource nor the result need exist in the * workspace. The validation check on the resource name/path is not done when the resource * handle is constructed; rather, it is done automatically as the resource is created. * <p> * The supplied path may be absolute or relative; in either case, it is interpreted as relative * to this resource and is appended to this container's full path to form the full path of the * resultant resource. A trailing separator is ignored. The path of the resulting resource must * have at least two segments. * </p> * * @param path the path of the member folder * @return the (handle of the) member folder * @see #getFile(IPath) */ public IFolder getFolder(IPath path); /** * Returns a list of existing member resources (projects, folders and files) in this resource, * in no particular order. * <p> * This is a convenience method, fully equivalent to <code>members(IResource.NONE)</code>. * Team-private member resources are <b>not</b> included in the result. * </p> * <p> * Note that the members of a project or folder are the files and folders immediately contained * within it. The members of the workspace root are the projects in the workspace. * </p> * * @return an array of members of this resource * @exception CoreException if this request fails. Reasons include: * <ul> * <li>This resource does not exist.</li> * <li>This resource is a project that is not open.</li> * </ul> * @see #findMember(IPath) * @see IResource#isAccessible() */ public IResource[] members() throws CoreException; /** * Returns a list of all member resources (projects, folders and files) in this resource, in no * particular order. * <p> * This is a convenience method, fully equivalent to: * * <pre> * members(includePhantoms ? INCLUDE_PHANTOMS : IResource.NONE); * </pre> * * Team-private member resources are <b>not</b> included in the result. * </p> * * @param includePhantoms <code>true</code> if phantom resources are of interest; * <code>false</code> if phantom resources are not of interest * @return an array of members of this resource * @exception CoreException if this request fails. Reasons include: * <ul> * <li>This resource does not exist.</li> * <li> <code>includePhantoms</code> is <code>false</code> and this resource does * not exist.</li> * <li> <code>includePhantoms</code> is <code>false</code> and this resource is a * project that is not open.</li> * </ul> * @see #members(int) * @see IResource#exists() * @see IResource#isPhantom() */ public IResource[] members(boolean includePhantoms) throws CoreException; /** * Returns a list of all member resources (projects, folders and files) in this resource, in no * particular order. * <p> * If the <code>INCLUDE_PHANTOMS</code> flag is not specified in the member flags (recommended), * only member resources that exist will be returned. If the <code>INCLUDE_PHANTOMS</code> flag * is specified, the result will also include any phantom member resources the workspace is * keeping track of. * </p> * <p> * If the <code>INCLUDE_TEAM_PRIVATE_MEMBERS</code> flag is specified in the member flags, team * private members will be included along with the others. If the * <code>INCLUDE_TEAM_PRIVATE_MEMBERS</code> flag is not specified (recommended), the result * will omit any team private member resources. * </p> * <p> * If the {@link #INCLUDE_HIDDEN} flag is specified in the member flags, hidden members will be * included along with the others. If the {@link #INCLUDE_HIDDEN} flag is not specified * (recommended), the result will omit any hidden member resources. * </p> * <p> * If the <code>EXCLUDE_DERIVED</code> flag is not specified, derived resources are included. If * the <code>EXCLUDE_DERIVED</code> flag is specified in the member flags, derived resources are * not included. * </p> * * @param memberFlags bit-wise or of member flag constants ({@link #INCLUDE_PHANTOMS}, * {@link #INCLUDE_TEAM_PRIVATE_MEMBERS}, {@link #INCLUDE_HIDDEN} and * {@link #EXCLUDE_DERIVED}) indicating which members are of interest * @return an array of members of this resource * @exception CoreException if this request fails. Reasons include: * <ul> * <li>This resource does not exist.</li> * <li>the <code>INCLUDE_PHANTOMS</code> flag is not specified and this resource * does not exist.</li> * <li>the <code>INCLUDE_PHANTOMS</code> flag is not specified and this resource * is a project that is not open.</li> * </ul> * @see IResource#exists() * @since 2.0 */ public IResource[] members(int memberFlags) throws CoreException; /** * Returns a list of recently deleted files inside this container that have one or more saved * states in the local history. The depth parameter determines how deep inside the container to * look. This resource may or may not exist in the workspace. * <p> * When applied to an existing project resource, this method returns recently deleted files with * saved states in that project. Note that local history is maintained with each individual * project, and gets discarded when a project is deleted from the workspace. If applied to a * deleted project, this method returns the empty list. * </p> * <p> * When applied to the workspace root resource (depth infinity), this method returns all * recently deleted files with saved states in all existing projects. * </p> * <p> * When applied to a folder (or project) resource (depth one), this method returns all recently * deleted member files with saved states. * </p> * <p> * When applied to a folder resource (depth zero), this method returns an empty list unless * there was a recently deleted file with saved states at the same path as the folder. * </p> * <p> * This method is long-running; progress and cancellation are provided by the given progress * monitor. * </p> * * @param depth depth limit: one of <code>DEPTH_ZERO</code>, <code>DEPTH_ONE</code> or * <code>DEPTH_INFINITE</code> * @param monitor a progress monitor, or <code>null</code> if progress reporting and * cancellation are not desired * @return an array of recently deleted files * @exception CoreException if this method fails * @see IFile#getHistory(IProgressMonitor) * @since 2.0 */ public IFile[] findDeletedMembersWithHistory(int depth, IProgressMonitor monitor) throws CoreException; /** * Sets the default charset for this container. Passing a value of <code>null</code> will remove * the default charset setting for this resource. * * @param charset a charset string, or <code>null</code> * @exception CoreException if this method fails Reasons include: * <ul> * <li>This resource does not exist.</li> * <li>An error happened while persisting this setting.</li> * </ul> * @see IContainer#getDefaultCharset() * @since 3.0 * @deprecated Replaced by {@link #setDefaultCharset(String, IProgressMonitor)} which is a * workspace operation and reports changes in resource deltas. */ public void setDefaultCharset(String charset) throws CoreException; /** * Sets the default charset for this container. Passing a value of <code>null</code> will remove * the default charset setting for this resource. * <p> * This method changes resources; these changes will be reported in a subsequent resource change * event, including an indication that the encoding of affected resources has been changed. * </p> * <p> * This method is long-running; progress and cancellation are provided by the given progress * monitor. * </p> * * @param charset a charset string, or <code>null</code> * @param monitor a progress monitor, or <code>null</code> if progress reporting is not desired * @exception OperationCanceledException if the operation is canceled. Cancelation can occur * even if no progress monitor is provided. * @exception CoreException if this method fails Reasons include: * <ul> * <li>This resource is not accessible.</li> * <li>An error happened while persisting this setting.</li> * <li>Resource changes are disallowed during certain types of resource change * event notification. See {@link IResourceChangeEvent} for more details.</li> * </ul> * @see IContainer#getDefaultCharset() * @see IResourceRuleFactory#charsetRule(IResource) * @since 3.0 */ public void setDefaultCharset(String charset, IProgressMonitor monitor) throws CoreException; /** * Adds a new filter to this container. Filters restrict the set of files and directories in the * underlying file system that will be included as members of this container. * <p> * The {@link IResource#BACKGROUND_REFRESH} update flag controls when changes to the resource * hierarchy under this container resulting from the new filter take effect. If this flag is * specified, the resource hierarchy is updated in a separate thread after this method returns. * If the flag is not specified, any resource changes resulting from the new filter will occur * before this method returns. * </p> * <p> * This operation changes resources; these changes will be reported in a subsequent resource * change event that will include an indication of any resources that have been removed as a * result of the new filter. * </p> * <p> * This operation is long-running; progress and cancellation are provided by the given progress * monitor. * </p> * * @param type ({@link IResourceFilterDescription#INCLUDE_ONLY} or * {@link IResourceFilterDescription#EXCLUDE_ALL} and/or * {@link IResourceFilterDescription#INHERITABLE}) * @param matcherDescription the description of the matcher that will determine which * {@link IFileInfo} instances will be excluded from the resource tree * @param updateFlags bit-wise or of update flag constants ({@link IResource#BACKGROUND_REFRESH} * ) * @param monitor a progress monitor, or <code>null</code> if progress reporting is not desired * @return the description of the added filter * @exception CoreException if this filter could not be added. Reasons include: * <ul> * <li>Resource changes are disallowed during certain types of resource change * event notification. See <code>IResourceChangeEvent</code> for more details.</li> * </ul> * @exception OperationCanceledException if the operation is canceled. Cancelation can occur * even if no progress monitor is provided. * @see #getFilters() * @see IResourceFilterDescription#delete(int, IProgressMonitor) * * @since 3.6 */ public IResourceFilterDescription createFilter(int type, FileInfoMatcherDescription matcherDescription, int updateFlags, IProgressMonitor monitor) throws CoreException; /** * Retrieve all filters on this container. If no filters exist for this resource, an empty array * is returned. * * @return an array of filters * @exception CoreException if this resource's filters could not be retrieved. Reasons include: * <ul> * <li>This resource is not a folder.</li> * * @see #createFilter(int, FileInfoMatcherDescription, int, IProgressMonitor) * @see IResourceFilterDescription#delete(int, IProgressMonitor) * @since 3.6 */ public IResourceFilterDescription[] getFilters() throws CoreException; }