org.eclipse.core.resources.IFolder Maven / Gradle / Ivy
/*******************************************************************************
* 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;
}