org.eclipse.core.resources.IFolder.java Source code

Java tutorial

Introduction

Here is the source code for org.eclipse.core.resources.IFolder.java

Source

/*******************************************************************************
 *  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) - [229633] Group Support
 *******************************************************************************/
package org.eclipse.core.resources;

import java.net.URI;
import org.eclipse.core.runtime.*;

/**
 * Folders may be leaf or non-leaf resources and may contain files and/or other folders.
 * A folder resource is stored as a directory in the local file system.
 * <p>
 * Folders, like other resource types, may exist in the workspace but
 * not be local; non-local folder resources serve as place-holders for
 * folders whose properties have not yet been fetched from a repository.
 * </p>
 * <p>
 * Folders implement the <code>IAdaptable</code> interface;
 * extensions are managed by the platform's adapter manager.
 * </p>
 *
 * @see Platform#getAdapterManager()
 * @noimplement This interface is not intended to be implemented by clients.
 * @noextend This interface is not intended to be extended by clients.
 */
public interface IFolder extends IContainer, IAdaptable {

    /**
     * Creates a new folder resource as a member of this handle's parent resource.
     * <p>
     * This is a convenience method, fully equivalent to:
     * <pre>
     *   create((force ? FORCE : IResource.NONE), local, monitor);
     * </pre>
     * </p>
     * <p>
     * This method changes resources; these changes will be reported
     * in a subsequent resource change event, including an indication 
     * that the folder has been added to its parent.
     * </p>
     * <p>
     * This method is long-running; progress and cancellation are provided
     * by the given progress monitor. 
     * </p>
     * 
     * @param force a flag controlling how to deal with resources that
     *    are not in sync with the local file system
     * @param local a flag controlling whether or not the folder will be local
     *    after the creation
     * @param monitor a progress monitor, or <code>null</code> if progress
     *    reporting is not desired
     * @exception CoreException if this method fails. Reasons include:
     * <ul>
     * <li> This resource already exists in the workspace.</li>
     * <li> The workspace contains a resource of a different type 
     *      at the same path as this resource.</li>
     * <li> The parent of this resource does not exist.</li>
     * <li> The parent of this resource is a project that is not open.</li>
     * <li> The parent contains a resource of a different type 
     *      at the same path as this resource.</li>
     * <li> The parent of this resource is virtual, but this resource is not.</li>
     * <li> The name of this resource is not valid (according to 
     *    <code>IWorkspace.validateName</code>).</li>
     * <li> The corresponding location in the local file system is occupied
     *    by a file (as opposed to a directory).</li>
     * <li> The corresponding location in the local file system is occupied
     *    by a folder and <code>force </code> is <code>false</code>.</li>
     * <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 IFolder#create(int,boolean,IProgressMonitor)
     */
    public void create(boolean force, boolean local, IProgressMonitor monitor) throws CoreException;

    /**
     * Creates a new folder resource as a member of this handle's parent resource.
     * <p>
     * The <code>FORCE</code> update flag controls how this method deals with
     * cases where the workspace is not completely in sync with the local file 
     * system. If <code>FORCE</code> is not specified, the method will only attempt
     * to create a directory in the local file system if there isn't one already. 
     * This option ensures there is no unintended data loss; it is the recommended
     * setting. However, if <code>FORCE</code> is specified, this method will 
     * be deemed a success even if there already is a corresponding directory.
     * </p>
     * <p>
     * The {@link IResource#DERIVED} update flag indicates that this resource
     * should immediately be set as a derived resource.  Specifying this flag
     * is equivalent to atomically calling {@link IResource#setDerived(boolean)}
     * with a value of <code>true</code> immediately after creating the resource.
     * </p>
     * <p>
     * The {@link IResource#TEAM_PRIVATE} update flag indicates that this resource
     * should immediately be set as a team private resource.  Specifying this flag
     * is equivalent to atomically calling {@link IResource#setTeamPrivateMember(boolean)}
     * with a value of <code>true</code> immediately after creating the resource.
     * </p>
     * <p>
     * The {@link IResource#HIDDEN} update flag indicates that this resource
     * should immediately be set as a hidden resource.  Specifying this flag
     * is equivalent to atomically calling {@link IResource#setHidden(boolean)}
     * with a value of <code>true</code> immediately after creating the resource.
     * </p>
     * <p>
     * Update flags other than those listed above are ignored.
     * </p>
     * <p>
     * This method synchronizes this resource with the local file system.
     * </p>
     * <p>
     * This method changes resources; these changes will be reported
     * in a subsequent resource change event, including an indication 
     * that the folder has been added to its parent.
     * </p>
     * <p>
     * This method is long-running; progress and cancellation are provided
     * by the given progress monitor. 
     * </p>
     * 
     * @param updateFlags bit-wise or of update flag constants
     *   ({@link IResource#FORCE}, {@link IResource#DERIVED}, {@link IResource#TEAM_PRIVATE})
     *   and {@link IResource#VIRTUAL})
     * @param local a flag controlling whether or not the folder will be local
     *    after the creation
     * @param monitor a progress monitor, or <code>null</code> if progress
     *    reporting is not desired
     * @exception CoreException if this method fails. Reasons include:
     * <ul>
     * <li> This resource already exists in the workspace.</li>
     * <li> The workspace contains a resource of a different type 
     *      at the same path as this resource.</li>
     * <li> The parent of this resource does not exist.</li>
     * <li> The parent of this resource is a project that is not open.</li>
     * <li> The parent contains a resource of a different type 
     *      at the same path as this resource.</li>
     * <li> The parent of this resource is virtual, but this resource is not.</li>
     * <li> The name of this resource is not valid (according to 
     *    <code>IWorkspace.validateName</code>).</li>
     * <li> The corresponding location in the local file system is occupied
     *    by a file (as opposed to a directory).</li>
     * <li> The corresponding location in the local file system is occupied
     *    by a folder and <code>FORCE</code> is not specified.</li>
     * <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 IResourceRuleFactory#createRule(IResource)
     * @since 2.0
     */
    public void create(int updateFlags, boolean local, IProgressMonitor monitor) throws CoreException;

    /**
     * Creates a new folder resource as a member of this handle's parent resource.
     * The folder's contents will be located in the directory specified by the given
     * file system path.  The given path must be either an absolute file system
     * path, or a relative path whose first segment is the name of a workspace path
     * variable.
     * <p>
     * The <code>ALLOW_MISSING_LOCAL</code> update flag controls how this 
     * method deals with cases where the local file system directory to be linked does
     * not exist, or is relative to a workspace path variable that is not defined.
     * If <code>ALLOW_MISSING_LOCAL</code> is specified, the operation will succeed
     * even if the local directory is missing, or the path is relative to an
     * undefined variable. If <code>ALLOW_MISSING_LOCAL</code> is not specified, the
     * operation will fail in the case where the local file system directory does
     * not exist or the path is relative to an undefined variable.
     * </p>
     * <p>
     * The {@link IResource#REPLACE} update flag controls how this 
     * method deals with cases where a resource of the same name as the 
     * prospective link already exists. If {@link IResource#REPLACE}
     * is specified, then the existing linked resource's location is replaced
     * by localLocation's value.  This does <b>not</b>
     * cause the underlying file system contents of that resource to be deleted.
     * If {@link IResource#REPLACE} is not specified, this method will
     * fail if an existing resource exists of the same name.
     * </p>
     * <p>
     * The {@link IResource#BACKGROUND_REFRESH} update flag controls how
     * this method synchronizes the new resource with the filesystem. If this flag is 
     * specified, resources on disk will be synchronized in the background after the 
     * method returns. Child resources of the link may not be available until 
     * this background refresh completes. If this flag is not specified, resources are 
     * synchronized in the foreground before this method returns.
     * </p>
     * <p>
     * The {@link IResource#HIDDEN} update flag indicates that this resource
     * should immediately be set as a hidden resource.  Specifying this flag
     * is equivalent to atomically calling {@link IResource#setHidden(boolean)}
     * with a value of <code>true</code> immediately after creating the resource.
     * </p>
     * <p>
     * Update flags other than those listed above are ignored.
     * </p>
     * <p>
     * This method changes resources; these changes will be reported
     * in a subsequent resource change event, including an indication 
     * that the folder has been added to its parent.
     * </p>
     * <p>
     * This method is long-running; progress and cancellation are provided
     * by the given progress monitor. 
     * </p>
     * 
     * @param localLocation a file system path where the folder should be linked
     * @param updateFlags bit-wise or of update flag constants
     *   ({@link IResource#ALLOW_MISSING_LOCAL}, {@link IResource#REPLACE}, {@link IResource#BACKGROUND_REFRESH}, and {@link IResource#HIDDEN})
     * @param monitor a progress monitor, or <code>null</code> if progress
     *    reporting is not desired
     * @exception CoreException if this method fails. Reasons include:
     * <ul>
     * <li> This resource already exists in the workspace.</li>
     * <li> The workspace contains a resource of a different type 
     *      at the same path as this resource.</li>
     * <li> The parent of this resource does not exist.</li>
     * <li> The parent of this resource is not an open project</li>
     * <li> The name of this resource is not valid (according to 
     *    <code>IWorkspace.validateName</code>).</li>
     * <li> The corresponding location in the local file system does not exist, or
     * is relative to an undefined variable, and <code>ALLOW_MISSING_LOCAL</code> is
     * not specified.</li>
     * <li> The corresponding location in the local file system is occupied
     *    by a file (as opposed to a directory).</li>
     * <li> Resource changes are disallowed during certain types of resource change 
     *       event notification.  See <code>IResourceChangeEvent</code> for more details.</li>
     * <li>The team provider for the project which contains this folder does not permit
     *       linked resources.</li>
     * <li>This folder's project contains a nature which does not permit linked resources.</li>
     * </ul>
     * @exception OperationCanceledException if the operation is canceled. 
     * Cancelation can occur even if no progress monitor is provided.
     * @see IResource#isLinked()
     * @see IResource#ALLOW_MISSING_LOCAL
     * @see IResource#REPLACE
     * @see IResource#BACKGROUND_REFRESH
     * @see IResource#HIDDEN
     * @since 2.1
     */
    public void createLink(IPath localLocation, int updateFlags, IProgressMonitor monitor) throws CoreException;

    /**
     * Creates a new folder resource as a member of this handle's parent resource.
     * The folder's contents will be located in the directory specified by the given
     * file system URI.  The given URI must be either absolute, or a relative URI 
     * whose first path segment is the name of a workspace path variable.
     * <p>
     * The <code>ALLOW_MISSING_LOCAL</code> update flag controls how this 
     * method deals with cases where the local file system directory to be linked does
     * not exist, or is relative to a workspace path variable that is not defined.
     * If <code>ALLOW_MISSING_LOCAL</code> is specified, the operation will succeed
     * even if the local directory is missing, or the path is relative to an
     * undefined variable. If <code>ALLOW_MISSING_LOCAL</code> is not specified, the
     * operation will fail in the case where the local file system directory does
     * not exist or the path is relative to an undefined variable.
     * </p>
     * <p>
     * The {@link IResource#REPLACE} update flag controls how this 
     * method deals with cases where a resource of the same name as the 
     * prospective link already exists. If {@link IResource#REPLACE}
     * is specified, then any existing resource with the same name is removed
     * from the workspace to make way for creation of the link.  This does <b>not</b>
     * cause the underlying file system contents of that resource to be deleted.
     * If {@link IResource#REPLACE} is not specified, this method will
     * fail if an existing resource exists of the same name.
     * </p>
     * <p>
     * The {@link IResource#BACKGROUND_REFRESH} update flag controls how
     * this method synchronizes the new resource with the filesystem. If this flag is 
     * specified, resources on disk will be synchronized in the background after the 
     * method returns. Child resources of the link may not be available until 
     * this background refresh completes. If this flag is not specified, resources are 
     * synchronized in the foreground before this method returns.
     * </p>
     * <p>
     * The {@link IResource#HIDDEN} update flag indicates that this resource
     * should immediately be set as a hidden resource.  Specifying this flag
     * is equivalent to atomically calling {@link IResource#setHidden(boolean)}
     * with a value of <code>true</code> immediately after creating the resource.
     * </p>
     * <p>
     * Update flags other than those listed above are ignored.
     * </p>
     * <p>
     * This method changes resources; these changes will be reported
     * in a subsequent resource change event, including an indication 
     * that the folder has been added to its parent.
     * </p>
     * <p>
     * This method is long-running; progress and cancellation are provided
     * by the given progress monitor. 
     * </p>
     * 
     * @param location a file system path where the folder should be linked
     * @param updateFlags bit-wise or of update flag constants
     *   ({@link IResource#ALLOW_MISSING_LOCAL}, {@link IResource#REPLACE}, {@link IResource#BACKGROUND_REFRESH}, and {@link IResource#HIDDEN})
     * @param monitor a progress monitor, or <code>null</code> if progress
     *    reporting is not desired
     * @exception CoreException if this method fails. Reasons include:
     * <ul>
     * <li> This resource already exists in the workspace.</li>
     * <li> The workspace contains a resource of a different type 
     *      at the same path as this resource.</li>
     * <li> The parent of this resource does not exist.</li>
     * <li> The parent of this resource is not an open project</li>
     * <li> The name of this resource is not valid (according to 
     *    <code>IWorkspace.validateName</code>).</li>
     * <li> The corresponding location in the local file system does not exist, or
     * is relative to an undefined variable, and <code>ALLOW_MISSING_LOCAL</code> is
     * not specified.</li>
     * <li> The corresponding location in the local file system is occupied
     *    by a file (as opposed to a directory).</li>
     * <li> Resource changes are disallowed during certain types of resource change 
     *       event notification.  See <code>IResourceChangeEvent</code> for more details.</li>
     * <li>The team provider for the project which contains this folder does not permit
     *       linked resources.</li>
     * <li>This folder's project contains a nature which does not permit linked resources.</li>
     * </ul>
     * @exception OperationCanceledException if the operation is canceled. 
     * Cancelation can occur even if no progress monitor is provided.
     * @see IResource#isLinked()
     * @see IResource#ALLOW_MISSING_LOCAL
     * @see IResource#REPLACE
     * @see IResource#BACKGROUND_REFRESH
     * @see IResource#HIDDEN
     * @since 3.2
     */
    public void createLink(URI location, int updateFlags, IProgressMonitor monitor) throws CoreException;

    /**
     * Deletes this resource from the workspace.
     * <p>
     * This is a convenience method, fully equivalent to:
     * <pre>
     *   delete((keepHistory ? KEEP_HISTORY : IResource.NONE) | (force ? FORCE : IResource.NONE), monitor);
     * </pre>
     * </p>
     * <p>
     * This method changes resources; these changes will be reported
     * in a subsequent resource change event, including an indication 
     * that this folder has been removed from its parent.
     * </p>
     * <p>
     * This method is long-running; progress and cancellation are provided
     * by the given progress monitor. 
     * </p>
     * 
     * @param force a flag controlling whether resources that are not
     *    in sync with the local file system will be tolerated
     * @param keepHistory a flag controlling whether files under this folder
     *    should be stored in the workspace's local history
     * @param monitor a progress monitor, or <code>null</code> if progress
     *    reporting is not desired
     * @exception CoreException if this method fails. Reasons include:
     * <ul>
     * <li> This resource could not be deleted for some reason.</li>
     * <li> This resource is out of sync with the local file system
     *      and <code>force</code> is <code>false</code>.</li>
     * <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 IResourceRuleFactory#deleteRule(IResource)
     * @see IResource#delete(int,IProgressMonitor)
     */
    public void delete(boolean force, boolean keepHistory, IProgressMonitor monitor) throws CoreException;

    /**
     * Returns a handle to the file with the given name in this folder.
     * <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>
     *
     * @param name the string name of the member file
     * @return the (handle of the) member file
     * @see #getFolder(String)
     */
    public IFile getFile(String name);

    /**
     * Returns a handle to the folder with the given name in this folder.
     * <p> 
     * This is a resource handle operation; neither the container
     * 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>
     *
     * @param name the string name of the member folder
     * @return the (handle of the) member folder
     * @see #getFile(String)
     */
    public IFolder getFolder(String name);

    /**
     * Moves this resource so that it is located at the given path.  
     * <p>
     * This is a convenience method, fully equivalent to:
     * <pre>
     *   move(destination, (keepHistory ? KEEP_HISTORY : IResource.NONE) | (force ? FORCE : IResource.NONE), monitor);
     * </pre>
     * </p>
     * <p>
     * This method changes resources; these changes will be reported
     * in a subsequent resource change event, including an indication 
     * that this folder has been removed from its parent and a new folder
     * has been added to the parent of the destination.
     * </p>
     * <p>
     * This method is long-running; progress and cancellation are provided
     * by the given progress monitor. 
     * </p>
     * 
     * @param destination the destination path 
     * @param force a flag controlling whether resources that are not
     *    in sync with the local file system will be tolerated
     * @param keepHistory a flag controlling whether files under this folder
     *    should be stored in the workspace's local history
     * @param monitor a progress monitor, or <code>null</code> if progress
     *    reporting is not desired
     * @exception CoreException if this resource could not be moved. Reasons include:
     * <ul>
     * <li> This resource does not exist.</li>
     * <li> This resource or one of its descendents is not local.</li>
     * <li> The resource corresponding to the parent destination path does not exist.</li>
     * <li> The resource corresponding to the parent destination path is a closed 
     *      project.</li>
     * <li> A resource at destination path does exist.</li>
     * <li> A resource of a different type exists at the destination path.</li>
     * <li> This resource or one of its descendents is out of sync with the local file system
     *      and <code>force</code> is <code>false</code>.</li>
     * <li> The workspace and the local file system are out of sync
     *      at the destination resource or one of its descendents.</li>
     * <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 IResourceRuleFactory#moveRule(IResource, IResource)
     * @see IResource#move(IPath,int,IProgressMonitor)
     */
    public void move(IPath destination, boolean force, boolean keepHistory, IProgressMonitor monitor)
            throws CoreException;
}