/** @file * Definitions for the Wireshark Memory Manager Doubly-Linked List * Copyright 2012, Evan Huus * * Wireshark - Network traffic analyzer * By Gerald Combs * Copyright 1998 Gerald Combs * * SPDX-License-Identifier: GPL-2.0-or-later */ #ifndef __WMEM_LIST_H__ #define __WMEM_LIST_H__ #include #include #include "wmem_core.h" #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ /** @addtogroup wmem * @{ * @defgroup wmem-list Doubly-Linked List * * A doubly-linked list implementation on top of wmem. * * @{ */ struct _wmem_list_t; struct _wmem_list_frame_t; typedef struct _wmem_list_t wmem_list_t; typedef struct _wmem_list_frame_t wmem_list_frame_t; WS_DLL_PUBLIC guint wmem_list_count(const wmem_list_t *list); WS_DLL_PUBLIC wmem_list_frame_t * wmem_list_head(const wmem_list_t *list); WS_DLL_PUBLIC wmem_list_frame_t * wmem_list_tail(const wmem_list_t *list); WS_DLL_PUBLIC wmem_list_frame_t * wmem_list_frame_next(const wmem_list_frame_t *frame); WS_DLL_PUBLIC wmem_list_frame_t * wmem_list_frame_prev(const wmem_list_frame_t *frame); WS_DLL_PUBLIC void * wmem_list_frame_data(const wmem_list_frame_t *frame); WS_DLL_PUBLIC void wmem_list_remove(wmem_list_t *list, void *data); WS_DLL_PUBLIC void wmem_list_remove_frame(wmem_list_t *list, wmem_list_frame_t *frame); /* * Linear search, search is O(n) */ WS_DLL_PUBLIC wmem_list_frame_t * wmem_list_find(wmem_list_t *list, const void *data); WS_DLL_PUBLIC wmem_list_frame_t * wmem_list_find_custom(wmem_list_t *list, const void *data, GCompareFunc func); WS_DLL_PUBLIC void wmem_list_prepend(wmem_list_t *list, void *data); WS_DLL_PUBLIC void wmem_list_append(wmem_list_t *list, void *data); WS_DLL_PUBLIC void wmem_list_insert_sorted(wmem_list_t *list, void* data, GCompareFunc func); WS_DLL_PUBLIC wmem_list_t * wmem_list_new(wmem_allocator_t *allocator) G_GNUC_MALLOC; WS_DLL_PUBLIC void wmem_list_foreach(wmem_list_t *list, GFunc foreach_func, gpointer user_data); WS_DLL_PUBLIC void wmem_destroy_list(wmem_list_t *list); /** @} * @} */ #ifdef __cplusplus } #endif /* __cplusplus */ #endif /* __WMEM_LIST_H__ */ /* * Editor modelines - https://www.wireshark.org/tools/modelines.html * * Local variables: * c-basic-offset: 4 * tab-width: 8 * indent-tabs-mode: nil * End: * * vi: set shiftwidth=4 tabstop=8 expandtab: * :indentSize=4:tabSize=8:noTabs=true: */