Massively cleaned up #include's, so they're in a consistent
[freeradius.git] / src / lib / strlcat.c
1 /*
2  *  strlcat.c   Concatenate strings.
3  *
4  *  Version:    $Id$
5  *
6  */
7
8 /*
9  * Copyright (c) 1998 Todd C. Miller <Todd.Miller@courtesan.com>
10  *
11  * Permission to use, copy, modify, and distribute this software for any
12  * purpose with or without fee is hereby granted, provided that the above
13  * copyright notice and this permission notice appear in all copies.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
16  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
17  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
18  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
19  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
20  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
21  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
22  *
23  * Copyright 2006  The FreeRADIUS server project
24  */
25
26 #include <freeradius-devel/ident.h>
27 RCSID("$Id$")
28
29 #include <freeradius-devel/autoconf.h>
30
31 #ifndef HAVE_STRLCAT
32
33 #include <freeradius-devel/missing.h>
34
35 /*
36  * Appends src to string dst of size siz (unlike strncat, siz is the
37  * full size of dst, not space left).  At most siz-1 characters
38  * will be copied.  Always NUL terminates (unless siz <= strlen(dst)).
39  * Returns strlen(src) + MIN(siz, strlen(initial dst)).
40  * If retval >= siz, truncation occurred.
41  */
42 size_t
43 strlcat(char *dst, const char *src, size_t siz)
44 {
45         char *d = dst;
46         const char *s = src;
47         size_t n = siz;
48         size_t dlen;
49
50         /* Find the end of dst and adjust bytes left but don't go past end */
51         while (n-- != 0 && *d != '\0')
52                 d++;
53         dlen = d - dst;
54         n = siz - dlen;
55
56         if (n == 0)
57                 return(dlen + strlen(s));
58         while (*s != '\0') {
59                 if (n != 1) {
60                         *d++ = *s;
61                         n--;
62                 }
63                 s++;
64         }
65         *d = '\0';
66
67         return(dlen + (s - src));       /* count does not include NUL */
68 }
69
70 #endif