1 /* $MirOS: contrib/code/jupp/queue.c,v 1.3 2017/01/10 19:16:27 tg Exp $ */
3 * Doubly linked list primitives
5 * (C) 1992 Joseph H. Allen
7 * This file is part of JOE (Joe's Own Editor)
21 void *alitem(void *list, int itemsize)
23 STDITEM *freelist = (STDITEM *)list;
25 if (qempty(STDITEM, link, freelist)) {
26 STDITEM *i = (STDITEM *) joe_malloc(itemsize * 16);
27 STDITEM *z = (STDITEM *) ((unsigned char *) i + itemsize * 16);
30 enquef(STDITEM, link, freelist, i);
31 i = (STDITEM *) ((unsigned char *) i + itemsize);
34 return (void *) deque_f(STDITEM, link, freelist->link.prev);
37 void frchn(void *list, void *ch)
39 STDITEM *freelist = (STDITEM *)list;
40 STDITEM *chn = (STDITEM *)ch;
43 if ((i = chn->link.prev) != chn) {
44 deque(STDITEM, link, chn);
45 splicef(STDITEM, link, freelist, i);