/* * Copyright (c) 2019 TAOS Data, Inc. * * This program is free software: you can use, redistribute, and/or modify * it under the terms of the GNU Affero General Public License, version 3 * or later ("AGPL"), as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ #define _DEFAULT_SOURCE #include "tlist.h" void tdListInit(SList *list, int32_t eleSize) { TD_DLIST_INIT(list); listEleSize(list) = eleSize; } SList *tdListNew(int32_t eleSize) { SList *list = (SList *)taosMemoryMalloc(sizeof(SList)); if (list == NULL) return NULL; tdListInit(list, eleSize); return list; } void tdListEmpty(SList *list) { SListNode *node; while ((node = TD_DLIST_HEAD(list)) != NULL) { TD_DLIST_POP(list, node); taosMemoryFree(node); } } void *tdListFree(SList *list) { if (list) { tdListEmpty(list); taosMemoryFree(list); } return NULL; } void tdListEmptyP(SList *list, FDelete fp) { SListNode *node; while ((node = TD_DLIST_HEAD(list)) != NULL) { TD_DLIST_POP(list, node); fp(node->data); taosMemoryFree(node); } } void *tdListFreeP(SList *list, FDelete fp) { if (list) { tdListEmptyP(list, fp); taosMemoryFree(list); } return NULL; } void tdListPrependNode(SList *list, SListNode *node) { TD_DLIST_PREPEND(list, node); } void tdListAppendNode(SList *list, SListNode *node) { TD_DLIST_APPEND(list, node); } int32_t tdListPrepend(SList *list, void *data) { SListNode *node = (SListNode *)taosMemoryMalloc(sizeof(SListNode) + list->eleSize); if (node == NULL) return -1; memcpy((void *)(node->data), data, list->eleSize); TD_DLIST_PREPEND(list, node); return 0; } int32_t tdListAppend(SList *list, const void *data) { SListNode *node = (SListNode *)taosMemoryCalloc(1, sizeof(SListNode) + list->eleSize); if (node == NULL) return -1; memcpy((void *)(node->data), data, list->eleSize); TD_DLIST_APPEND(list, node); return 0; } // return the node pointer SListNode *tdListAdd(SList *list, const void *data) { SListNode *node = (SListNode *)taosMemoryCalloc(1, sizeof(SListNode) + list->eleSize); if (node == NULL) return NULL; memcpy((void *)(node->data), data, list->eleSize); TD_DLIST_APPEND(list, node); return node; } SListNode *tdListPopHead(SList *list) { SListNode *node; node = TD_DLIST_HEAD(list); if (node) { TD_DLIST_POP(list, node); } return node; } SListNode *tdListPopTail(SList *list) { SListNode *node; node = TD_DLIST_TAIL(list); if (node) { TD_DLIST_POP(list, node); } return node; } SListNode *tdListGetHead(SList *list) { return TD_DLIST_HEAD(list); } SListNode *tdListGetTail(SList *list) { return TD_DLIST_TAIL(list); } SListNode *tdListPopNode(SList *list, SListNode *node) { TD_DLIST_POP(list, node); return node; } // Move all node elements from src to dst, the dst is assumed as an empty list void tdListMove(SList *src, SList *dst) { SListNode *node = NULL; while ((node = tdListPopHead(src)) != NULL) { tdListAppendNode(dst, node); } } void tdListDiscard(SList *list) { if (list) { listHead(list) = listTail(list) = NULL; listNEles(list) = 0; } } void tdListNodeGetData(SList *list, SListNode *node, void *target) { memcpy(target, node->data, listEleSize(list)); } void tdListInitIter(SList *list, SListIter *pIter, TD_LIST_DIRECTION_T direction) { pIter->direction = direction; if (direction == TD_LIST_FORWARD) { pIter->next = listHead(list); } else { pIter->next = listTail(list); } } SListNode *tdListNext(SListIter *pIter) { SListNode *node = pIter->next; if (node == NULL) return NULL; if (pIter->direction == TD_LIST_FORWARD) { pIter->next = TD_DLIST_NODE_NEXT(node); } else { pIter->next = TD_DLIST_NODE_PREV(node); } return node; }