2 * Doubly linked list primitives
4 * (C) 1992 Joseph H. Allen
6 * This file is part of JOE (Joe's Own Editor)
11 __RCSID("$MirOS: contrib/code/jupp/queue.c,v 1.5 2017/12/08 02:00:40 tg Exp $");
22 void *alitem(void *list, int itemsize)
24 STDITEM *freelist = (STDITEM *)list;
26 if (qempty(STDITEM, link, freelist)) {
27 STDITEM *i = malloc(itemsize * 16);
28 STDITEM *z = (STDITEM *)((unsigned char *)i + itemsize * 16);
31 enquef(STDITEM, link, freelist, i);
32 i = (STDITEM *)((unsigned char *)i + itemsize);
35 return (void *)deque_f(STDITEM, link, freelist->link.prev);
38 void frchn(void *list, void *ch)
40 STDITEM *freelist = (STDITEM *)list;
41 STDITEM *chn = (STDITEM *)ch;
44 if ((i = chn->link.prev) != chn) {
45 deque(STDITEM, link, chn);
46 splicef(STDITEM, link, freelist, i);