gurba-0.40/
gurba-0.40/bin/
gurba-0.40/lib/
gurba-0.40/lib/cmds/guild/fighter/
gurba-0.40/lib/cmds/monster/
gurba-0.40/lib/cmds/race/catfolk/
gurba-0.40/lib/cmds/race/dwarf/
gurba-0.40/lib/cmds/verb/
gurba-0.40/lib/daemons/data/
gurba-0.40/lib/data/boards/
gurba-0.40/lib/data/messages/
gurba-0.40/lib/data/players/
gurba-0.40/lib/design/
gurba-0.40/lib/domains/gurba/
gurba-0.40/lib/domains/gurba/guilds/fighter/
gurba-0.40/lib/domains/gurba/monsters/
gurba-0.40/lib/domains/gurba/objects/armor/
gurba-0.40/lib/domains/gurba/objects/clothing/
gurba-0.40/lib/domains/gurba/objects/weapons/
gurba-0.40/lib/domains/gurba/vendors/
gurba-0.40/lib/kernel/cmds/admin/
gurba-0.40/lib/kernel/daemons/
gurba-0.40/lib/kernel/include/
gurba-0.40/lib/kernel/lib/
gurba-0.40/lib/kernel/net/
gurba-0.40/lib/kernel/sys/
gurba-0.40/lib/logs/
gurba-0.40/lib/pub/
gurba-0.40/lib/std/modules/languages/
gurba-0.40/lib/std/races/
gurba-0.40/lib/std/races/monsters/
gurba-0.40/lib/wiz/fudge/
gurba-0.40/lib/wiz/spud/
gurba-0.40/src/host/beos/
gurba-0.40/src/host/pc/res/
gurba-0.40/src/kfun/
gurba-0.40/src/lpc/
gurba-0.40/src/parser/
gurba-0.40/tmp/
# include <string.h>

# define IDX(a, i, n)	((void *) ((char *) (a) + (i) * (n)))

/*
 * NAME:	qsort()
 * DESCRIPTION:	sort an array
 */
void qsort(void *arr, size_t size, size_t sz,
	   int (*cmp)(const void *a, const void *b))
{
    char elt[128];
    void *val;
    int n, i, j;

    i = 1;
    for (;;) {
	if (i >= size) {
	    return;
	}
	if (cmp(IDX(arr, i - 1, sz), IDX(arr, i, sz)) > 0) {
	    break;
	}
	i++;
    }

    for (n = 1; n < size; n <<= 1) ;

    for (n >>= 1; n > 0; --n) {
	memcpy(elt, IDX(arr, n - 1, sz), sz);
	for (i = n, j = n << 1; j <= size; i = j, j <<= 1) {
	    val = IDX(arr, j - 1, sz);
	    if (j < size && cmp(IDX(arr, j, sz), val) > 0) {
		val = IDX(arr, j++, sz);
	    }
	    if (cmp(elt, val) > 0) {
		break;
	    }
	    memcpy(IDX(arr, i - 1, sz), val, sz);
	}
	memcpy(IDX(arr, i - 1, sz), elt, sz);
    }

    for (n = size - 1; n > 0; --n) {
	memcpy(elt, IDX(arr, n, sz), sz);
	memcpy(IDX(arr, n, sz), arr, sz);
	for (i = 1, j = 2; j <= n; i = j, j <<= 1) {
	    val = IDX(arr, j - 1, sz);
	    if (j < n && cmp(IDX(arr, j, sz), val) > 0) {
		val = IDX(arr, j++, sz);
	    }
	    if (cmp(elt, val) > 0) {
		break;
	    }
	    memcpy(IDX(arr, i - 1, sz), val, sz);
	}
	memcpy(IDX(arr, i - 1, sz), elt, sz);
    }
}