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 interfaceNodeList
00036 interfaceNodeList_new ()
00037 {
00038 interfaceNodeList s = (interfaceNodeList) dmalloc (sizeof (*s));
00039
00040 s->nelements = 0;
00041 s->nspacelow = interfaceNodeListGROWLOW;
00042 s->nspacehigh = interfaceNodeListGROWHI;
00043 s->elementsroot = (interfaceNode *) dmalloc (sizeof (*s->elements)
00044 * interfaceNodeListBASESIZE);
00045 s->elements = s->elementsroot + interfaceNodeListGROWLOW;
00046
00047 return (s);
00048 }
00049
00050 static void
00051 interfaceNodeList_grow (interfaceNodeList s)
00052 {
00053 int i;
00054 interfaceNode *newelements;
00055
00056 newelements = (interfaceNode *) dmalloc
00057 (sizeof (*newelements) * (s->nelements + interfaceNodeListBASESIZE));
00058
00059 for (i = 0; i < s->nelements; i++)
00060 {
00061 newelements[i + interfaceNodeListGROWLOW] = s->elements[i];
00062 }
00063
00064 s->nspacelow = interfaceNodeListGROWLOW;
00065 s->nspacehigh = interfaceNodeListGROWHI;
00066
00067 sfree (s->elementsroot);
00068 s->elementsroot = newelements;
00069
00070 s->elements = newelements + s->nspacelow;
00071 }
00072
00073 interfaceNodeList
00074 interfaceNodeList_addh (interfaceNodeList s, interfaceNode el)
00075 {
00076 llassert (interfaceNodeListGROWHI > 0);
00077
00078 if (s->nspacehigh <= 0)
00079 interfaceNodeList_grow (s);
00080
00081 s->nspacehigh--;
00082 s->elements[s->nelements] = el;
00083 s->nelements++;
00084
00085 return s;
00086 }
00087
00088 void
00089 interfaceNodeList_addl (interfaceNodeList s, interfaceNode el)
00090 {
00091 llassert (interfaceNodeListGROWLOW > 0);
00092
00093 if (s->nspacelow <= 0)
00094 interfaceNodeList_grow (s);
00095
00096 s->nspacelow--;
00097 s->elements--;
00098 s->elements[0] = el;
00099 s->nelements++;
00100 }
00101
00102 void
00103 interfaceNodeList_free (interfaceNodeList s)
00104 {
00105 int i;
00106
00107 for (i = 0; i < s->nelements; i++)
00108 {
00109 interfaceNode_free (s->elements[i]);
00110 }
00111
00112 sfree (s->elementsroot);
00113 sfree (s);
00114 }