Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 1 | |
| 2 | #include <ngx_config.h> |
Igor Sysoev | 1c10462 | 2003-06-03 15:42:58 +0000 | [diff] [blame] | 3 | #include <ngx_core.h> |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 4 | |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 5 | |
Igor Sysoev | 10a543a | 2004-03-16 07:10:12 +0000 | [diff] [blame] | 6 | ngx_array_t *ngx_create_array(ngx_pool_t *p, ngx_uint_t n, size_t size) |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 7 | { |
| 8 | ngx_array_t *a; |
| 9 | |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 10 | ngx_test_null(a, ngx_palloc(p, sizeof(ngx_array_t)), NULL); |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 11 | |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 12 | ngx_test_null(a->elts, ngx_palloc(p, n * size), NULL); |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 13 | |
| 14 | a->pool = p; |
| 15 | a->nelts = 0; |
| 16 | a->nalloc = n; |
| 17 | a->size = size; |
| 18 | |
| 19 | return a; |
| 20 | } |
| 21 | |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 22 | |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 23 | void ngx_destroy_array(ngx_array_t *a) |
| 24 | { |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 25 | ngx_pool_t *p; |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 26 | |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 27 | p = a->pool; |
| 28 | |
Igor Sysoev | 1c13c66 | 2003-05-20 15:37:55 +0000 | [diff] [blame] | 29 | if ((char *) a->elts + a->size * a->nalloc == p->last) { |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 30 | p->last -= a->size * a->nalloc; |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 31 | } |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 32 | |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 33 | if ((char *) a + sizeof(ngx_array_t) == p->last) { |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 34 | p->last = (char *) a; |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 35 | } |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 36 | } |
| 37 | |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 38 | |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 39 | void *ngx_push_array(ngx_array_t *a) |
| 40 | { |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 41 | void *elt, *new; |
| 42 | ngx_pool_t *p; |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 43 | |
| 44 | /* array is full */ |
| 45 | if (a->nelts == a->nalloc) { |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 46 | p = a->pool; |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 47 | |
| 48 | /* array allocation is the last in the pool */ |
Igor Sysoev | 1c13c66 | 2003-05-20 15:37:55 +0000 | [diff] [blame] | 49 | if ((char *) a->elts + a->size * a->nelts == p->last |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 50 | && (unsigned) (p->end - p->last) >= a->size) |
| 51 | { |
| 52 | p->last += a->size; |
| 53 | a->nalloc++; |
| 54 | |
| 55 | /* allocate new array */ |
| 56 | } else { |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 57 | ngx_test_null(new, ngx_palloc(p, 2 * a->nalloc * a->size), NULL); |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 58 | |
Igor Sysoev | 4e9393a | 2003-01-09 05:36:00 +0000 | [diff] [blame] | 59 | ngx_memcpy(new, a->elts, a->nalloc * a->size); |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 60 | a->elts = new; |
| 61 | a->nalloc *= 2; |
| 62 | } |
| 63 | } |
| 64 | |
Igor Sysoev | 1c13c66 | 2003-05-20 15:37:55 +0000 | [diff] [blame] | 65 | elt = (char *) a->elts + a->size * a->nelts; |
Igor Sysoev | 6de5c2c | 2002-08-06 16:39:45 +0000 | [diff] [blame] | 66 | a->nelts++; |
| 67 | |
| 68 | return elt; |
| 69 | } |