2004-09-03 10:50:30 -05:00
|
|
|
|
2004-09-28 03:34:51 -05:00
|
|
|
/*
|
2004-09-29 11:00:49 -05:00
|
|
|
* Copyright (C) Igor Sysoev
|
2004-09-28 03:34:51 -05:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2004-09-03 10:50:30 -05:00
|
|
|
#include <ngx_config.h>
|
|
|
|
#include <ngx_core.h>
|
|
|
|
|
|
|
|
|
2006-10-11 07:47:11 -05:00
|
|
|
ngx_list_t *
|
|
|
|
ngx_list_create(ngx_pool_t *pool, ngx_uint_t n, size_t size)
|
|
|
|
{
|
|
|
|
ngx_list_t *list;
|
|
|
|
|
|
|
|
list = ngx_palloc(pool, sizeof(ngx_list_t));
|
|
|
|
if (list == NULL) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
list->part.elts = ngx_palloc(pool, n * size);
|
|
|
|
if (list->part.elts == NULL) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
list->part.nelts = 0;
|
|
|
|
list->part.next = NULL;
|
|
|
|
list->last = &list->part;
|
|
|
|
list->size = size;
|
|
|
|
list->nalloc = n;
|
|
|
|
list->pool = pool;
|
|
|
|
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void *
|
|
|
|
ngx_list_push(ngx_list_t *l)
|
2004-09-03 10:50:30 -05:00
|
|
|
{
|
|
|
|
void *elt;
|
|
|
|
ngx_list_part_t *last;
|
|
|
|
|
|
|
|
last = l->last;
|
|
|
|
|
|
|
|
if (last->nelts == l->nalloc) {
|
|
|
|
|
|
|
|
/* the last part is full, allocate a new list part */
|
|
|
|
|
2005-03-19 06:38:37 -06:00
|
|
|
last = ngx_palloc(l->pool, sizeof(ngx_list_part_t));
|
|
|
|
if (last == NULL) {
|
2004-09-03 10:50:30 -05:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2005-03-19 06:38:37 -06:00
|
|
|
last->elts = ngx_palloc(l->pool, l->nalloc * l->size);
|
|
|
|
if (last->elts == NULL) {
|
2004-09-03 10:50:30 -05:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
last->nelts = 0;
|
|
|
|
last->next = NULL;
|
|
|
|
|
|
|
|
l->last->next = last;
|
|
|
|
l->last = last;
|
|
|
|
}
|
|
|
|
|
|
|
|
elt = (char *) last->elts + l->size * last->nelts;
|
|
|
|
last->nelts++;
|
|
|
|
|
|
|
|
return elt;
|
|
|
|
}
|