All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.core.resources.IFolder Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 *  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.
 * 

* 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. *

*

* Folders implement the IAdaptable interface; * extensions are managed by the platform's adapter manager. *

* * @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. *

* This is a convenience method, fully equivalent to: *

	 *   create((force ? FORCE : IResource.NONE), local, monitor);
	 * 
*

*

* 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. *

*

* This method is long-running; progress and cancellation are provided * by the given progress monitor. *

* * @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 null if progress * reporting is not desired * @exception CoreException if this method fails. Reasons include: *
    *
  • This resource already exists in the workspace.
  • *
  • The workspace contains a resource of a different type * at the same path as this resource.
  • *
  • The parent of this resource does not exist.
  • *
  • The parent of this resource is a project that is not open.
  • *
  • The parent contains a resource of a different type * at the same path as this resource.
  • *
  • The parent of this resource is virtual, but this resource is not.
  • *
  • The name of this resource is not valid (according to * IWorkspace.validateName).
  • *
  • The corresponding location in the local file system is occupied * by a file (as opposed to a directory).
  • *
  • The corresponding location in the local file system is occupied * by a folder and force is false.
  • *
  • Resource changes are disallowed during certain types of resource change * event notification. See IResourceChangeEvent for more details.
  • *
* @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. *

* The FORCE update flag controls how this method deals with * cases where the workspace is not completely in sync with the local file * system. If FORCE 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 FORCE is specified, this method will * be deemed a success even if there already is a corresponding directory. *

*

* 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 true immediately after creating the resource. *

*

* 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 true immediately after creating the resource. *

*

* 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 true immediately after creating the resource. *

*

* Update flags other than those listed above are ignored. *

*

* This method synchronizes this resource with the local file system. *

*

* 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. *

*

* This method is long-running; progress and cancellation are provided * by the given progress monitor. *

* * @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 null if progress * reporting is not desired * @exception CoreException if this method fails. Reasons include: *
    *
  • This resource already exists in the workspace.
  • *
  • The workspace contains a resource of a different type * at the same path as this resource.
  • *
  • The parent of this resource does not exist.
  • *
  • The parent of this resource is a project that is not open.
  • *
  • The parent contains a resource of a different type * at the same path as this resource.
  • *
  • The parent of this resource is virtual, but this resource is not.
  • *
  • The name of this resource is not valid (according to * IWorkspace.validateName).
  • *
  • The corresponding location in the local file system is occupied * by a file (as opposed to a directory).
  • *
  • The corresponding location in the local file system is occupied * by a folder and FORCE is not specified.
  • *
  • Resource changes are disallowed during certain types of resource change * event notification. See IResourceChangeEvent for more details.
  • *
* @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. *

* The ALLOW_MISSING_LOCAL 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 ALLOW_MISSING_LOCAL is specified, the operation will succeed * even if the local directory is missing, or the path is relative to an * undefined variable. If ALLOW_MISSING_LOCAL 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. *

*

* 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 not * 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. *

*

* 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. *

*

* 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 true immediately after creating the resource. *

*

* Update flags other than those listed above are ignored. *

*

* 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. *

*

* This method is long-running; progress and cancellation are provided * by the given progress monitor. *

* * @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 null if progress * reporting is not desired * @exception CoreException if this method fails. Reasons include: *
    *
  • This resource already exists in the workspace.
  • *
  • The workspace contains a resource of a different type * at the same path as this resource.
  • *
  • The parent of this resource does not exist.
  • *
  • The parent of this resource is not an open project
  • *
  • The name of this resource is not valid (according to * IWorkspace.validateName).
  • *
  • The corresponding location in the local file system does not exist, or * is relative to an undefined variable, and ALLOW_MISSING_LOCAL is * not specified.
  • *
  • The corresponding location in the local file system is occupied * by a file (as opposed to a directory).
  • *
  • Resource changes are disallowed during certain types of resource change * event notification. See IResourceChangeEvent for more details.
  • *
  • The team provider for the project which contains this folder does not permit * linked resources.
  • *
  • This folder's project contains a nature which does not permit linked resources.
  • *
* @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. *

* The ALLOW_MISSING_LOCAL 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 ALLOW_MISSING_LOCAL is specified, the operation will succeed * even if the local directory is missing, or the path is relative to an * undefined variable. If ALLOW_MISSING_LOCAL 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. *

*

* 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 not * 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. *

*

* 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. *

*

* 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 true immediately after creating the resource. *

*

* Update flags other than those listed above are ignored. *

*

* 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. *

*

* This method is long-running; progress and cancellation are provided * by the given progress monitor. *

* * @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 null if progress * reporting is not desired * @exception CoreException if this method fails. Reasons include: *
    *
  • This resource already exists in the workspace.
  • *
  • The workspace contains a resource of a different type * at the same path as this resource.
  • *
  • The parent of this resource does not exist.
  • *
  • The parent of this resource is not an open project
  • *
  • The name of this resource is not valid (according to * IWorkspace.validateName).
  • *
  • The corresponding location in the local file system does not exist, or * is relative to an undefined variable, and ALLOW_MISSING_LOCAL is * not specified.
  • *
  • The corresponding location in the local file system is occupied * by a file (as opposed to a directory).
  • *
  • Resource changes are disallowed during certain types of resource change * event notification. See IResourceChangeEvent for more details.
  • *
  • The team provider for the project which contains this folder does not permit * linked resources.
  • *
  • This folder's project contains a nature which does not permit linked resources.
  • *
* @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. *

* This is a convenience method, fully equivalent to: *

	 *   delete((keepHistory ? KEEP_HISTORY : IResource.NONE) | (force ? FORCE : IResource.NONE), monitor);
	 * 
*

*

* 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. *

*

* This method is long-running; progress and cancellation are provided * by the given progress monitor. *

* * @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 null if progress * reporting is not desired * @exception CoreException if this method fails. Reasons include: *
    *
  • This resource could not be deleted for some reason.
  • *
  • This resource is out of sync with the local file system * and force is false.
  • *
  • Resource changes are disallowed during certain types of resource change * event notification. See IResourceChangeEvent for more details.
  • *
* @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. *

* 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. *

* * @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. *

* 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. *

* * @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. *

* This is a convenience method, fully equivalent to: *

	 *   move(destination, (keepHistory ? KEEP_HISTORY : IResource.NONE) | (force ? FORCE : IResource.NONE), monitor);
	 * 
*

*

* 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. *

*

* This method is long-running; progress and cancellation are provided * by the given progress monitor. *

* * @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 null if progress * reporting is not desired * @exception CoreException if this resource could not be moved. Reasons include: *
    *
  • This resource does not exist.
  • *
  • This resource or one of its descendents is not local.
  • *
  • The resource corresponding to the parent destination path does not exist.
  • *
  • The resource corresponding to the parent destination path is a closed * project.
  • *
  • A resource at destination path does exist.
  • *
  • A resource of a different type exists at the destination path.
  • *
  • This resource or one of its descendents is out of sync with the local file system * and force is false.
  • *
  • The workspace and the local file system are out of sync * at the destination resource or one of its descendents.
  • *
  • Resource changes are disallowed during certain types of resource change * event notification. See IResourceChangeEvent for more details.
  • *
* @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; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy