| Puma Reference Manual | Puma::CT_DeclList Class Reference |
Tree node representing a list of declarations. More...
#include <Puma/CTree.h>

Public Member Functions | |
| CT_DeclList (int size=20, int incr=20) | |
| Constructor. More... | |
| const char * | NodeName () const |
| Get the name of the node. More... | |
| void | Linkage (CT_LinkageSpec *l) |
| Set the linkage specifiers to each declaration in the list. More... | |
Public Member Functions inherited from Puma::CT_List | |
| CT_List * | IsList () |
| Get a pointer to this CT_List. More... | |
| int | Entries () const |
| Get the number of list entries. More... | |
| CTree * | Entry (int n) const |
| Get the n-th list entry. More... | |
| int | Sons () const |
| Get the number of sons. More... | |
| CTree * | Son (int n) const |
| Get the n-th son. More... | |
| int | Index (CTree *son) |
| Get the index of the given son, or -1 if not found. More... | |
| int | GetProperties () const |
| Get the list properties. More... | |
| void | AddProperties (int p) |
| Add a list property. More... | |
| void | AddSon (CTree *s) |
| Add a son. More... | |
| void | PrefixSon (CTree *s) |
| Prepend a son. More... | |
| void | InsertSon (CTree *before, CTree *son) |
| Insert a son before another son. More... | |
| void | ReplaceSon (CTree *old_son, CTree *new_son) |
| Replace a son. More... | |
| void | RemoveSon (CTree *son) |
| Remove a son. More... | |
| void | InsertSon (int idx, CTree *s) |
| Insert a son at the given index. More... | |
| void | ReplaceSon (int idx, CTree *s) |
| Replace the son at the given index. More... | |
| void | RemoveSon (int idx) |
| Remove the son at the given index. More... | |
Public Member Functions inherited from Puma::CTree | |
| virtual | ~CTree () |
| Destructor. More... | |
| virtual Token * | token () const |
| Get the first token of the syntactic construct represented by this sub-tree. More... | |
| virtual Token * | end_token () const |
| Get the last token of the syntactic construct represented by this sub-tree. More... | |
| virtual CT_Token * | token_node () const |
| Get the CT_Token node of the first token of the syntactic construct represented by this sub-tree. More... | |
| virtual CT_Token * | end_token_node () const |
| Get the CT_Token node of the last token of the syntactic construct represented by this sub-tree. More... | |
| virtual CTree * | Parent () const |
| Get the parent node. More... | |
| virtual CTypeInfo * | Type () const |
| Get the semantic type of the node. More... | |
| virtual CExprValue * | Value () const |
| Get the calculated value of the expression. More... | |
| virtual CSemScope * | SemScope () const |
| Get the scope opened by the node. More... | |
| virtual CSemValue * | SemValue () const |
| Get the semantic value of the node. More... | |
| virtual CSemObject * | SemObject () const |
| Get the semantic information of the node. More... | |
| virtual CT_SimpleName * | IsSimpleName () |
| Get a pointer to CT_SimpleName if the current node represents a name. More... | |
| virtual CT_String * | IsString () |
| Get a pointer to CT_String if the current node represents a string. More... | |
| virtual CT_Declarator * | IsDeclarator () |
| Get a pointer to CT_Declarator if the current node represents a declarator. More... | |
| virtual CT_Statement * | IsStatement () |
| Get a pointer to CT_Statement if the current node represents a statement. More... | |
| virtual CT_Expression * | IsExpression () |
| Get a pointer to CT_Expression if the current node represents a expression. More... | |
| virtual CT_Decl * | IsDeclaration () |
| Get a pointer to CT_Decl if the current node represents a declaration. More... | |
| virtual CT_Call * | IsCall () |
| Get a pointer to CT_Call if the current node represents a call expression. More... | |
| virtual CT_DelayedParse * | IsDelayedParse () |
| Get a pointer to CT_DelayedParse if the current node represents a delayed code fragment. More... | |
| bool | HasValueNull () const |
| Return true if the tree has the constant value 0. More... | |
Static Public Member Functions | |
| static const char * | NodeId () |
| Get the identifier for this node type. More... | |
Additional Inherited Members | |
Public Types inherited from Puma::CT_List | |
| enum | { OPEN = 1, CLOSE = 2, OPEN_CLOSE = 3, SEPARATORS = 4, FORCE_EMPTY = 8, END_SEP = 16, NO_LAST_SEP = 32, INTRO = 64 } |
| List properties. More... | |
Static Public Attributes inherited from Puma::CTree | |
| static int | alloc |
| static int | release |
Protected Member Functions inherited from Puma::CT_List | |
| CT_List (int size=5, int incr=5, int props=0) | |
| Constructor. More... | |
Protected Member Functions inherited from Puma::CTree | |
| CTree * | Son (CTree *const *sons, int len, int n) const |
| Get the n-th son from given sons array. More... | |
| int | Sons (CTree *const *sons, int len) const |
| Get the number of sons in the given sons array. More... | |
| void | ReplaceSon (CTree **sons, int len, CTree *old_son, CTree *new_son) |
| Replace a son. More... | |
| void | ReplaceSon (CTree *&son, CTree *old_son, CTree *new_son) |
| Replace a son if it equals the given son. More... | |
| void | AddSon (CTree *&son, CTree *new_son) |
| Add a new son. More... | |
| void | SetParent (const CTree *parent) |
| Set the parent tree node. More... | |
| void | SetParent (CTree *node, const CTree *parent) |
| Set the parent tree node of the given tree node. More... | |
| CTree () | |
| Default constructor. More... | |
Tree node representing a list of declarations.
|
inline |
Constructor.
| size | The initial size of the list. |
| incr | The initial increment count of the list. |
| void Puma::CT_DeclList::Linkage | ( | CT_LinkageSpec * | l | ) |
Set the linkage specifiers to each declaration in the list.
| l | The linkage specifiers node. |
|
static |
Get the identifier for this node type.
Can be compared with NodeName().
|
inlinevirtual |
Get the name of the node.
Can be compared with NodeId().
Implements Puma::CTree.
Reimplemented in Puma::CT_MembList, Puma::CT_ArgNameList, Puma::CT_ArgDeclSeq, Puma::CT_ArgDeclList, and Puma::CT_Program.