Igor Sysoev | d90282d | 2004-09-28 08:34:51 +0000 | [diff] [blame] | 1 | |
| 2 | /* |
Igor Sysoev | ff8da91 | 2004-09-29 16:00:49 +0000 | [diff] [blame] | 3 | * Copyright (C) Igor Sysoev |
Maxim Konovalov | f8d59e3 | 2012-01-18 15:07:43 +0000 | [diff] [blame] | 4 | * Copyright (C) Nginx, Inc. |
Igor Sysoev | d90282d | 2004-09-28 08:34:51 +0000 | [diff] [blame] | 5 | */ |
| 6 | |
| 7 | |
Igor Sysoev | b9e3441 | 2004-09-03 15:50:30 +0000 | [diff] [blame] | 8 | #ifndef _NGX_LIST_H_INCLUDED_ |
| 9 | #define _NGX_LIST_H_INCLUDED_ |
| 10 | |
| 11 | |
| 12 | #include <ngx_config.h> |
| 13 | #include <ngx_core.h> |
| 14 | |
| 15 | |
| 16 | typedef struct ngx_list_part_s ngx_list_part_t; |
| 17 | |
| 18 | struct ngx_list_part_s { |
| 19 | void *elts; |
| 20 | ngx_uint_t nelts; |
| 21 | ngx_list_part_t *next; |
| 22 | }; |
| 23 | |
| 24 | |
| 25 | typedef struct { |
| 26 | ngx_list_part_t *last; |
| 27 | ngx_list_part_t part; |
| 28 | size_t size; |
| 29 | ngx_uint_t nalloc; |
| 30 | ngx_pool_t *pool; |
| 31 | } ngx_list_t; |
| 32 | |
| 33 | |
Igor Sysoev | 35d5272 | 2006-10-11 12:47:11 +0000 | [diff] [blame] | 34 | ngx_list_t *ngx_list_create(ngx_pool_t *pool, ngx_uint_t n, size_t size); |
| 35 | |
| 36 | static ngx_inline ngx_int_t |
| 37 | ngx_list_init(ngx_list_t *list, ngx_pool_t *pool, ngx_uint_t n, size_t size) |
Igor Sysoev | 980a924 | 2004-09-05 19:54:02 +0000 | [diff] [blame] | 38 | { |
Igor Sysoev | c157172 | 2005-03-19 12:38:37 +0000 | [diff] [blame] | 39 | list->part.elts = ngx_palloc(pool, n * size); |
| 40 | if (list->part.elts == NULL) { |
Igor Sysoev | 980a924 | 2004-09-05 19:54:02 +0000 | [diff] [blame] | 41 | return NGX_ERROR; |
| 42 | } |
| 43 | |
| 44 | list->part.nelts = 0; |
| 45 | list->part.next = NULL; |
| 46 | list->last = &list->part; |
| 47 | list->size = size; |
| 48 | list->nalloc = n; |
| 49 | list->pool = pool; |
| 50 | |
| 51 | return NGX_OK; |
| 52 | } |
Igor Sysoev | b9e3441 | 2004-09-03 15:50:30 +0000 | [diff] [blame] | 53 | |
| 54 | |
Igor Sysoev | 980a924 | 2004-09-05 19:54:02 +0000 | [diff] [blame] | 55 | /* |
| 56 | * |
| 57 | * the iteration through the list: |
| 58 | * |
| 59 | * part = &list.part; |
| 60 | * data = part->elts; |
| 61 | * |
| 62 | * for (i = 0 ;; i++) { |
| 63 | * |
| 64 | * if (i >= part->nelts) { |
| 65 | * if (part->next == NULL) { |
| 66 | * break; |
| 67 | * } |
| 68 | * |
| 69 | * part = part->next; |
| 70 | * data = part->elts; |
| 71 | * i = 0; |
| 72 | * } |
| 73 | * |
| 74 | * ... data[i] ... |
| 75 | * |
| 76 | * } |
| 77 | */ |
Igor Sysoev | b9e3441 | 2004-09-03 15:50:30 +0000 | [diff] [blame] | 78 | |
| 79 | |
Igor Sysoev | aab4d8c | 2004-09-06 18:45:00 +0000 | [diff] [blame] | 80 | void *ngx_list_push(ngx_list_t *list); |
Igor Sysoev | b9e3441 | 2004-09-03 15:50:30 +0000 | [diff] [blame] | 81 | |
| 82 | |
| 83 | #endif /* _NGX_LIST_H_INCLUDED_ */ |