Annotation of embedaddon/nginx/src/core/ngx_queue.c, revision 1.1

1.1     ! misho       1: 
        !             2: /*
        !             3:  * Copyright (C) Igor Sysoev
        !             4:  * Copyright (C) Nginx, Inc.
        !             5:  */
        !             6: 
        !             7: 
        !             8: #include <ngx_config.h>
        !             9: #include <ngx_core.h>
        !            10: 
        !            11: 
        !            12: /*
        !            13:  * find the middle queue element if the queue has odd number of elements
        !            14:  * or the first element of the queue's second part otherwise
        !            15:  */
        !            16: 
        !            17: ngx_queue_t *
        !            18: ngx_queue_middle(ngx_queue_t *queue)
        !            19: {
        !            20:     ngx_queue_t  *middle, *next;
        !            21: 
        !            22:     middle = ngx_queue_head(queue);
        !            23: 
        !            24:     if (middle == ngx_queue_last(queue)) {
        !            25:         return middle;
        !            26:     }
        !            27: 
        !            28:     next = ngx_queue_head(queue);
        !            29: 
        !            30:     for ( ;; ) {
        !            31:         middle = ngx_queue_next(middle);
        !            32: 
        !            33:         next = ngx_queue_next(next);
        !            34: 
        !            35:         if (next == ngx_queue_last(queue)) {
        !            36:             return middle;
        !            37:         }
        !            38: 
        !            39:         next = ngx_queue_next(next);
        !            40: 
        !            41:         if (next == ngx_queue_last(queue)) {
        !            42:             return middle;
        !            43:         }
        !            44:     }
        !            45: }
        !            46: 
        !            47: 
        !            48: /* the stable insertion sort */
        !            49: 
        !            50: void
        !            51: ngx_queue_sort(ngx_queue_t *queue,
        !            52:     ngx_int_t (*cmp)(const ngx_queue_t *, const ngx_queue_t *))
        !            53: {
        !            54:     ngx_queue_t  *q, *prev, *next;
        !            55: 
        !            56:     q = ngx_queue_head(queue);
        !            57: 
        !            58:     if (q == ngx_queue_last(queue)) {
        !            59:         return;
        !            60:     }
        !            61: 
        !            62:     for (q = ngx_queue_next(q); q != ngx_queue_sentinel(queue); q = next) {
        !            63: 
        !            64:         prev = ngx_queue_prev(q);
        !            65:         next = ngx_queue_next(q);
        !            66: 
        !            67:         ngx_queue_remove(q);
        !            68: 
        !            69:         do {
        !            70:             if (cmp(prev, q) <= 0) {
        !            71:                 break;
        !            72:             }
        !            73: 
        !            74:             prev = ngx_queue_prev(prev);
        !            75: 
        !            76:         } while (prev != ngx_queue_sentinel(queue));
        !            77: 
        !            78:         ngx_queue_insert_after(prev, q);
        !            79:     }
        !            80: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>