2 * zebra string function
4 * XXX This version of snprintf does not check bounds!
8 The implementations of strlcpy and strlcat are copied from rsync (GPL):
9 Copyright (C) Andrew Tridgell 1998
10 Copyright (C) 2002 by Martin Pool
12 Note that these are not terribly efficient, since they make more than one
13 pass over the argument strings. At some point, they should be optimized.
15 The implementation of strndup is copied from glibc-2.3.5:
16 Copyright (C) 1996, 1997, 1998, 2001, 2002 Free Software Foundation, Inc.
24 * snprint() is a real basic wrapper around the standard sprintf()
25 * without any bounds checking
28 snprintf(char *str
, size_t size
, const char *format
, ...)
32 va_start (args
, format
);
34 return vsprintf (str
, format
, args
);
40 * Like strncpy but does not 0 fill the buffer and always null
43 * @param bufsize is the size of the destination buffer.
45 * @return index of the terminating byte.
48 strlcpy(char *d
, const char *s
, size_t bufsize
)
50 size_t len
= strlen(s
);
64 * Like strncat() but does not 0 fill the buffer and always null
67 * @param bufsize length of the buffer, which should be one more than
68 * the maximum resulting string length.
71 strlcat(char *d
, const char *s
, size_t bufsize
)
73 size_t len1
= strlen(d
);
74 size_t len2
= strlen(s
);
75 size_t ret
= len1
+ len2
;
77 if (len1
< bufsize
- 1) {
78 if (len2
>= bufsize
- len1
)
79 len2
= bufsize
- len1
- 1;
80 memcpy(d
+len1
, s
, len2
);
89 strnlen(const char *s
, size_t maxlen
)
92 return (p
= (const char *)memchr(s
, '\0', maxlen
)) ? (size_t)(p
-s
) : maxlen
;
98 strndup (const char *s
, size_t maxlen
)
100 size_t len
= strnlen (s
, maxlen
);
101 char *new = (char *) malloc (len
+ 1);
107 return (char *) memcpy (new, s
, len
);