]> Pileus Git - ~andy/fetchmail/blob - strlcat.c
Further cleanups to compile with C++ compiler.
[~andy/fetchmail] / strlcat.c
1 /*      $NetBSD: strlcat.c,v 1.16 2003/10/27 00:12:42 lukem Exp $       */
2 /*      $OpenBSD: strlcat.c,v 1.10 2003/04/12 21:56:39 millert Exp $    */
3
4 /*
5  * Copyright (c) 1998 Todd C. Miller <Todd.Miller@courtesan.com>
6  *
7  * Permission to use, copy, modify, and distribute this software for any
8  * purpose with or without fee is hereby granted, provided that the above
9  * copyright notice and this permission notice appear in all copies.
10  *
11  * THE SOFTWARE IS PROVIDED "AS IS" AND TODD C. MILLER DISCLAIMS ALL
12  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES
13  * OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL TODD C. MILLER BE LIABLE
14  * FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
16  * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
17  * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18  */
19
20 #include <sys/types.h>
21 #include <assert.h>
22 #include <string.h>
23
24 #ifndef HAVE_STRLCAT
25 /*
26  * Appends src to string dst of size siz (unlike strncat, siz is the
27  * full size of dst, not space left).  At most siz-1 characters
28  * will be copied.  Always NUL terminates (unless siz <= strlen(dst)).
29  * Returns strlen(src) + MIN(siz, strlen(initial dst)).
30  * If retval >= siz, truncation occurred.
31  */
32 size_t
33 strlcat(char *dst, const char *src, size_t siz)
34 {
35         char *d = dst;
36         const char *s = src;
37         size_t n = siz;
38         size_t dlen;
39
40         /* Find the end of dst and adjust bytes left but don't go past end */
41         while (n-- != 0 && *d != '\0')
42                 d++;
43         dlen = d - dst;
44         n = siz - dlen;
45
46         if (n == 0)
47                 return(dlen + strlen(s));
48         while (*s != '\0') {
49                 if (n != 1) {
50                         *d++ = *s;
51                         n--;
52                 }
53                 s++;
54         }
55         *d = '\0';
56
57         return(dlen + (s - src));       /* count does not include NUL */
58 }
59 #endif