1 /****************************************************************************
3 * GNAT COMPILER COMPONENTS *
9 * Copyright (C) 1992-2003, Free Software Foundation, Inc. *
11 * GNAT is free software; you can redistribute it and/or modify it under *
12 * terms of the GNU General Public License as published by the Free Soft- *
13 * ware Foundation; either version 2, or (at your option) any later ver- *
14 * sion. GNAT is distributed in the hope that it will be useful, but WITH- *
15 * OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY *
16 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License *
17 * for more details. You should have received a copy of the GNU General *
18 * Public License distributed with GNAT; see file COPYING. If not, write *
19 * to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, *
20 * MA 02111-1307, USA. *
22 * GNAT was originally developed by the GNAT team at New York University. *
23 * Extensive contributions were provided by Ada Core Technologies Inc. *
25 ****************************************************************************/
27 /* This is the C header corresponding to the Ada package specification for
28 Nlists. It also contains the implementations of inlined functions from the
29 the package body for Nlists. It was generated manually from nlists.ads and
30 nlists.adb and must be kept synchronized with changes in these files.
32 Note that only routines for reading the tree are included, since the
33 tree transformer is not supposed to modify the tree in any way. */
35 /* The following is the structure used for the list headers table */
44 /* The list headers are stored in an array. The pointer to this array is
45 passed as a parameter to gigi and stored in the global variable
48 extern struct List_Header
*List_Headers_Ptr
;
50 /* The previous and next links for lists are held in two arrays, Next_Node and
51 Prev_Node. The pointers to these arrays are passed as parameters to gigi
52 and stored in the global variables Prev_Node_Ptr and Next_Node_Ptr. */
54 extern Node_Id
*Next_Node_Ptr
;
55 extern Node_Id
*Prev_Node_Ptr
;
57 /* Node List Access Functions */
59 static Node_Id
First (List_Id
);
64 return List_Headers_Ptr
[List
- First_List_Id
].first
;
67 #define First_Non_Pragma nlists__first_non_pragma
68 extern Node_Id
First_Non_Pragma (Node_Id
);
70 static Node_Id
Last (List_Id
);
75 return List_Headers_Ptr
[List
- First_List_Id
].last
;
78 #define First_Non_Pragma nlists__first_non_pragma
79 extern Node_Id
First_Non_Pragma (List_Id
);
81 static Node_Id
Next (Node_Id
);
86 return Next_Node_Ptr
[Node
- First_Node_Id
];
89 #define Next_Non_Pragma nlists__next_non_pragma
90 extern Node_Id
Next_Non_Pragma (List_Id
);
92 static Node_Id
Prev (Node_Id
);
97 return Prev_Node_Ptr
[Node
- First_Node_Id
];
101 #define Prev_Non_Pragma nlists__prev_non_pragma
102 extern Node_Id
Prev_Non_Pragma (Node_Id
);
104 static Boolean
Is_Empty_List (List_Id
);
105 static Boolean
Is_Non_Empty_List (List_Id
);
106 static Boolean
Is_List_Member (Node_Id
);
107 static List_Id
List_Containing (Node_Id
);
110 Is_Empty_List (List_Id Id
)
112 return (First (Id
) == Empty
);
116 Is_Non_Empty_List (List_Id Id
)
118 return (Present (Id
) && First (Id
) != Empty
);
122 Is_List_Member (Node_Id Node
)
124 return Nodes_Ptr
[Node
- First_Node_Id
].U
.K
.in_list
;
128 List_Containing (Node_Id Node
)
130 return Nodes_Ptr
[Node
- First_Node_Id
].V
.NX
.link
;