/******************************************************************************* * Copyright (c) 2003, 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 - Initial API and implementation *******************************************************************************/ package org.eclipse.cdt.managedbuilder.core; import org.eclipse.core.resources.IProject; import org.eclipse.core.resources.IResource; /** * This class represents a project configuration in the old (CDT 2.0) * managed build system model. * <p> * The configuration contains one or more children of type tool-reference. * * @noextend This class is not intended to be subclassed by clients. * @noimplement This interface is not intended to be implemented by clients. * * @deprecated This class was deprecated in 2.1 */ @Deprecated public interface IConfigurationV2 extends IBuildObject { // Schema element names public static final String CONFIGURATION_ELEMENT_NAME = "configuration"; //$NON-NLS-1$ public static final String TOOLREF_ELEMENT_NAME = "toolReference"; //$NON-NLS-1$ public static final String PARENT = "parent"; //$NON-NLS-1$ /** * Projects have C or CC natures. Tools can specify a filter so they are not * misapplied to a project. This method allows the caller to retrieve a list * of tools from a project that are correct for a project's nature. * * @param project the project to filter for * @return an array of <code>ITools</code> that have compatible filters * for the specified project */ ITool[] getFilteredTools(IProject project); /** * @return the resource that owns the project that owns the configuration. */ public IResource getOwner(); /** * @return the configuration that this configuration is based on. */ public IConfigurationV2 getParent(); /** * @return the target for this configuration. */ public ITarget getTarget(); /** * Answers the <code>ITool</code> in the receiver with the same * id as the argument, or <code>null</code>. * * @param id unique identifier to search for * @return ITool */ public ITool getToolById(String id); /** * Returns the tools that are used in this configuration. * * @return ITool[] */ public ITool[] getTools(); /** * @return the tool references that are children of this configuration. */ public IToolReference[] getToolReferences(); /** * Answers <code>true</code> the receiver has changes that need to be saved * in the project file, else <code>false</code>. * * @return boolean */ public boolean isDirty(); /** * Answers whether the receiver has been changed and requires the * project to be rebuilt. * * @return <code>true</code> if the receiver contains a change * that needs the project to be rebuilt */ public boolean needsRebuild(); /** * Sets the element's "dirty" (have I been modified?) flag. */ public void setDirty(boolean isDirty); /** * Sets the name of the receiver to the value specified in the argument * * @param name new name */ public void setName(String name); /** * Sets the value of a boolean option for this configuration. * * @param option The option to change. * @param value The value to apply to the option. */ public void setOption(IOption option, boolean value) throws BuildException; /** * Sets the value of a string option for this configuration. * * @param option The option that will be effected by change. * @param value The value to apply to the option. */ public void setOption(IOption option, String value) throws BuildException; /** * Sets the value of a list option for this configuration. * * @param option The option to change. * @param value The values to apply to the option. */ public void setOption(IOption option, String[] value) throws BuildException; /** * Sets the rebuild state in the receiver. * * @param rebuild <code>true</code> will force a rebuild the next time the project builds * @see org.eclipse.cdt.managedbuilder.core.IManagedBuildInfo#setRebuildState(boolean) */ void setRebuildState(boolean rebuild); /** * Overrides the tool command for a tool defined in the receiver. * * @param tool The tool that will have its command modified * @param command The command */ public void setToolCommand(ITool tool, String command); /** * Sets the configuration that was created from this V2.0 configuration. */ public void setCreatedConfig(IConfiguration config); /** * Returns the configuration that was created from this V2.0 configuration. * * @return IConfiguration */ public IConfiguration getCreatedConfig(); }