removing quicklist, importing it from a submodule

This commit is contained in:
Enno Rehling 2012-05-30 19:55:17 -07:00
parent 6e106c9fc0
commit db094810fd
35 changed files with 30 additions and 537 deletions

View file

@ -27,7 +27,7 @@ without prior permission by the authors of Eressea.
#include <util/language.h> #include <util/language.h>
#include <util/log.h> #include <util/log.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <lua.h> #include <lua.h>
#include <tolua.h> #include <tolua.h>

View file

@ -44,7 +44,7 @@ without prior permission by the authors of Eressea.
#include <util/event.h> #include <util/event.h>
#include <util/lists.h> #include <util/lists.h>
#include <util/log.h> #include <util/log.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <lua.h> #include <lua.h>
#include <tolua.h> #include <tolua.h>

View file

@ -57,7 +57,7 @@ without prior permission by the authors of Eressea.
#include <util/language.h> #include <util/language.h>
#include <util/lists.h> #include <util/lists.h>
#include <util/log.h> #include <util/log.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rand.h> #include <util/rand.h>
#include <util/rng.h> #include <util/rng.h>
#include <util/storage.h> #include <util/storage.h>

View file

@ -21,7 +21,6 @@
#include <util/nrmessage.c> #include <util/nrmessage.c>
#include <util/os.c> #include <util/os.c>
#include <util/parser.c> #include <util/parser.c>
#include <util/quicklist.c>
#include <util/rand.c> #include <util/rand.c>
#include <util/resolve.c> #include <util/resolve.c>
#include <util/sql.c> #include <util/sql.c>

View file

@ -64,7 +64,7 @@ without prior permission by the authors of Eressea.
#include <util/log.h> #include <util/log.h>
#include <util/message.h> #include <util/message.h>
#include <util/nrmessage.h> #include <util/nrmessage.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <libxml/encoding.h> #include <libxml/encoding.h>

View file

@ -78,7 +78,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/lists.h> #include <util/lists.h>
#include <util/log.h> #include <util/log.h>
#include <util/parser.h> #include <util/parser.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rand.h> #include <util/rand.h>
#include <util/rng.h> #include <util/rng.h>
#include <util/sql.h> #include <util/sql.h>

View file

@ -17,7 +17,7 @@ without prior permission by the authors of Eressea.
#include <assert.h> #include <assert.h>
#include <util/attrib.h> #include <util/attrib.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rng.h> #include <util/rng.h>
#include <kernel/building.h> #include <kernel/building.h>

View file

@ -77,7 +77,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/log.h> #include <util/log.h>
#include <util/message.h> #include <util/message.h>
#include <util/nrmessage.h> #include <util/nrmessage.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rng.h> #include <util/rng.h>
#include <libxml/encoding.h> #include <libxml/encoding.h>

View file

@ -43,7 +43,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/attrib.h> #include <util/attrib.h>
#include <util/base36.h> #include <util/base36.h>
#include <util/parser.h> #include <util/parser.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rand.h> #include <util/rand.h>
#include <util/rng.h> #include <util/rng.h>

View file

@ -58,7 +58,7 @@ without prior permission by the authors of Eressea.
#include <util/goodies.h> #include <util/goodies.h>
#include <util/language.h> #include <util/language.h>
#include <util/message.h> #include <util/message.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/unicode.h> #include <util/unicode.h>
#include <util/xml.h> #include <util/xml.h>

View file

@ -34,7 +34,7 @@ without prior permission by the authors of Eressea.
#include <util/bsdstring.h> #include <util/bsdstring.h>
#include <util/language.h> #include <util/language.h>
#include <util/parser.h> #include <util/parser.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rng.h> #include <util/rng.h>
#include <util/umlaut.h> #include <util/umlaut.h>

View file

@ -61,7 +61,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/log.h> #include <util/log.h>
#include <util/os.h> #include <util/os.h>
#include <util/parser.h> #include <util/parser.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rand.h> #include <util/rand.h>
#include <util/rng.h> #include <util/rng.h>

View file

@ -40,7 +40,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/functions.h> #include <util/functions.h>
#include <util/language.h> #include <util/language.h>
#include <util/log.h> #include <util/log.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/resolve.h> #include <util/resolve.h>
#include <util/storage.h> #include <util/storage.h>
#include <util/umlaut.h> #include <util/umlaut.h>

View file

@ -62,7 +62,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/log.h> #include <util/log.h>
#include <util/lists.h> #include <util/lists.h>
#include <util/parser.h> #include <util/parser.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rand.h> #include <util/rand.h>
#include <util/rng.h> #include <util/rng.h>
#include <util/sql.h> #include <util/sql.h>

View file

@ -29,7 +29,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/attrib.h> #include <util/attrib.h>
#include <util/language.h> #include <util/language.h>
#include <util/log.h> #include <util/log.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rng.h> #include <util/rng.h>
#include <util/storage.h> #include <util/storage.h>

View file

@ -284,7 +284,7 @@ attrib_type at_curse = {
/* Spruch identifizieren */ /* Spruch identifizieren */
#include <util/umlaut.h> #include <util/umlaut.h>
#include <util/quicklist.h> #include <quicklist.h>
static quicklist *cursetypes[256]; static quicklist *cursetypes[256];

View file

@ -28,7 +28,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include "spellbook.h" #include "spellbook.h"
/* util includes */ /* util includes */
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rand.h> #include <util/rand.h>
#include <util/rng.h> #include <util/rng.h>

View file

@ -8,7 +8,7 @@
#include <kernel/skill.h> #include <kernel/skill.h>
#include <kernel/spell.h> #include <kernel/spell.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <CuTest.h> #include <CuTest.h>
#include <tests.h> #include <tests.h>

View file

@ -41,7 +41,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/lists.h> #include <util/lists.h>
#include <util/language.h> #include <util/language.h>
#include <util/log.h> #include <util/log.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/resolve.h> #include <util/resolve.h>
#include <util/rng.h> #include <util/rng.h>
#include <util/storage.h> #include <util/storage.h>

View file

@ -57,7 +57,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/lists.h> #include <util/lists.h>
#include <util/log.h> #include <util/log.h>
#include <util/parser.h> #include <util/parser.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/resolve.h> #include <util/resolve.h>
#include <util/rand.h> #include <util/rand.h>
#include <util/rng.h> #include <util/rng.h>

View file

@ -10,7 +10,7 @@
#include <kernel/spellbook.h> #include <kernel/spellbook.h>
#include <kernel/unit.h> #include <kernel/unit.h>
#include <kernel/pool.h> #include <kernel/pool.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/language.h> #include <util/language.h>
#include <CuTest.h> #include <CuTest.h>

View file

@ -18,7 +18,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <platform.h> #include <platform.h>
#include <kernel/config.h> #include <kernel/config.h>
#include <util/quicklist.h> #include <quicklist.h>
#include "pathfinder.h" #include "pathfinder.h"
#include "region.h" #include "region.h"

View file

@ -53,7 +53,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/lists.h> #include <util/lists.h>
#include <util/log.h> #include <util/log.h>
#include <util/os.h> #include <util/os.h>
#include <util/quicklist.h> #include <quicklist.h>
/* libc includes */ /* libc includes */
#include <sys/stat.h> #include <sys/stat.h>

View file

@ -65,7 +65,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/log.h> #include <util/log.h>
#include <util/os.h> #include <util/os.h>
#include <util/parser.h> #include <util/parser.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rand.h> #include <util/rand.h>
#include <util/resolve.h> #include <util/resolve.h>
#include <util/rng.h> #include <util/rng.h>

View file

@ -36,7 +36,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/language.h> #include <util/language.h>
#include <util/lists.h> #include <util/lists.h>
#include <util/umlaut.h> #include <util/umlaut.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/storage.h> #include <util/storage.h>
#include <util/xml.h> #include <util/xml.h>

View file

@ -26,7 +26,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/language.h> #include <util/language.h>
#include <util/log.h> #include <util/log.h>
#include <util/umlaut.h> #include <util/umlaut.h>
#include <util/quicklist.h> #include <quicklist.h>
/* libc includes */ /* libc includes */
#include <assert.h> #include <assert.h>

View file

@ -1,6 +1,6 @@
#include <platform.h> #include <platform.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <kernel/types.h> #include <kernel/types.h>
#include <kernel/spell.h> #include <kernel/spell.h>
#include <kernel/magic.h> #include <kernel/magic.h>

View file

@ -2,7 +2,7 @@
#include <kernel/config.h> #include <kernel/config.h>
#include <kernel/spell.h> #include <kernel/spell.h>
#include <kernel/magic.h> #include <kernel/magic.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/log.h> #include <util/log.h>
#include "spellbook.h" #include "spellbook.h"

View file

@ -4,7 +4,7 @@
#include <kernel/magic.h> #include <kernel/magic.h>
#include <kernel/spell.h> #include <kernel/spell.h>
#include <kernel/spellbook.h> #include <kernel/spellbook.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/language.h> #include <util/language.h>
#include <CuTest.h> #include <CuTest.h>

View file

@ -35,7 +35,7 @@
#include <util/language.h> #include <util/language.h>
#include <util/lists.h> #include <util/lists.h>
#include <util/log.h> #include <util/log.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/rng.h> #include <util/rng.h>
#include <util/sql.h> #include <util/sql.h>
#include <util/unicode.h> #include <util/unicode.h>

View file

@ -30,7 +30,7 @@
#include <util/language.h> #include <util/language.h>
#include <util/resolve.h> #include <util/resolve.h>
#include <util/rng.h> #include <util/rng.h>
#include <util/quicklist.h> #include <quicklist.h>
#include <util/storage.h> #include <util/storage.h>
/* libc includes */ /* libc includes */

View file

@ -8,7 +8,6 @@
#include <util/base36_test.c> #include <util/base36_test.c>
#include <util/bsdstring_test.c> #include <util/bsdstring_test.c>
#include <util/functions_test.c> #include <util/functions_test.c>
#include <util/quicklist_test.c>
#include <util/umlaut_test.c> #include <util/umlaut_test.c>
#include <kernel/magic_test.c> #include <kernel/magic_test.c>
#include <kernel/move_test.c> #include <kernel/move_test.c>
@ -51,7 +50,6 @@ int RunAllTests(void)
/* util */ /* util */
CuSuiteAddSuite(suite, get_base36_suite()); CuSuiteAddSuite(suite, get_base36_suite());
CuSuiteAddSuite(suite, get_bsdstring_suite()); CuSuiteAddSuite(suite, get_bsdstring_suite());
CuSuiteAddSuite(suite, get_quicklist_suite());
CuSuiteAddSuite(suite, get_functions_suite()); CuSuiteAddSuite(suite, get_functions_suite());
CuSuiteAddSuite(suite, get_umlaut_suite()); CuSuiteAddSuite(suite, get_umlaut_suite());
/* kernel */ /* kernel */

View file

@ -1,256 +0,0 @@
/*
Copyright (c) 2010-2011, Enno Rehling <enno@eressea.de>
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted, provided that the above
copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
**/
#include "quicklist.h"
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#define QL_MAXSIZE 14 /* max. number of elements unrolled into one node */
#define QL_LIMIT 7 /* this many or fewer number in a node => attempt merge */
/* The total size of this struct is 64 bytes on a 32-bit system with
* normal alignment. YMMV, so on a 64-bit system, twiddle the
* constants above */
struct quicklist {
struct quicklist *next;
int num_elements;
void *elements[QL_MAXSIZE];
};
void *ql_get(const quicklist * ql, int index)
{
return (ql
&& index < ql->num_elements) ? ql->elements[index] : ql_get(ql->next,
index - ql->num_elements);
}
void *ql_replace(quicklist * ql, int index, void *data)
{
if (ql && index < ql->num_elements) {
void *orig = ql->elements[index];
ql->elements[index] = data;
return orig;
} else {
return ql_replace(ql->next, index - ql->num_elements, data);
}
}
int ql_length(const quicklist * ql)
{
return ql ? ql->num_elements + ql_length(ql->next) : 0;
}
int ql_empty(const quicklist * ql)
{
return !ql;
}
void ql_push(quicklist ** qlp, void *data)
{
quicklist *ql = 0;
while (*qlp && ((*qlp)->next || (*qlp)->num_elements == QL_MAXSIZE)) {
qlp = &(*qlp)->next;
}
if (!*qlp) {
ql = (quicklist *) malloc(sizeof(quicklist));
ql->num_elements = 0;
ql->next = 0;
*qlp = ql;
} else {
ql = *qlp;
}
ql->elements[ql->num_elements++] = data;
}
int ql_delete(quicklist ** qlp, int index)
{
quicklist *ql = *qlp;
if (index < 0)
return EINVAL;
if (ql && index >= ql->num_elements) {
return ql_delete(&ql->next, index - ql->num_elements);
} else if (ql) {
if (index + 1 < ql->num_elements) {
memmove(ql->elements + index, ql->elements + index + 1,
(ql->num_elements - index - 1) * sizeof(void *));
}
--ql->num_elements;
if (ql->num_elements == 0) {
*qlp = ql->next;
free(ql);
} else if (ql->next && ql->num_elements <= QL_LIMIT) {
quicklist *qn = ql->next;
if (ql->num_elements + qn->num_elements > QL_MAXSIZE) {
memcpy(ql->elements + ql->num_elements, qn->elements, sizeof(void *));
--qn->num_elements;
++ql->num_elements;
memmove(qn->elements, qn->elements + 1,
qn->num_elements * sizeof(void *));
} else {
memcpy(ql->elements + ql->num_elements, qn->elements,
qn->num_elements * sizeof(void *));
ql->num_elements += qn->num_elements;
ql->next = qn->next;
free(qn);
}
}
}
return 0;
}
int ql_insert(quicklist ** qlp, int index, void *data)
{
quicklist *ql = *qlp;
if (ql) {
if (index >= QL_MAXSIZE) {
return ql_insert(&ql->next, index - ql->num_elements, data);
} else if (ql->num_elements < QL_MAXSIZE) {
memmove(ql->elements + index + 1, ql->elements + index,
(ql->num_elements - index) * sizeof(void *));
ql->elements[index] = data;
++ql->num_elements;
} else {
quicklist *qn = (quicklist *) malloc(sizeof(quicklist));
qn->next = ql->next;
ql->next = qn;
qn->num_elements = ql->num_elements-QL_LIMIT;
ql->num_elements = QL_LIMIT;
memcpy(qn->elements, ql->elements + ql->num_elements,
qn->num_elements * sizeof(void *));
if (index <= ql->num_elements) {
return ql_insert(qlp, index, data);
} else {
return ql_insert(&ql->next, index - ql->num_elements, data);
}
}
} else if (index == 0) {
ql_push(qlp, data);
} else {
return EINVAL;
}
return 0;
}
void ql_foreach(struct quicklist *ql, void (*cb) (void *))
{
for (; ql; ql = ql->next) {
int i;
for (i = 0; i != ql->num_elements; ++i) {
cb(ql->elements[i]);
}
}
}
int ql_advance(struct quicklist **iterator, int *index, int stride)
{
quicklist *ql = *iterator;
int i = *index;
if (!ql || i < 0 || stride < 0) {
return ERANGE;
} else if (i + stride < ql->num_elements) {
*index = i + stride;
return 0;
} else {
*index = i - ql->num_elements + stride;
*iterator = ql->next;
return ql_advance(iterator, index, 0);
}
}
void ql_free(struct quicklist *ql)
{
while (ql) {
quicklist * qn = ql;
ql = ql->next;
free(qn);
}
}
int ql_set_remove(struct quicklist **qlp, void *data)
{
int qi;
quicklist *ql = *qlp;
if (!ql)
return 0;
for (qi = 0; qi != ql->num_elements; ++qi) {
void *qd = ql_get(ql, qi);
if (qd == data) {
return ql_delete(qlp, qi) == 0;
}
}
return ql_set_remove(&ql->next, data);
}
int ql_set_insert(struct quicklist **qlp, void *data)
{
if (*qlp) {
quicklist *ql = *qlp;
if (ql->num_elements > 0 && ql->elements[ql->num_elements - 1] < data) {
if (ql->num_elements == QL_MAXSIZE || (ql->next
&& ql->next->elements[0] <= data)) {
return ql_set_insert(&ql->next, data);
} else {
ql->elements[ql->num_elements++] = data;
}
return 0;
} else {
int i;
/* TODO: OPT | binary search */
for (i = 0; i != ql->num_elements; ++i) {
if (data < ql->elements[i]) {
ql_insert(qlp, i, data);
return 0;
}
if (data == ql->elements[i]) {
return 1;
}
}
}
}
ql_push(qlp, data);
return 0;
}
int ql_set_find(struct quicklist **qlp, int *qip, const void *data)
{
quicklist *ql = *qlp;
int qi;
while (ql && ql->elements[ql->num_elements - 1] < data) {
ql = ql->next;
}
if (!ql)
return 0;
/* TODO: OPT | binary search */
for (qi = 0; qi != ql->num_elements; ++qi) {
if (ql->elements[qi] > data) {
return 0;
}
if (ql->elements[qi] == data) {
if (qip) {
*qip = qi;
*qlp = ql;
}
return 1;
}
}
return 0;
}

View file

@ -1,45 +0,0 @@
/*
Copyright (c) 2010-2011, Enno Rehling <enno@eressea.de>
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted, provided that the above
copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
**/
#ifndef _QUICKLIST_H
#define _QUICKLIST_H
#ifdef __cplusplus
extern "C" {
#endif
/* see http://en.wikipedia.org/wiki/Unrolled_linked_list */
typedef struct quicklist quicklist;
void *ql_get(const struct quicklist *ql, int index);
int ql_length(const struct quicklist *ql);
int ql_empty(const struct quicklist *ql);
void ql_push(struct quicklist **qlp, void *data);
int ql_delete(struct quicklist **qlp, int index);
int ql_insert(struct quicklist **qlp, int index, void *data);
void ql_foreach(struct quicklist *ql, void (*cb) (void *));
int ql_advance(struct quicklist **iterator, int *index, int stride);
void ql_free(struct quicklist *ql);
void *ql_replace(struct quicklist *ql, int index, void *data);
/* you can use it as a set (sorted pointers)*/
int ql_set_insert(struct quicklist **qlp, void *data);
int ql_set_find(struct quicklist **qlp, int *qip, const void *data);
int ql_set_remove(struct quicklist **qlp, void *data);
#ifdef __cplusplus
}
#endif
#endif

View file

@ -1,203 +0,0 @@
#include <CuTest.h>
#include <stdio.h>
#include <string.h>
#include "quicklist.h"
static const char *hello = "Hello World";
static void test_insert(CuTest * tc)
{
struct quicklist *ql = NULL;
int i;
for (i = 0; i != 32; ++i) {
CuAssertIntEquals(tc, i, ql_length(ql));
ql_insert(&ql, 0, (void *)i);
}
for (i = 0; i != 32; ++i) {
CuAssertIntEquals(tc, 31 - i, (int)ql_get(ql, i));
}
}
static void test_insert_delete_gives_null(CuTest * tc)
{
struct quicklist *ql = NULL;
CuAssertIntEquals(tc, 1, ql_empty(ql));
ql_push(&ql, (void *)42);
CuAssertIntEquals(tc, 0, ql_empty(ql));
ql_delete(&ql, 0);
CuAssertPtrEquals(tc, 0, ql);
}
static void test_replace(CuTest * tc)
{
struct quicklist *ql = NULL;
int a;
ql_push(&ql, (void *)42);
a = (int)ql_replace(ql, 0, (void *)43);
CuAssertIntEquals(tc, 42, a);
CuAssertIntEquals(tc, 43, (int)ql_get(ql, 0));
}
static void test_set_insert(CuTest * tc)
{
struct quicklist *ql = NULL;
int a, qi;
a = ql_set_insert(&ql, (void *)42);
CuAssertIntEquals(tc, 1, ql_length(ql));
CuAssertIntEquals(tc, 0, a);
a = ql_set_insert(&ql, (void *)43);
CuAssertIntEquals(tc, 2, ql_length(ql));
CuAssertIntEquals(tc, 0, a);
a = ql_set_insert(&ql, (void *)42);
CuAssertIntEquals(tc, 2, ql_length(ql));
CuAssertIntEquals(tc, 1, a);
a = ql_set_insert(&ql, (void *)41);
CuAssertIntEquals(tc, 0, a);
CuAssertIntEquals(tc, 3, ql_length(ql));
CuAssertIntEquals(tc, 41, (int)ql_get(ql, 0));
CuAssertIntEquals(tc, 42, (int)ql_get(ql, 1));
CuAssertIntEquals(tc, 43, (int)ql_get(ql, 2));
a = ql_set_find(&ql, &qi, (void *)49);
CuAssertIntEquals(tc, 0, a);
a = ql_set_find(&ql, &qi, (void *)42);
CuAssertIntEquals(tc, 1, a);
CuAssertIntEquals(tc, 42, (int)ql_get(ql, qi));
}
static void test_set_remove(CuTest * tc)
{
struct quicklist *ql = NULL, *q2;
int a;
ql_set_insert(&ql, (void *)41);
ql_set_insert(&ql, (void *)42);
ql_set_insert(&ql, (void *)43);
q2 = ql;
a = ql_set_remove(&ql, (void *)42);
CuAssertPtrEquals(tc, q2, ql);
CuAssertIntEquals(tc, 1, a);
CuAssertIntEquals(tc, 41, (int)ql_get(ql, 0));
CuAssertIntEquals(tc, 43, (int)ql_get(ql, 1));
CuAssertIntEquals(tc, 2, ql_length(ql));
a = ql_set_remove(&ql, (void *)42);
CuAssertPtrEquals(tc, q2, ql);
CuAssertIntEquals(tc, 0, a);
ql_set_remove(&ql, (void *)41);
ql_set_remove(&ql, (void *)43);
CuAssertPtrEquals(tc, 0, ql);
}
static void test_set_find(CuTest * tc)
{
struct quicklist *ql = NULL, *q2;
int a, qi;
for (a = 0; a != 32; ++a) {
ql_set_insert(&ql, (void *)a);
}
q2 = ql;
a = ql_set_find(&q2, 0, (void *)31);
CuAssertIntEquals(tc, 1, a);
CuAssertPtrEquals(tc, ql, q2);
q2 = ql;
a = ql_set_find(&ql, &qi, (void *)0);
CuAssertIntEquals(tc, 1, a);
CuAssertIntEquals(tc, 0, qi);
CuAssertPtrEquals(tc, ql, q2);
q2 = ql;
a = ql_set_find(&ql, &qi, (void *)31);
CuAssertIntEquals(tc, 1, a);
CuAssertIntEquals(tc, 31, (int)ql_get(ql, qi));
CuAssertTrue(tc, ql != q2);
}
static void test_advance(CuTest * tc)
{
struct quicklist *ql = NULL, *qli;
int i, n = 31;
for (i = 0; i != 32; ++i) {
ql_insert(&ql, 0, (void *)i);
}
for (i = 0, qli = ql; qli; ql_advance(&qli, &i, 1), n--) {
int g = (int)ql_get(qli, i);
CuAssertIntEquals(tc, n, g);
}
}
static void test_push(CuTest * tc)
{
struct quicklist *ql = NULL;
CuAssertIntEquals(tc, 0, ql_length(ql));
ql_push(&ql, (void *)hello);
CuAssertIntEquals(tc, 1, ql_length(ql));
CuAssertStrEquals(tc, "Hello World", (const char *)ql_get(ql, 0));
ql_delete(&ql, 0);
CuAssertPtrEquals(tc, 0, ql);
}
static void test_delete_edgecases(CuTest * tc)
{
struct quicklist *ql = NULL;
ql_delete(&ql, 0);
CuAssertPtrEquals(tc, 0, ql);
ql_push(&ql, (void *)hello);
ql_delete(&ql, -1);
ql_delete(&ql, 32);
CuAssertIntEquals(tc, 1, ql_length(ql));
}
static void test_insert_many(CuTest * tc)
{
struct quicklist *ql = NULL;
int i;
for (i = 0; i != 32; ++i) {
ql_push(&ql, (void *)i);
}
for (i = 0; i != 32; ++i) {
CuAssertIntEquals(tc, 32 - i, ql_length(ql));
CuAssertIntEquals(tc, i, (int)ql_get(ql, 0));
CuAssertIntEquals(tc, 31, (int)ql_get(ql, ql_length(ql) - 1));
ql_delete(&ql, 0);
}
CuAssertPtrEquals(tc, 0, ql);
}
static void test_delete_rand(CuTest * tc)
{
struct quicklist *ql = NULL;
int i;
for (i = 0; i != 32; ++i) {
ql_push(&ql, (void *)i);
}
CuAssertIntEquals(tc, 32, ql_length(ql));
ql_delete(&ql, 0);
CuAssertIntEquals(tc, 1, (int)ql_get(ql, 0));
CuAssertIntEquals(tc, 31, ql_length(ql));
ql_delete(&ql, 30);
CuAssertIntEquals(tc, 30, ql_length(ql));
}
CuSuite *get_quicklist_suite(void)
{
CuSuite *suite = CuSuiteNew();
SUITE_ADD_TEST(suite, test_advance);
SUITE_ADD_TEST(suite, test_replace);
SUITE_ADD_TEST(suite, test_push);
SUITE_ADD_TEST(suite, test_insert);
SUITE_ADD_TEST(suite, test_set_remove);
SUITE_ADD_TEST(suite, test_set_find);
SUITE_ADD_TEST(suite, test_insert_delete_gives_null);
SUITE_ADD_TEST(suite, test_insert_many);
SUITE_ADD_TEST(suite, test_delete_rand);
SUITE_ADD_TEST(suite, test_delete_edgecases);
SUITE_ADD_TEST(suite, test_set_insert);
return suite;
}