X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/3a9be3b03e764af6a69418124a4e213713b2fd6d..ab1a94e98438ed2d29533aca9e613d667237c3d0:/include/xbt/strbuff.h diff --git a/include/xbt/strbuff.h b/include/xbt/strbuff.h index 1666655730..585d719d09 100644 --- a/include/xbt/strbuff.h +++ b/include/xbt/strbuff.h @@ -1,8 +1,6 @@ -/* $Id: buff.h 3483 2007-05-07 11:18:56Z mquinson $ */ - /* strbuff -- string buffers */ -/* Copyright (c) 2007, 2008, 2009, 2010. The SimGrid Team. +/* Copyright (c) 2007-2011, 2013-2014. The SimGrid Team. * All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it @@ -17,24 +15,38 @@ #include "xbt/str.h" #include "xbt/dict.h" -/** - ** Buffer code - **/ -typedef struct { +SG_BEGIN_DECL() + +/** @defgroup xbt_strbuff String buffers + * @ingroup XBT_adt + * + * This data container is very similar to the Java StringBuffer: + * that's a string to which you can add content with a lesser performance + * penalty than if you recreate a new string from scratch. Once done building + * your string, you must retrieve the content and free its container. + * + * @{ + */ + +/** @brief Buffer data container **/ +struct xbt_strbuff { char *data; int used, size; -} s_xbt_strbuff_t, *xbt_strbuff_t; - +}; +typedef struct xbt_strbuff s_xbt_strbuff_t; +typedef struct xbt_strbuff* xbt_strbuff_t; -XBT_PUBLIC(void) xbt_strbuff_empty(xbt_strbuff_t b); +XBT_PUBLIC(void) xbt_strbuff_clear(xbt_strbuff_t b); XBT_PUBLIC(xbt_strbuff_t) xbt_strbuff_new(void); -XBT_PUBLIC(xbt_strbuff_t) xbt_strbuff_new_from(char *s); +XBT_PUBLIC(xbt_strbuff_t) xbt_strbuff_new_from(const char *s); XBT_PUBLIC(void) xbt_strbuff_free(xbt_strbuff_t b); XBT_PUBLIC(void) xbt_strbuff_free_container(xbt_strbuff_t b); XBT_PUBLIC(void) xbt_strbuff_append(xbt_strbuff_t b, const char *toadd); +XBT_PUBLIC(void) xbt_strbuff_printf(xbt_strbuff_t b, const char *fmt, ...); XBT_PUBLIC(void) xbt_strbuff_chomp(xbt_strbuff_t b); XBT_PUBLIC(void) xbt_strbuff_trim(xbt_strbuff_t b); -XBT_PUBLIC(void) xbt_strbuff_varsubst(xbt_strbuff_t b, - xbt_dict_t patterns); +XBT_PUBLIC(void) xbt_strbuff_varsubst(xbt_strbuff_t b, xbt_dict_t patterns); +/** @} */ +SG_END_DECL() #endif