1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2025-01-24 19:03:29 +00:00
emacs/oldXMenu/XCrAssoc.c

57 lines
1.4 KiB
C
Raw Normal View History

1999-10-03 19:36:13 +00:00
/* Copyright Massachusetts Institute of Technology 1985 */
#include "copyright.h"
1999-10-03 19:36:13 +00:00
#include <config.h>
#include <X11/Xlib.h>
#include <errno.h>
#include "X10.h"
#ifndef NULL
#define NULL 0
#endif
/*
* XCreateAssocTable - Create an XAssocTable. The size argument should be
* a power of two for efficiency reasons. Some size suggestions: use 32
* buckets per 100 objects; a reasonable maximum number of object per
* buckets is 8. If there is an error creating the XAssocTable, a NULL
* pointer is returned.
*/
XAssocTable *XCreateAssocTable(register int size)
/* Desired size of the table. */
1999-10-03 19:36:13 +00:00
{
register XAssocTable *table; /* XAssocTable to be initialized. */
register XAssoc *buckets; /* Pointer to the first bucket in */
/* the bucket array. */
2003-02-04 14:56:31 +00:00
1999-10-03 19:36:13 +00:00
/* Malloc the XAssocTable. */
if ((table = (XAssocTable *)malloc(sizeof(XAssocTable))) == NULL) {
/* malloc call failed! */
errno = ENOMEM;
return(NULL);
}
2003-02-04 14:56:31 +00:00
1999-10-03 19:36:13 +00:00
/* calloc the buckets (actually just their headers). */
buckets = (XAssoc *)calloc((unsigned)size, (unsigned)sizeof(XAssoc));
if (buckets == NULL) {
/* calloc call failed! */
errno = ENOMEM;
return(NULL);
}
/* Insert table data into the XAssocTable structure. */
table->buckets = buckets;
table->size = size;
while (--size >= 0) {
/* Initialize each bucket. */
buckets->prev = buckets;
buckets->next = buckets;
buckets++;
}
return(table);
}
2003-09-01 15:45:59 +00:00