list.c revision 1a650d1e
1/* $Xorg: list.c,v 1.4 2001/02/09 02:05:59 xorgcvs Exp $ */ 2/****************************************************************************** 3 4Copyright 1993, 1998 The Open Group 5 6Permission to use, copy, modify, distribute, and sell this software and its 7documentation for any purpose is hereby granted without fee, provided that 8the above copyright notice appear in all copies and that both that 9copyright notice and this permission notice appear in supporting 10documentation. 11 12The above copyright notice and this permission notice shall be included in 13all copies or substantial portions of the Software. 14 15THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN 19AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 20CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 21 22Except as contained in this notice, the name of The Open Group shall not be 23used in advertising or otherwise to promote the sale, use or other dealings 24in this Software without prior written authorization from The Open Group. 25******************************************************************************/ 26 27#include "xsm.h" 28 29List * 30ListInit(void) 31{ 32 List *l; 33 34 l = (List *)XtMalloc(sizeof *l); 35 if(!l) return l; 36 l->next = l; 37 l->prev = l; 38 l->thing = NULL; 39 return l; 40} 41 42List * 43ListFirst(List *l) 44{ 45 if(l->next->thing) return l->next; 46 else return NULL; 47} 48 49List * 50ListNext(List *l) 51{ 52 if(l->next->thing) return l->next; 53 else return NULL; 54} 55 56void 57ListFreeAll(List *l) 58{ 59 char *thing; 60 List *next; 61 62 next = l->next; 63 do { 64 l = next; 65 next = l->next; 66 thing = l->thing; 67 XtFree((char *)l); 68 } while(thing); 69} 70 71void 72ListFreeAllButHead(List *l) 73{ 74 List *p, *next; 75 76 p = ListFirst(l); 77 78 while (p) 79 { 80 next = ListNext (p); 81 XtFree((char *) p); 82 p = next; 83 } 84 85 l->next = l; 86 l->prev = l; 87} 88 89List * 90ListAddFirst(List *l, char *v) 91{ 92 List *e; 93 94 e = (List *)XtMalloc(sizeof *e); 95 if(!e) return NULL; 96 97 e->thing = v; 98 e->prev = l; 99 e->next = e->prev->next; 100 e->prev->next = e; 101 e->next->prev = e; 102 103 return e; 104} 105 106List * 107ListAddLast(List *l, char *v) 108{ 109 List *e; 110 111 e = (List *)XtMalloc(sizeof *e); 112 if(!e) return NULL; 113 114 e->thing = v; 115 e->next = l; 116 e->prev = e->next->prev; 117 e->prev->next = e; 118 e->next->prev = e; 119 120 return e; 121} 122 123void 124ListFreeOne(List *e) 125{ 126 e->next->prev = e->prev; 127 e->prev->next = e->next; 128 XtFree((char *)e); 129} 130 131 132Status 133ListSearchAndFreeOne(List *l, char *thing) 134{ 135 List *p; 136 137 for (p = ListFirst (l); p; p = ListNext (p)) 138 if (((char *) p->thing) == (char *) thing) 139 { 140 ListFreeOne (p); 141 return (1); 142 } 143 144 return (0); 145} 146 147 148int 149ListCount(List *l) 150{ 151 int i; 152 List *e; 153 154 i = 0; 155 for(e = ListFirst(l); e; e = ListNext(e)) i++; 156 157 return i; 158} 159