=================================================================== RCS file: /cvs/mandoc/Attic/xstd.c,v retrieving revision 1.2 retrieving revision 1.4 diff -u -p -r1.2 -r1.4 --- mandoc/Attic/xstd.c 2008/12/29 18:08:44 1.2 +++ mandoc/Attic/xstd.c 2009/01/20 13:44:05 1.4 @@ -1,4 +1,4 @@ -/* $Id: xstd.c,v 1.2 2008/12/29 18:08:44 kristaps Exp $ */ +/* $Id: xstd.c,v 1.4 2009/01/20 13:44:05 kristaps Exp $ */ /* * Copyright (c) 2008 Kristaps Dzonsons * @@ -16,18 +16,23 @@ * 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); #endif - int xstrcmp(const char *p1, const char *p2) { @@ -35,7 +40,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 +47,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,8 +54,6 @@ xstrlcpy(char *dst, const char *src, size_t sz) return(strlcpy(dst, src, sz) < sz); } - - void * xcalloc(size_t num, size_t sz) { @@ -63,7 +64,6 @@ xcalloc(size_t num, size_t sz) return(p); } - char * xstrdup(const char *p) { @@ -74,9 +74,29 @@ xstrdup(const char *p) return(pp); } +int +xstrlcats(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->data.text.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.4 2009/01/20 13:44:05 kristaps Exp $ */ /* * Copyright (c) 1998 Todd C. Miller @@ -125,7 +145,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)