=================================================================== RCS file: /cvs/mandoc/Attic/xstd.c,v retrieving revision 1.2 retrieving revision 1.9 diff -u -p -r1.2 -r1.9 --- mandoc/Attic/xstd.c 2008/12/29 18:08:44 1.2 +++ mandoc/Attic/xstd.c 2009/03/08 19:47:41 1.9 @@ -1,4 +1,4 @@ -/* $Id: xstd.c,v 1.2 2008/12/29 18:08:44 kristaps Exp $ */ +/* $Id: xstd.c,v 1.9 2009/03/08 19:47:41 kristaps Exp $ */ /* * Copyright (c) 2008 Kristaps Dzonsons * @@ -16,12 +16,18 @@ * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR * PERFORMANCE OF THIS SOFTWARE. */ +#include #include #include #include #include "private.h" +/* + * Contains wrappers for common functions to simplify their general + * usage throughout this codebase. + */ + #ifdef __linux__ extern size_t strlcat(char *, const char *, size_t); extern size_t strlcpy(char *, const char *, size_t); @@ -35,7 +41,6 @@ xstrcmp(const char *p1, const char *p2) return(0 == strcmp(p1, p2)); } - int xstrlcat(char *dst, const char *src, size_t sz) { @@ -43,7 +48,6 @@ xstrlcat(char *dst, const char *src, size_t sz) return(strlcat(dst, src, sz) < sz); } - int xstrlcpy(char *dst, const char *src, size_t sz) { @@ -51,7 +55,15 @@ xstrlcpy(char *dst, const char *src, size_t sz) return(strlcpy(dst, src, sz) < sz); } +void * +xrealloc(void *ptr, size_t sz) +{ + void *p; + if (NULL == (p = realloc(ptr, sz))) + err(EXIT_FAILURE, "realloc"); + return(p); +} void * xcalloc(size_t num, size_t sz) @@ -63,7 +75,6 @@ xcalloc(size_t num, size_t sz) return(p); } - char * xstrdup(const char *p) { @@ -74,9 +85,29 @@ xstrdup(const char *p) return(pp); } +int +xstrlcpys(char *buf, const struct mdoc_node *n, size_t sz) +{ + char *p; + assert(sz > 0); + assert(buf); + *buf = 0; + + for ( ; n; n = n->next) { + assert(MDOC_TEXT == n->type); + p = n->string; + if ( ! xstrlcat(buf, p, sz)) + return(0); + if (n->next && ! xstrlcat(buf, " ", sz)) + return(0); + } + + return(1); +} + #ifdef __linux__ -/* $OpenBSD: xstd.c,v 1.2 2008/12/29 18:08:44 kristaps Exp $ */ +/* $OpenBSD: xstd.c,v 1.9 2009/03/08 19:47:41 kristaps Exp $ */ /* * Copyright (c) 1998 Todd C. Miller @@ -125,7 +156,6 @@ strlcat(char *dst, const char *src, size_t siz) return(dlen + (s - src)); /* count does not include NUL */ } - size_t strlcpy(char *dst, const char *src, size_t siz)