/* wmem_strbuf.h * Definitions for the Wireshark Memory Manager String Buffer * Copyright 2012, Evan Huus * * Wireshark - Network traffic analyzer * By Gerald Combs * Copyright 1998 Gerald Combs * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * 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. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #ifndef __WMEM_STRBUF_H__ #define __WMEM_STRBUF_H__ #include #include #include "wmem_core.h" #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ /** @addtogroup wmem * @{ * @defgroup wmem-strbuf String Buffer * * A string object implementation on top of wmem. * * @{ */ struct _wmem_strbuf_t; typedef struct _wmem_strbuf_t wmem_strbuf_t; WS_DLL_PUBLIC wmem_strbuf_t * wmem_strbuf_sized_new(wmem_allocator_t *allocator, gsize alloc_len, gsize max_len) G_GNUC_MALLOC; #define wmem_strbuf_new_label(ALLOCATOR) \ wmem_strbuf_sized_new((ALLOCATOR), 0, ITEM_LABEL_LENGTH) WS_DLL_PUBLIC wmem_strbuf_t * wmem_strbuf_new(wmem_allocator_t *allocator, const gchar *str) G_GNUC_MALLOC; WS_DLL_PUBLIC void wmem_strbuf_append(wmem_strbuf_t *strbuf, const gchar *str); WS_DLL_PUBLIC void wmem_strbuf_append_printf(wmem_strbuf_t *strbuf, const gchar *format, ...) G_GNUC_PRINTF(2, 3); WS_DLL_PUBLIC void wmem_strbuf_append_c(wmem_strbuf_t *strbuf, const gchar c); WS_DLL_PUBLIC void wmem_strbuf_append_unichar(wmem_strbuf_t *strbuf, const gunichar c); WS_DLL_PUBLIC void wmem_strbuf_truncate(wmem_strbuf_t *strbuf, const gsize len); WS_DLL_PUBLIC const gchar * wmem_strbuf_get_str(wmem_strbuf_t *strbuf); WS_DLL_PUBLIC gsize wmem_strbuf_get_len(wmem_strbuf_t *strbuf); /** Truncates the allocated memory down to the minimal amount, frees the header * structure, and returns a non-const pointer to the raw string. The * wmem_strbuf_t structure cannot be used after this is called. Basically a * destructor for when you still need the underlying C-string. */ WS_DLL_PUBLIC char * wmem_strbuf_finalize(wmem_strbuf_t *strbuf); /** @} * @} */ #ifdef __cplusplus } #endif /* __cplusplus */ #endif /* __WMEM_STRBUF_H__ */ /* * Editor modelines - http://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: */