00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032 # include "lclintMacros.nf"
00033 # include "llbasic.h"
00034
00035 declaratorNodeList
00036 declaratorNodeList_new ()
00037 {
00038 declaratorNodeList s = (declaratorNodeList) dmalloc (sizeof (*s));
00039
00040 s->nelements = 0;
00041 s->nspace = declaratorNodeListBASESIZE;
00042 s->elements = (declaratorNode *)
00043 dmalloc (sizeof (*s->elements) * declaratorNodeListBASESIZE);
00044
00045 return (s);
00046 }
00047
00048 static void
00049 declaratorNodeList_grow (declaratorNodeList s)
00050 {
00051 int i;
00052 declaratorNode *newelements;
00053
00054 s->nspace = declaratorNodeListBASESIZE + s->nspace;
00055 newelements = (declaratorNode *) dmalloc (sizeof (*newelements) * (s->nelements + s->nspace));
00056
00057 if (newelements == (declaratorNode *) 0)
00058 {
00059 llfatalerror (cstring_makeLiteral ("declaratorNodeList_grow: out of memory!"));
00060 }
00061
00062 for (i = 0; i < s->nelements; i++)
00063 {
00064 newelements[i] = s->elements[i];
00065 }
00066
00067 sfree (s->elements);
00068 s->elements = newelements;
00069 }
00070
00071 declaratorNodeList
00072 declaratorNodeList_add (declaratorNodeList s, declaratorNode el)
00073 {
00074 if (s->nspace <= 0)
00075 declaratorNodeList_grow (s);
00076
00077 s->nspace--;
00078 s->elements[s->nelements] = el;
00079 s->nelements++;
00080
00081 return s;
00082 }
00083
00084 cstring
00085 declaratorNodeList_unparse (declaratorNodeList s)
00086 {
00087 cstring st = cstring_undefined;
00088 bool first = TRUE;
00089
00090 declaratorNodeList_elements (s, current)
00091 {
00092 if (first)
00093 {
00094 st = declaratorNode_unparse (current);
00095 first = FALSE;
00096 }
00097 else
00098 {
00099 st = message ("%q, %q", st, declaratorNode_unparse (current));
00100 }
00101 } end_declaratorNodeList_elements;
00102
00103 return st;
00104 }
00105
00106 declaratorNodeList
00107 declaratorNodeList_copy (declaratorNodeList s)
00108 {
00109 declaratorNodeList ret = declaratorNodeList_new ();
00110
00111 declaratorNodeList_elements (s, el)
00112 {
00113 ret = declaratorNodeList_add (ret, declaratorNode_copy (el));
00114 } end_declaratorNodeList_elements ;
00115
00116 return ret;
00117 }
00118
00119 void
00120 declaratorNodeList_free (declaratorNodeList s)
00121 {
00122 int i;
00123 for (i = 0; i < s->nelements; i++)
00124 {
00125 declaratorNode_free (s->elements[i]);
00126 }
00127
00128 sfree (s->elements);
00129 sfree (s);
00130 }