/*******************************************************************************
* Copyright (c) 2004, 2011 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:
* Doug Schaefer (IBM) - Initial API and implementation
*******************************************************************************/
package org.eclipse.cdt.core.dom.ast;
/**
* This is a function definition, i.e. it has a body.
*
* @noextend This interface is not intended to be extended by clients.
* @noimplement This interface is not intended to be implemented by clients.
*/
public interface IASTFunctionDefinition extends IASTDeclaration {
/**
* <code>DECL_SPECIFIER</code> represents the relationship between a
* <code>IASTFunctionDefinition</code> and its
* <code>IASTDeclSpecifier</code>.
*/
public static final ASTNodeProperty DECL_SPECIFIER = new ASTNodeProperty(
"IASTFunctionDefinition.DECL_SPECIFIER - IASTDeclSpecifier for IASTFunctionDefinition"); //$NON-NLS-1$
/**
* <code>DECLARATOR</code> represents the relationship between a
* <code>IASTFunctionDefinition</code> and its
* <code>IASTFunctionDeclarator</code>.
*/
public static final ASTNodeProperty DECLARATOR = new ASTNodeProperty(
"IASTFunctionDefinition.DECLARATOR - IASTFunctionDeclarator for IASTFunctionDefinition"); //$NON-NLS-1$
/**
* <code>FUNCTION_BODY</code> represents the relationship between a
* <code>IASTFunctionDefinition</code> and its <code>IASTStatement</code>.
*/
public static final ASTNodeProperty FUNCTION_BODY = new ASTNodeProperty(
"IASTFunctionDefinition.FUNCTION_BODY - Function Body for IASTFunctionDefinition"); //$NON-NLS-1$
/**
* Get the decl specifier for the function.
*
*/
public IASTDeclSpecifier getDeclSpecifier();
/**
* Set the decl specifier for the function.
*
* @param declSpec
*/
public void setDeclSpecifier(IASTDeclSpecifier declSpec);
/**
* Get the function declarator of the function.
* Note, that the function declarator may contain nested declarators and may also nest within
* another declarator. In the latter case this function definition is always the parent of the
* outermost declarator.
* <pre>
* void (f)(int a); // has nested declarator
* void (f(int a)); // is nested in another declarator
* </pre>
*/
public IASTFunctionDeclarator getDeclarator();
/**
* Set the declarator for the function.
* Note, that the function declarator may contain nested declarators and may also nest within
* another declarator. In the latter case this function definition is set to be the parent of the
* outermost declarator.
* <pre>
* void (f)(int a); // has nested declarator
* void (f(int a)); // is nested in another declarator
* </pre>
* @param declarator
*/
public void setDeclarator(IASTFunctionDeclarator declarator);
/**
* Get the body of the function. This is usually a compound statement but
* C++ also has a function try block.
*
*/
public IASTStatement getBody();
/**
* Set the body of the function.
*
* @param statement
*/
public void setBody(IASTStatement statement);
/**
* Get the logical IScope that the function definition body represents.
*
* @return <code>IScope</code> representing function body.
*/
public IScope getScope();
/**
* @since 5.1
*/
public IASTFunctionDefinition copy();
/**
* @since 5.3
*/
public IASTFunctionDefinition copy(CopyStyle style);
}