2 /* Parse tree node interface */
10 typedef struct _node
{
15 struct _node
*n_child
;
18 extern DL_IMPORT(node
*) PyNode_New(int type
);
19 extern DL_IMPORT(int) PyNode_AddChild(node
*n
, int type
,
20 char *str
, int lineno
);
21 extern DL_IMPORT(void) PyNode_Free(node
*n
);
23 /* Node access functions */
24 #define NCH(n) ((n)->n_nchildren)
25 #define CHILD(n, i) (&(n)->n_child[i])
26 #define TYPE(n) ((n)->n_type)
27 #define STR(n) ((n)->n_str)
29 /* Assert that the type of a node is what we expect */
31 #define REQ(n, type) { /*pass*/ ; }
33 #define REQ(n, type) \
34 { if (TYPE(n) != (type)) { \
35 fprintf(stderr, "FATAL: node type %d, required %d\n", \
41 extern DL_IMPORT(void) PyNode_ListTree(node
*);
46 #endif /* !Py_NODE_H */