Annotation of embedaddon/curl/lib/llist.c, revision 1.1

1.1     ! misho       1: /***************************************************************************
        !             2:  *                                  _   _ ____  _
        !             3:  *  Project                     ___| | | |  _ \| |
        !             4:  *                             / __| | | | |_) | |
        !             5:  *                            | (__| |_| |  _ <| |___
        !             6:  *                             \___|\___/|_| \_\_____|
        !             7:  *
        !             8:  * Copyright (C) 1998 - 2020, Daniel Stenberg, <daniel@haxx.se>, et al.
        !             9:  *
        !            10:  * This software is licensed as described in the file COPYING, which
        !            11:  * you should have received as part of this distribution. The terms
        !            12:  * are also available at https://curl.haxx.se/docs/copyright.html.
        !            13:  *
        !            14:  * You may opt to use, copy, modify, merge, publish, distribute and/or sell
        !            15:  * copies of the Software, and permit persons to whom the Software is
        !            16:  * furnished to do so, under the terms of the COPYING file.
        !            17:  *
        !            18:  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
        !            19:  * KIND, either express or implied.
        !            20:  *
        !            21:  ***************************************************************************/
        !            22: 
        !            23: #include "curl_setup.h"
        !            24: 
        !            25: #include <curl/curl.h>
        !            26: 
        !            27: #include "llist.h"
        !            28: #include "curl_memory.h"
        !            29: 
        !            30: /* this must be the last include file */
        !            31: #include "memdebug.h"
        !            32: 
        !            33: /*
        !            34:  * @unittest: 1300
        !            35:  */
        !            36: void
        !            37: Curl_llist_init(struct curl_llist *l, curl_llist_dtor dtor)
        !            38: {
        !            39:   l->size = 0;
        !            40:   l->dtor = dtor;
        !            41:   l->head = NULL;
        !            42:   l->tail = NULL;
        !            43: }
        !            44: 
        !            45: /*
        !            46:  * Curl_llist_insert_next()
        !            47:  *
        !            48:  * Inserts a new list element after the given one 'e'. If the given existing
        !            49:  * entry is NULL and the list already has elements, the new one will be
        !            50:  * inserted first in the list.
        !            51:  *
        !            52:  * The 'ne' argument should be a pointer into the object to store.
        !            53:  *
        !            54:  * @unittest: 1300
        !            55:  */
        !            56: void
        !            57: Curl_llist_insert_next(struct curl_llist *list, struct curl_llist_element *e,
        !            58:                        const void *p,
        !            59:                        struct curl_llist_element *ne)
        !            60: {
        !            61:   ne->ptr = (void *) p;
        !            62:   if(list->size == 0) {
        !            63:     list->head = ne;
        !            64:     list->head->prev = NULL;
        !            65:     list->head->next = NULL;
        !            66:     list->tail = ne;
        !            67:   }
        !            68:   else {
        !            69:     /* if 'e' is NULL here, we insert the new element first in the list */
        !            70:     ne->next = e?e->next:list->head;
        !            71:     ne->prev = e;
        !            72:     if(!e) {
        !            73:       list->head->prev = ne;
        !            74:       list->head = ne;
        !            75:     }
        !            76:     else if(e->next) {
        !            77:       e->next->prev = ne;
        !            78:     }
        !            79:     else {
        !            80:       list->tail = ne;
        !            81:     }
        !            82:     if(e)
        !            83:       e->next = ne;
        !            84:   }
        !            85: 
        !            86:   ++list->size;
        !            87: }
        !            88: 
        !            89: /*
        !            90:  * @unittest: 1300
        !            91:  */
        !            92: void
        !            93: Curl_llist_remove(struct curl_llist *list, struct curl_llist_element *e,
        !            94:                   void *user)
        !            95: {
        !            96:   void *ptr;
        !            97:   if(e == NULL || list->size == 0)
        !            98:     return;
        !            99: 
        !           100:   if(e == list->head) {
        !           101:     list->head = e->next;
        !           102: 
        !           103:     if(list->head == NULL)
        !           104:       list->tail = NULL;
        !           105:     else
        !           106:       e->next->prev = NULL;
        !           107:   }
        !           108:   else {
        !           109:     if(!e->prev)
        !           110:       list->head = e->next;
        !           111:     else
        !           112:       e->prev->next = e->next;
        !           113: 
        !           114:     if(!e->next)
        !           115:       list->tail = e->prev;
        !           116:     else
        !           117:       e->next->prev = e->prev;
        !           118:   }
        !           119: 
        !           120:   ptr = e->ptr;
        !           121: 
        !           122:   e->ptr  = NULL;
        !           123:   e->prev = NULL;
        !           124:   e->next = NULL;
        !           125: 
        !           126:   --list->size;
        !           127: 
        !           128:   /* call the dtor() last for when it actually frees the 'e' memory itself */
        !           129:   if(list->dtor)
        !           130:     list->dtor(user, ptr);
        !           131: }
        !           132: 
        !           133: void
        !           134: Curl_llist_destroy(struct curl_llist *list, void *user)
        !           135: {
        !           136:   if(list) {
        !           137:     while(list->size > 0)
        !           138:       Curl_llist_remove(list, list->tail, user);
        !           139:   }
        !           140: }
        !           141: 
        !           142: size_t
        !           143: Curl_llist_count(struct curl_llist *list)
        !           144: {
        !           145:   return list->size;
        !           146: }

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