X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=string.h;h=febe1a025001c440d02c0de782788bddca1837a5;hp=a2dfa4229c3c619207aee5b2af37811802d59023;hb=9a4a139a9c57420e1bd4b96000985cbfa841782d;hpb=2cfb78331c33cb74c6abf357e8221604c3c9ec47;ds=inline diff --git a/string.h b/string.h index a2dfa422..febe1a02 100644 --- a/string.h +++ b/string.h @@ -6,9 +6,13 @@ /** \file string.h exported sybmols from string.c */ +/** A string buffer used for para_printf(). */ struct para_buffer { + /** The buffer. May be \p NULL. */ char *buf; + /** The size of \a buf. */ size_t size; + /** The next para_printf() will write at this offset. */ size_t offset; }; @@ -19,7 +23,7 @@ __must_check __malloc char *para_strdup(const char *s); __must_check __malloc __printf_1_2 char *make_message(const char *fmt, ...); __must_check __malloc char *para_strcat(char *a, const char *b); __must_check __malloc char *para_dirname(const char *name); -__must_check __malloc char *para_basename(const char *name); +__must_check const char *para_basename(const char *name); void chop(char* buf); __must_check __malloc char *para_tmpname(void); __must_check int para_mkstemp(char *template, mode_t mode); @@ -29,9 +33,11 @@ __must_check unsigned split_args(char *args, char *** const argv_ptr, const char __malloc char *para_hostname(void); void valid_fd_012(void); __printf_2_3 int para_printf(struct para_buffer *b, const char *fmt, ...); +/** Used for for_each_line() and for_each_line_ro(). */ typedef int line_handler_t(char *, void *); int for_each_line(char *buf, size_t size, line_handler_t *line_handler, void *private_data); -int for_each_line_ro(char *buf, size_t size, line_handler_t line_handler, +int for_each_line_ro(char *buf, size_t size, line_handler_t *line_handler, void *private_data); - +int para_atoi64(const char *str, int64_t *result); +int para_atoi32(const char *str, int32_t *value);