blob: d49ff2c86926d6a27851b6e44325c2187109d829 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2005, 2007 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
*
*******************************************************************************/
package org.eclipse.dltk.core;
import org.eclipse.core.resources.IResource;
import org.eclipse.core.resources.IWorkspace;
import org.eclipse.core.runtime.IProgressMonitor;
public interface IScriptModel extends IModelElement, IParent, IOpenable {
/**
* Returns the script project with the given name. This is a handle-only method.
* The project may or may not exist.
*
* @param name the name of the script project
* @return the script project with the given name
*/
IDLTKProject getScriptProject(String name);
/**
* Returns the script projects in this model, or an empty array if there
* are none.
*
* @return the script projects in this model, or an empty array if there
* are none
* @exception ModelException if this request fails.
*/
IDLTKProject[] getScriptProjects() throws ModelException;
/**
* Deletes the given elements, forcing the operation if necessary and specified.
*
* @param elements the elements to delete
* @param force a flag controlling whether underlying resources that are not
* in sync with the local file system will be tolerated
* @param monitor a progress monitor
* @exception ModelException if an element could not be deleted. Reasons include:
* <ul>
* <li> There is no element to process (NO_ELEMENTS_TO_PROCESS). The given elements is null or empty</li>
* <li> A specified element does not exist (ELEMENT_DOES_NOT_EXIST)</li>
* <li> A <code>CoreException</code> occurred while updating an underlying resource</li>
* <li> An element is read-only (<code>READ_ONLY</code>) </li>
* </ul>
*/
void delete(IModelElement[] elements, boolean force, IProgressMonitor monitor) throws ModelException;
/**
* Returns whether this script model contains an <code>IModelElement</code> whose
* resource is the given resource or a non-script resource which is the given resource.
* <p>
* Note: no existency check is performed on the argument resource. If it is not accessible
* (see <code>IResource.isAccessible()</code>) yet but would be located in script model
* range, then it will return <code>true</code>.
* </p><p>
* If the resource is accessible, it can be reached by navigating the script model down using the
* <code>getChildren()</code> and/or <code>getNonScriptResources()</code> methods.
* </p>
* @param resource the resource to check
* @return true if the resource is accessible through the script model
*
*/
boolean contains(IResource resource);
Object[] getForeignResources() throws ModelException;
/**
* Returns the workspace associated with this script model.
*
* @return the workspace associated with this script model
*/
IWorkspace getWorkspace();
/**
* Moves the given elements to the specified container(s).
* If one container is specified, all elements are moved to that
* container. If more than one container is specified, the number of
* elements and containers must match, and each element is moved to
* its associated container.
* <p>
* Optionally, each element can positioned before a sibling
* element. If <code>null</code> is specified for sibling, the element
* is inserted as the last child of its associated container.
* </p>
* <p>
* Optionally, each element can be renamed. If
* <code>null</code> is specified for the new name, the element
* is not renamed.
* </p>
* <p>
* Optionally, any existing child in the destination container with
* the same name can be replaced by specifying <code>true</code> for
* force. Otherwise an exception is thrown in the event that a name
* collision occurs.
* </p>
*
* @param elements the elements to move
* @param containers the container, or list of containers
* @param siblings the list of siblings element any of which may be
* <code>null</code>; or <code>null</code>
* @param renamings the list of new names any of which may be
* <code>null</code>; or <code>null</code>
* @param replace <code>true</code> if any existing child in a target container
* with the target name should be replaced, and <code>false</code> to throw an
* exception in the event of a name collision
* @param monitor a progress monitor
* @exception ModelException if an element could not be moved. Reasons include:
* <ul>
* <li> There is no element to process (NO_ELEMENTS_TO_PROCESS). The given elements is null or empty</li>
* <li> A specified element, container, or sibling does not exist (ELEMENT_DOES_NOT_EXIST)</li>
* <li> A <code>CoreException</code> occurred while updating an underlying resource</li>
* <li> A container is of an incompatible type (<code>INVALID_DESTINATION</code>)</li>
* <li> A sibling is not a child of it associated container (<code>INVALID_SIBLING</code>)</li>
* <li> A new name is invalid (<code>INVALID_NAME</code>)</li>
* <li> A child in its associated container already exists with the same
* name and <code>replace</code> has been specified as <code>false</code> (<code>NAME_COLLISION</code>)</li>
* <li> A container or element is read-only (<code>READ_ONLY</code>) </li>
* </ul>
*
* @exception IllegalArgumentException any element or container is <code>null</code>
*/
void move(IModelElement[] elements, IModelElement[] containers, IModelElement[] siblings, String[] renamings, boolean replace, IProgressMonitor monitor) throws ModelException;
/**
* Copies the given elements to the specified container(s).
* If one container is specified, all elements are copied to that
* container. If more than one container is specified, the number of
* elements and containers must match, and each element is copied to
* its associated container.
* <p>
* Optionally, each copy can positioned before a sibling
* element. If <code>null</code> is specified for a given sibling, the copy
* is inserted as the last child of its associated container.
* </p>
* <p>
* Optionally, each copy can be renamed. If
* <code>null</code> is specified for the new name, the copy
* is not renamed.
* </p>
* <p>
* Optionally, any existing child in the destination container with
* the same name can be replaced by specifying <code>true</code> for
* force. Otherwise an exception is thrown in the event that a name
* collision occurs.
* </p>
*
* @param elements the elements to copy
* @param containers the container, or list of containers
* @param siblings the list of siblings element any of which may be
* <code>null</code>; or <code>null</code>
* @param renamings the list of new names any of which may be
* <code>null</code>; or <code>null</code>
* @param replace <code>true</code> if any existing child in a target container
* with the target name should be replaced, and <code>false</code> to throw an
* exception in the event of a name collision
* @param monitor a progress monitor
* @exception ModelException if an element could not be copied. Reasons include:
* <ul>
* <li> There is no element to process (NO_ELEMENTS_TO_PROCESS). The given elements is null or empty</li>
* <li> A specified element, container, or sibling does not exist (ELEMENT_DOES_NOT_EXIST)</li>
* <li> A <code>CoreException</code> occurred while updating an underlying resource</li>
* <li> A container is of an incompatible type (<code>INVALID_DESTINATION</code>)</li>
* <li> A sibling is not a child of it associated container (<code>INVALID_SIBLING</code>)</li>
* <li> A new name is invalid (<code>INVALID_NAME</code>)</li>
* <li> A child in its associated container already exists with the same
* name and <code>replace</code> has been specified as <code>false</code> (<code>NAME_COLLISION</code>)</li>
* <li> A container or element is read-only (<code>READ_ONLY</code>) </li>
* </ul>
*/
void copy(IModelElement[] elements, IModelElement[] containers, IModelElement[] siblings, String[] renamings, boolean replace, IProgressMonitor monitor) throws ModelException;
/**
* Renames the given elements as specified.
* If one container is specified, all elements are renamed within that
* container. If more than one container is specified, the number of
* elements and containers must match, and each element is renamed within
* its associated container.
*
* @param elements the elements to rename
* @param destinations the container, or list of containers
* @param names the list of new names
* @param replace <code>true</code> if an existing child in a target container
* with the target name should be replaced, and <code>false</code> to throw an
* exception in the event of a name collision
* @param monitor a progress monitor
* @exception ModelException if an element could not be renamed. Reasons include:
* <ul>
* <li> There is no element to process (NO_ELEMENTS_TO_PROCESS). The given elements is null or empty</li>
* <li> A specified element does not exist (ELEMENT_DOES_NOT_EXIST)</li>
* <li> A <code>CoreException</code> occurred while updating an underlying resource
* <li> A new name is invalid (<code>INVALID_NAME</code>)
* <li> A child already exists with the same name and <code>replace</code> has been specified as <code>false</code> (<code>NAME_COLLISION</code>)
* <li> An element is read-only (<code>READ_ONLY</code>)
* </ul>
*/
void rename(IModelElement[] elements, IModelElement[] destinations, String[] names, boolean replace, IProgressMonitor monitor) throws ModelException;
}