diff options
author | Markus Friedl <markus@cvs.openbsd.org> | 2002-09-03 18:40:19 +0000 |
---|---|---|
committer | Markus Friedl <markus@cvs.openbsd.org> | 2002-09-03 18:40:19 +0000 |
commit | dcad5d7dd03970f8f7e20a1e7e4c75216d4bbc3a (patch) | |
tree | 599bc2ff192de2c3f40cc8c55e170ddc4ecf5f82 /sbin/isakmpd/sysdep | |
parent | 2741f6d23d2d1f623eb69ff237144716ef814778 (diff) |
add strlcpy/cat for BSD/OS
Diffstat (limited to 'sbin/isakmpd/sysdep')
-rw-r--r-- | sbin/isakmpd/sysdep/common/libsysdep/GNUmakefile | 4 | ||||
-rw-r--r-- | sbin/isakmpd/sysdep/common/libsysdep/Makefile | 4 | ||||
-rw-r--r-- | sbin/isakmpd/sysdep/common/libsysdep/strlcat.c | 73 | ||||
-rw-r--r-- | sbin/isakmpd/sysdep/common/libsysdep/strlcpy.c | 69 |
4 files changed, 146 insertions, 4 deletions
diff --git a/sbin/isakmpd/sysdep/common/libsysdep/GNUmakefile b/sbin/isakmpd/sysdep/common/libsysdep/GNUmakefile index eb6a09a04ca..23df20d66a5 100644 --- a/sbin/isakmpd/sysdep/common/libsysdep/GNUmakefile +++ b/sbin/isakmpd/sysdep/common/libsysdep/GNUmakefile @@ -1,4 +1,4 @@ -# $OpenBSD: GNUmakefile,v 1.2 2001/01/28 22:38:47 niklas Exp $ +# $OpenBSD: GNUmakefile,v 1.3 2002/09/03 18:40:18 markus Exp $ # # Copyright (c) 1999 Niklas Hallqvist. All rights reserved. @@ -36,7 +36,7 @@ .CURDIR:= $(shell pwd) LIB= sysdep -SRCS= arc4random.c blowfish.c cast.c md5.c sha1.c +SRCS= arc4random.c blowfish.c cast.c md5.c sha1.c strlcat.c strlcpy.c NOMAN= CFLAGS+= -I${.CURDIR}/.. -I/usr/include/machine diff --git a/sbin/isakmpd/sysdep/common/libsysdep/Makefile b/sbin/isakmpd/sysdep/common/libsysdep/Makefile index 8a9eabd7a75..9f80a24ee2b 100644 --- a/sbin/isakmpd/sysdep/common/libsysdep/Makefile +++ b/sbin/isakmpd/sysdep/common/libsysdep/Makefile @@ -1,4 +1,4 @@ -# $OpenBSD: Makefile,v 1.2 2001/01/28 22:38:47 niklas Exp $ +# $OpenBSD: Makefile,v 1.3 2002/09/03 18:40:18 markus Exp $ # # Copyright (c) 1999 Niklas Hallqvist. All rights reserved. @@ -35,7 +35,7 @@ OPSYS!= uname -s LIB= sysdep -SRCS= arc4random.c blowfish.c cast.c md5.c sha1.c +SRCS= arc4random.c blowfish.c cast.c md5.c sha1.c strlcat.c strlcpy.c NOPROFILE= NOPIC= NOMAN= diff --git a/sbin/isakmpd/sysdep/common/libsysdep/strlcat.c b/sbin/isakmpd/sysdep/common/libsysdep/strlcat.c new file mode 100644 index 00000000000..37143be1dd7 --- /dev/null +++ b/sbin/isakmpd/sysdep/common/libsysdep/strlcat.c @@ -0,0 +1,73 @@ +/* $OpenBSD: strlcat.c,v 1.1 2002/09/03 18:40:18 markus Exp $ */ + +/* + * Copyright (c) 1998 Todd C. Miller <Todd.Miller@courtesan.com> + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. The name of the author may not be used to endorse or promote products + * derived from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, + * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY + * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL + * THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; + * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, + * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR + * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF + * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#if defined(LIBC_SCCS) && !defined(lint) +static char *rcsid = "$OpenBSD: strlcat.c,v 1.1 2002/09/03 18:40:18 markus Exp $"; +#endif /* LIBC_SCCS and not lint */ + +#include <sys/types.h> +#include <string.h> + +/* + * Appends src to string dst of size siz (unlike strncat, siz is the + * full size of dst, not space left). At most siz-1 characters + * will be copied. Always NUL terminates (unless siz <= strlen(dst)). + * Returns strlen(src) + MIN(siz, strlen(initial dst)). + * If retval >= siz, truncation occurred. + */ +size_t +strlcat(dst, src, siz) + char *dst; + const char *src; + size_t siz; +{ + register char *d = dst; + register const char *s = src; + register size_t n = siz; + size_t dlen; + + /* Find the end of dst and adjust bytes left but don't go past end */ + while (n-- != 0 && *d != '\0') + d++; + dlen = d - dst; + n = siz - dlen; + + if (n == 0) + return(dlen + strlen(s)); + while (*s != '\0') { + if (n != 1) { + *d++ = *s; + n--; + } + s++; + } + *d = '\0'; + + return(dlen + (s - src)); /* count does not include NUL */ +} diff --git a/sbin/isakmpd/sysdep/common/libsysdep/strlcpy.c b/sbin/isakmpd/sysdep/common/libsysdep/strlcpy.c new file mode 100644 index 00000000000..8ab5c1465d5 --- /dev/null +++ b/sbin/isakmpd/sysdep/common/libsysdep/strlcpy.c @@ -0,0 +1,69 @@ +/* $OpenBSD: strlcpy.c,v 1.1 2002/09/03 18:40:18 markus Exp $ */ + +/* + * Copyright (c) 1998 Todd C. Miller <Todd.Miller@courtesan.com> + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. The name of the author may not be used to endorse or promote products + * derived from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, + * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY + * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL + * THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; + * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, + * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR + * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF + * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#if defined(LIBC_SCCS) && !defined(lint) +static char *rcsid = "$OpenBSD: strlcpy.c,v 1.1 2002/09/03 18:40:18 markus Exp $"; +#endif /* LIBC_SCCS and not lint */ + +#include <sys/types.h> +#include <string.h> + +/* + * Copy src to string dst of size siz. At most siz-1 characters + * will be copied. Always NUL terminates (unless siz == 0). + * Returns strlen(src); if retval >= siz, truncation occurred. + */ +size_t +strlcpy(dst, src, siz) + char *dst; + const char *src; + size_t siz; +{ + register char *d = dst; + register const char *s = src; + register size_t n = siz; + + /* Copy as many bytes as will fit */ + if (n != 0 && --n != 0) { + do { + if ((*d++ = *s++) == 0) + break; + } while (--n != 0); + } + + /* Not enough room in dst, add NUL and traverse rest of src */ + if (n == 0) { + if (siz != 0) + *d = '\0'; /* NUL-terminate dst */ + while (*s++) + ; + } + + return(s - src - 1); /* count does not include NUL */ +} |