src/core/ngx_queue.h - nginx source code

Data types defined

Macros defined

Source code


  1. /*
  2. * Copyright (C) Igor Sysoev
  3. * Copyright (C) Nginx, Inc.
  4. */


  5. #include <ngx_config.h>
  6. #include <ngx_core.h>


  7. #ifndef _NGX_QUEUE_H_INCLUDED_
  8. #define _NGX_QUEUE_H_INCLUDED_


  9. typedef struct ngx_queue_s  ngx_queue_t;

  10. struct ngx_queue_s {
  11.     ngx_queue_t  *prev;
  12.     ngx_queue_t  *next;
  13. };


  14. #define ngx_queue_init(q)                                                     \
  15.     (q)->prev = q;                                                            \
  16.     (q)->next = q


  17. #define ngx_queue_empty(h)                                                    \
  18.     (h == (h)->prev)


  19. #define ngx_queue_insert_head(h, x)                                           \
  20.     (x)->next = (h)->next;                                                    \
  21.     (x)->next->prev = x;                                                      \
  22.     (x)->prev = h;                                                            \
  23.     (h)->next = x


  24. #define ngx_queue_insert_after   ngx_queue_insert_head


  25. #define ngx_queue_insert_tail(h, x)                                           \
  26.     (x)->prev = (h)->prev;                                                    \
  27.     (x)->prev->next = x;                                                      \
  28.     (x)->next = h;                                                            \
  29.     (h)->prev = x


  30. #define ngx_queue_insert_before   ngx_queue_insert_tail


  31. #define ngx_queue_head(h)                                                     \
  32.     (h)->next


  33. #define ngx_queue_last(h)                                                     \
  34.     (h)->prev


  35. #define ngx_queue_sentinel(h)                                                 \
  36.     (h)


  37. #define ngx_queue_next(q)                                                     \
  38.     (q)->next


  39. #define ngx_queue_prev(q)                                                     \
  40.     (q)->prev


  41. #if (NGX_DEBUG)

  42. #define ngx_queue_remove(x)                                                   \
  43.     (x)->next->prev = (x)->prev;                                              \
  44.     (x)->prev->next = (x)->next;                                              \
  45.     (x)->prev = NULL;                                                         \
  46.     (x)->next = NULL

  47. #else

  48. #define ngx_queue_remove(x)                                                   \
  49.     (x)->next->prev = (x)->prev;                                              \
  50.     (x)->prev->next = (x)->next

  51. #endif


  52. #define ngx_queue_split(h, q, n)                                              \
  53.     (n)->prev = (h)->prev;                                                    \
  54.     (n)->prev->next = n;                                                      \
  55.     (n)->next = q;                                                            \
  56.     (h)->prev = (q)->prev;                                                    \
  57.     (h)->prev->next = h;                                                      \
  58.     (q)->prev = n;


  59. #define ngx_queue_add(h, n)                                                   \
  60.     (h)->prev->next = (n)->next;                                              \
  61.     (n)->next->prev = (h)->prev;                                              \
  62.     (h)->prev = (n)->prev;                                                    \
  63.     (h)->prev->next = h;


  64. #define ngx_queue_data(q, type, link)                                         \
  65.     (type *) ((u_char *) q - offsetof(type, link))


  66. ngx_queue_t *ngx_queue_middle(ngx_queue_t *queue);
  67. void ngx_queue_sort(ngx_queue_t *queue,
  68.     ngx_int_t (*cmp)(const ngx_queue_t *, const ngx_queue_t *));


  69. #endif /* _NGX_QUEUE_H_INCLUDED_ */