/*******************************************************************************
* 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:
* John Camelon (IBM) - Initial API and implementation
* Andrew Ferguson (Symbian)
*******************************************************************************/
package org.eclipse.cdt.core.dom.ast.cpp;
import org.eclipse.cdt.core.dom.ast.ASTNodeProperty;
import org.eclipse.cdt.core.dom.ast.IASTExpression;
import org.eclipse.cdt.core.dom.ast.IASTName;
import org.eclipse.cdt.core.dom.ast.IASTNameOwner;
import org.eclipse.cdt.core.dom.ast.IASTNode;
import org.eclipse.cdt.core.dom.ast.IASTTypeId;
/**
* @noextend This interface is not intended to be extended by clients.
* @noimplement This interface is not intended to be implemented by clients.
*/
public interface ICPPASTTemplateId extends IASTName, IASTNameOwner {
/**
* TEMPLATE_NAME is the IASTName.
*/
public static final ASTNodeProperty TEMPLATE_NAME = new ASTNodeProperty(
"ICPPASTTemplateId.TEMPLATE_NAME - TemplateId Name"); //$NON-NLS-1$
/**
* Get the name.
*
* @return <code>IASTName</code>
*/
public IASTName getTemplateName();
/**
* Set the name.
*
* @param name
* <code>IASTName</code>
*/
public void setTemplateName(IASTName name);
/**
* TEMPLATE_ID_ARGUMENT = template id argument.
*/
public static final ASTNodeProperty TEMPLATE_ID_ARGUMENT = new ASTNodeProperty(
"ICPPASTTemplateId.TEMPLATE_ID_ARGUMENT - TemplateId Argument"); //$NON-NLS-1$
/**
* Constant.
*/
public static final IASTNode[] EMPTY_ARG_ARRAY = new IASTNode[0];
/**
* Add template argument.
*
* @param typeId <code>IASTTypeId</code>
*/
public void addTemplateArgument(IASTTypeId typeId);
/**
* Add template argument.
*
* @param expression <code>IASTExpression</code>
*/
public void addTemplateArgument(IASTExpression expression);
/**
* Add an ambiguity node for later resolution.
*
* @param ambiguity
*/
public void addTemplateArgument(ICPPASTAmbiguousTemplateArgument ambiguity);
/**
* Get all template arguments. (as nodes)
*
* @return <code>IASTNode []</code>
*/
public IASTNode[] getTemplateArguments();
/**
* @since 5.1
*/
public ICPPASTTemplateId copy();
/**
* @since 5.3
*/
public ICPPASTTemplateId copy(CopyStyle style);
}