2021-06-25 11:16:24 -07:00
|
|
|
/* $NetBSD: lst.h,v 1.98 2021/04/03 11:08:40 rillig Exp $ */
|
2012-06-08 21:57:36 +00:00
|
|
|
|
1996-10-06 15:57:15 +00:00
|
|
|
/*
|
2012-06-08 21:57:36 +00:00
|
|
|
* Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This code is derived from software contributed to Berkeley by
|
|
|
|
* Adam de Boor.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. Neither the name of the University nor the names of its contributors
|
|
|
|
* may be used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* from: @(#)lst.h 8.1 (Berkeley) 6/6/93
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (c) 1988, 1989 by Adam de Boor
|
1996-10-06 15:57:15 +00:00
|
|
|
* Copyright (c) 1989 by Berkeley Softworks
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This code is derived from software contributed to Berkeley by
|
|
|
|
* Adam de Boor.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. All advertising materials mentioning features or use of this software
|
|
|
|
* must display the following acknowledgement:
|
|
|
|
* This product includes software developed by the University of
|
|
|
|
* California, Berkeley and its contributors.
|
|
|
|
* 4. Neither the name of the University nor the names of its contributors
|
|
|
|
* may be used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*
|
2012-06-08 21:57:36 +00:00
|
|
|
* from: @(#)lst.h 8.1 (Berkeley) 6/6/93
|
1996-10-06 15:57:15 +00:00
|
|
|
*/
|
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Doubly-linked lists of arbitrary pointers. */
|
2012-06-08 21:57:36 +00:00
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
#ifndef MAKE_LST_H
|
|
|
|
#define MAKE_LST_H
|
1996-10-06 15:57:15 +00:00
|
|
|
|
2021-01-13 17:24:34 -08:00
|
|
|
#ifdef HAVE_INTTYPES_H
|
|
|
|
#include <inttypes.h>
|
|
|
|
#elif defined(HAVE_STDINT_H)
|
2020-11-07 19:39:21 +00:00
|
|
|
#include <stdint.h>
|
2021-01-13 17:24:34 -08:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_STDLIB_H
|
2020-09-05 16:11:04 +00:00
|
|
|
#include <stdlib.h>
|
2021-01-13 17:24:34 -08:00
|
|
|
#endif
|
1996-10-06 15:57:15 +00:00
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
/* A doubly-linked list of pointers. */
|
2021-01-13 17:24:34 -08:00
|
|
|
typedef struct List List;
|
2020-09-05 16:11:04 +00:00
|
|
|
/* A single node in the doubly-linked list. */
|
2021-01-13 17:24:34 -08:00
|
|
|
typedef struct ListNode ListNode;
|
2020-11-07 19:39:21 +00:00
|
|
|
|
|
|
|
struct ListNode {
|
2021-01-13 17:24:34 -08:00
|
|
|
ListNode *prev; /* previous node in list, or NULL */
|
|
|
|
ListNode *next; /* next node in list, or NULL */
|
2020-11-07 19:39:21 +00:00
|
|
|
void *datum; /* datum associated with this element */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct List {
|
2021-01-13 17:24:34 -08:00
|
|
|
ListNode *first;
|
|
|
|
ListNode *last;
|
2020-11-07 19:39:21 +00:00
|
|
|
};
|
1996-10-06 15:57:15 +00:00
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Free the datum of a node, called before freeing the node itself. */
|
|
|
|
typedef void LstFreeProc(void *);
|
1996-10-06 15:57:15 +00:00
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Create or destroy a list */
|
1996-10-06 15:57:15 +00:00
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Create a new list. */
|
2020-11-07 19:39:21 +00:00
|
|
|
List *Lst_New(void);
|
2021-01-13 17:24:34 -08:00
|
|
|
/* Free the list nodes, but not the list itself. */
|
|
|
|
void Lst_Done(List *);
|
|
|
|
/* Free the list nodes, freeing the node data using the given function. */
|
|
|
|
void Lst_DoneCall(List *, LstFreeProc);
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Free the list, leaving the node data unmodified. */
|
2020-11-07 19:39:21 +00:00
|
|
|
void Lst_Free(List *);
|
1996-10-06 15:57:15 +00:00
|
|
|
|
2021-01-13 17:24:34 -08:00
|
|
|
#define LST_INIT { NULL, NULL }
|
|
|
|
|
|
|
|
/* Initialize a list, without memory allocation. */
|
|
|
|
MAKE_INLINE void
|
|
|
|
Lst_Init(List *list)
|
|
|
|
{
|
2021-06-25 11:16:24 -07:00
|
|
|
list->first = NULL;
|
|
|
|
list->last = NULL;
|
2021-01-13 17:24:34 -08:00
|
|
|
}
|
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Get information about a list */
|
1996-10-06 15:57:15 +00:00
|
|
|
|
2021-06-25 11:16:24 -07:00
|
|
|
MAKE_INLINE bool
|
2021-01-13 17:24:34 -08:00
|
|
|
Lst_IsEmpty(List *list)
|
2021-06-25 11:16:24 -07:00
|
|
|
{
|
|
|
|
return list->first == NULL;
|
|
|
|
}
|
2020-11-07 19:39:21 +00:00
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Find the first node that contains the given datum, or NULL. */
|
2020-11-07 19:39:21 +00:00
|
|
|
ListNode *Lst_FindDatum(List *, const void *);
|
1996-10-06 15:57:15 +00:00
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Modify a list */
|
1996-10-06 15:57:15 +00:00
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Insert a datum before the given node. */
|
2020-11-07 19:39:21 +00:00
|
|
|
void Lst_InsertBefore(List *, ListNode *, void *);
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Place a datum at the front of the list. */
|
2020-11-07 19:39:21 +00:00
|
|
|
void Lst_Prepend(List *, void *);
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Place a datum at the end of the list. */
|
2020-11-07 19:39:21 +00:00
|
|
|
void Lst_Append(List *, void *);
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Remove the node from the list. */
|
2020-11-07 19:39:21 +00:00
|
|
|
void Lst_Remove(List *, ListNode *);
|
|
|
|
void Lst_PrependAll(List *, List *);
|
|
|
|
void Lst_AppendAll(List *, List *);
|
|
|
|
void Lst_MoveAll(List *, List *);
|
2020-09-05 16:11:04 +00:00
|
|
|
|
|
|
|
/* Node-specific functions */
|
|
|
|
|
|
|
|
/* Replace the value of the node. */
|
2020-11-07 19:39:21 +00:00
|
|
|
void LstNode_Set(ListNode *, void *);
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Set the value of the node to NULL. Having NULL in a list is unusual. */
|
2020-11-07 19:39:21 +00:00
|
|
|
void LstNode_SetNull(ListNode *);
|
2020-09-05 16:11:04 +00:00
|
|
|
|
|
|
|
/* Using the list as a queue */
|
|
|
|
|
|
|
|
/* Add a datum at the tail of the queue. */
|
2021-01-13 17:24:34 -08:00
|
|
|
MAKE_INLINE void
|
|
|
|
Lst_Enqueue(List *list, void *datum) {
|
|
|
|
Lst_Append(list, datum);
|
|
|
|
}
|
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
/* Remove the head node of the queue and return its datum. */
|
2020-11-07 19:39:21 +00:00
|
|
|
void *Lst_Dequeue(List *);
|
|
|
|
|
2021-01-13 17:24:34 -08:00
|
|
|
/*
|
|
|
|
* A vector is an ordered collection of items, allowing for fast indexed
|
|
|
|
* access.
|
|
|
|
*/
|
2020-11-07 19:39:21 +00:00
|
|
|
typedef struct Vector {
|
2021-01-13 17:24:34 -08:00
|
|
|
void *items; /* memory holding the items */
|
|
|
|
size_t itemSize; /* size of a single item */
|
|
|
|
size_t len; /* number of actually usable elements */
|
|
|
|
size_t cap; /* capacity */
|
2020-11-07 19:39:21 +00:00
|
|
|
} Vector;
|
|
|
|
|
|
|
|
void Vector_Init(Vector *, size_t);
|
|
|
|
|
2021-01-13 17:24:34 -08:00
|
|
|
/*
|
|
|
|
* Return the pointer to the given item in the vector.
|
|
|
|
* The returned data is valid until the next modifying operation.
|
|
|
|
*/
|
2020-11-20 03:54:37 +00:00
|
|
|
MAKE_INLINE void *
|
2020-11-07 19:39:21 +00:00
|
|
|
Vector_Get(Vector *v, size_t i)
|
|
|
|
{
|
2021-01-13 17:24:34 -08:00
|
|
|
unsigned char *items = v->items;
|
|
|
|
return items + i * v->itemSize;
|
2020-11-07 19:39:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void *Vector_Push(Vector *);
|
|
|
|
void *Vector_Pop(Vector *);
|
2021-01-13 17:24:34 -08:00
|
|
|
|
|
|
|
MAKE_INLINE void
|
|
|
|
Vector_Done(Vector *v) {
|
|
|
|
free(v->items);
|
|
|
|
}
|
1996-10-06 15:57:15 +00:00
|
|
|
|
2020-09-05 16:11:04 +00:00
|
|
|
#endif /* MAKE_LST_H */
|