summaryrefslogtreecommitdiff
path: root/src/lib
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/libc/string/strlcat.c12
-rw-r--r--src/lib/libc/string/strlcpy.c10
-rw-r--r--src/lib/libc/string/strnlen.c9
3 files changed, 7 insertions, 24 deletions
diff --git a/src/lib/libc/string/strlcat.c b/src/lib/libc/string/strlcat.c
index 410f448b56..6bf2a41f79 100644
--- a/src/lib/libc/string/strlcat.c
+++ b/src/lib/libc/string/strlcat.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: strlcat.c,v 1.17 2016/10/14 18:19:04 dtucker Exp $ */ 1/* $OpenBSD: strlcat.c,v 1.18 2016/10/16 17:37:39 dtucker Exp $ */
2 2
3/* 3/*
4 * Copyright (c) 1998, 2015 Todd C. Miller <Todd.Miller@courtesan.com> 4 * Copyright (c) 1998, 2015 Todd C. Miller <Todd.Miller@courtesan.com>
@@ -18,7 +18,6 @@
18 18
19#include <sys/types.h> 19#include <sys/types.h>
20#include <string.h> 20#include <string.h>
21#include <stdint.h>
22 21
23/* 22/*
24 * Appends src to string dst of size dsize (unlike strncat, dsize is the 23 * Appends src to string dst of size dsize (unlike strncat, dsize is the
@@ -38,7 +37,7 @@ strlcat(char *dst, const char *src, size_t dsize)
38 /* Find the end of dst and adjust bytes left but don't go past end. */ 37 /* Find the end of dst and adjust bytes left but don't go past end. */
39 while (n-- != 0 && *dst != '\0') 38 while (n-- != 0 && *dst != '\0')
40 dst++; 39 dst++;
41 dlen = (uintptr_t)dst - (uintptr_t)odst; 40 dlen = dst - odst;
42 n = dsize - dlen; 41 n = dsize - dlen;
43 42
44 if (n-- == 0) 43 if (n-- == 0)
@@ -52,11 +51,6 @@ strlcat(char *dst, const char *src, size_t dsize)
52 } 51 }
53 *dst = '\0'; 52 *dst = '\0';
54 53
55 /* 54 return(dlen + (src - osrc)); /* count does not include NUL */
56 * Cast pointers to unsigned type before calculation, to avoid signed
57 * overflow when the string ends where the MSB has changed.
58 * Return value does not include NUL.
59 */
60 return (dlen + ((uintptr_t)src - (uintptr_t)osrc));
61} 55}
62DEF_WEAK(strlcat); 56DEF_WEAK(strlcat);
diff --git a/src/lib/libc/string/strlcpy.c b/src/lib/libc/string/strlcpy.c
index f282834680..367768928d 100644
--- a/src/lib/libc/string/strlcpy.c
+++ b/src/lib/libc/string/strlcpy.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: strlcpy.c,v 1.14 2016/10/14 18:19:04 dtucker Exp $ */ 1/* $OpenBSD: strlcpy.c,v 1.15 2016/10/16 17:37:39 dtucker Exp $ */
2 2
3/* 3/*
4 * Copyright (c) 1998, 2015 Todd C. Miller <Todd.Miller@courtesan.com> 4 * Copyright (c) 1998, 2015 Todd C. Miller <Todd.Miller@courtesan.com>
@@ -18,7 +18,6 @@
18 18
19#include <sys/types.h> 19#include <sys/types.h>
20#include <string.h> 20#include <string.h>
21#include <stdint.h>
22 21
23/* 22/*
24 * Copy string src to buffer dst of size dsize. At most dsize-1 23 * Copy string src to buffer dst of size dsize. At most dsize-1
@@ -47,11 +46,6 @@ strlcpy(char *dst, const char *src, size_t dsize)
47 ; 46 ;
48 } 47 }
49 48
50 /* 49 return(src - osrc - 1); /* count does not include NUL */
51 * Cast pointers to unsigned type before calculation, to avoid signed
52 * overflow when the string ends where the MSB has changed.
53 * Return value does not include NUL.
54 */
55 return((uintptr_t)src - (uintptr_t)osrc - 1);
56} 50}
57DEF_WEAK(strlcpy); 51DEF_WEAK(strlcpy);
diff --git a/src/lib/libc/string/strnlen.c b/src/lib/libc/string/strnlen.c
index 33c3b6e2ca..db809756ac 100644
--- a/src/lib/libc/string/strnlen.c
+++ b/src/lib/libc/string/strnlen.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: strnlen.c,v 1.7 2016/10/14 18:19:04 dtucker Exp $ */ 1/* $OpenBSD: strnlen.c,v 1.8 2016/10/16 17:37:39 dtucker Exp $ */
2 2
3/* 3/*
4 * Copyright (c) 2010 Todd C. Miller <Todd.Miller@courtesan.com> 4 * Copyright (c) 2010 Todd C. Miller <Todd.Miller@courtesan.com>
@@ -19,7 +19,6 @@
19#include <sys/types.h> 19#include <sys/types.h>
20 20
21#include <string.h> 21#include <string.h>
22#include <stdint.h>
23 22
24size_t 23size_t
25strnlen(const char *str, size_t maxlen) 24strnlen(const char *str, size_t maxlen)
@@ -29,10 +28,6 @@ strnlen(const char *str, size_t maxlen)
29 for (cp = str; maxlen != 0 && *cp != '\0'; cp++, maxlen--) 28 for (cp = str; maxlen != 0 && *cp != '\0'; cp++, maxlen--)
30 ; 29 ;
31 30
32 /* 31 return (size_t)(cp - str);
33 * Cast pointers to unsigned type before calculation, to avoid signed
34 * overflow when the string ends where the MSB has changed.
35 */
36 return (size_t)((uintptr_t)cp - (uintptr_t)str);
37} 32}
38DEF_WEAK(strnlen); 33DEF_WEAK(strnlen);