On Tue, Sep 24, 2013 at 12:20 AM, Jorge Zapata <jorgeluis.zap...@gmail.com> wrote: > cedric pushed a commit to branch master. > > http://git.enlightenment.org/core/efl.git/commit/?id=b5fce696c743c50ea0a049c4f879756b5ed231d4 > > commit b5fce696c743c50ea0a049c4f879756b5ed231d4 > Author: Jorge Zapata <jorgeluis.zap...@gmail.com> > Date: Mon Sep 23 21:13:18 2013 +0200 > > eina: add functions to alloc strings from a printf fmt > --- > src/lib/eina/eina_str.c | 41 +++++++++++++++++++++++++++++++++++++++++ > src/lib/eina/eina_str.h | 33 +++++++++++++++++++++++++++++++++ > 2 files changed, 74 insertions(+) > > diff --git a/src/lib/eina/eina_str.c b/src/lib/eina/eina_str.c > index 11fef3c..283476b 100644 > --- a/src/lib/eina/eina_str.c > +++ b/src/lib/eina/eina_str.c > @@ -652,3 +652,44 @@ eina_str_toupper(char **str) > for (p = *str; (*p); p++) > *p = toupper((unsigned char)(*p)); > } > + > +EAPI size_t > +eina_str_vprintf_length(const char *format, va_list args) > +{ > + char c; > + size_t len; > + > + len = vsnprintf(&c, 1, format, args) + 1; > + return len;
this is wrong if 1) vsnprintf returns an error (for example if there's a wrong format string) 2) format is "" - return value value should be 0, but will be 1 If you change the return value to ssize_t it's better and simpler if you do: "return vsnprintf(NULL, 0, format, args);" If you prefer to ignore the error and continue with an unsigned type, then you should check the return value for < 0 before returning. > +} > + > +EAPI char * > +eina_str_vprintf_dup(const char *format, va_list args) > +{ > + size_t length; > + char *ret; > + va_list copy; > + > + /* be sure to use a copy or the printf implementation will > + * step into the args > + */ > + va_copy(copy, args); > + length = eina_str_vprintf_length(format, copy); > + va_end(copy); > + > + ret = calloc(length, sizeof(char)); malloc instead? you are replacing all the chars below > + vsprintf(ret, format, args); > + return ret; > +} > + > +EAPI char * > +eina_str_printf_dup(const char *format, ...) > +{ > + char *ret; > + va_list args; > + > + va_start(args, format); > + ret = eina_str_vprintf_dup(format, args); > + va_end(args); > + return ret; > +} why these instead of plain (v)asprintf? Lucas De Marchi ------------------------------------------------------------------------------ October Webinars: Code for Performance Free Intel webinars can help you accelerate application performance. Explore tips for MPI, OpenMP, advanced profiling, and more. Get the most from the latest Intel processors and coprocessors. See abstracts and register > http://pubads.g.doubleclick.net/gampad/clk?id=60133471&iu=/4140/ostg.clktrk _______________________________________________ enlightenment-devel mailing list enlightenment-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/enlightenment-devel