From e15850ae972957d097eeadfd5721e3ac8f10fd4e Mon Sep 17 00:00:00 2001 From: Rob Landley Date: Mon, 19 Nov 2007 01:51:00 -0600 Subject: Replace strlcpy() with xstrcpy(), which exits if the string won't fit. --- lib/lib.c | 20 +++++--------------- lib/lib.h | 5 +---- 2 files changed, 6 insertions(+), 19 deletions(-) (limited to 'lib') diff --git a/lib/lib.c b/lib/lib.c index 4cbb2228..5d01efc9 100644 --- a/lib/lib.c +++ b/lib/lib.c @@ -11,22 +11,12 @@ #include "toys.h" -#if !defined(__UCLIBC__) && !defined(__KLIBC__) - -// uClibc has this, and if we define our own it conflicts. - -// Like strncpy but always null terminated. -void strlcpy(char *dest, char *src, size_t size) +// Strcpy with size checking: exit if there's not enough space for the string. +void xstrcpy(char *dest, char *src, size_t size) { - int len = strlen(src); - if (size--) { - if (len > size) len=size; - memcpy(dest,src, len); - dest[len] = 0; - } + if (strlen(src)+1 > size) error_exit("xstrcpy"); + strcpy(dest, src); } -#endif - void verror_msg(char *msg, int err, va_list va) { @@ -116,7 +106,7 @@ void *xrealloc(void *ptr, size_t size) void *xstrndup(char *s, size_t n) { void *ret = xmalloc(++n); - strlcpy(ret, s, n); + xstrcpy(ret, s, n); return ret; } diff --git a/lib/lib.h b/lib/lib.h index 07f4a6d8..67c6dac9 100644 --- a/lib/lib.h +++ b/lib/lib.h @@ -36,10 +36,7 @@ struct dirtree *dirtree_read(char *path, struct dirtree *parent, int (*callback)(struct dirtree *node)); // lib.c -#if !defined(__UCLIBC__) && !defined(__KLIBC__) -void strlcpy(char *dest, char *src, size_t size); -#endif - +void xstrcpy(char *dest, char *src, size_t size); void verror_msg(char *msg, int err, va_list va); void error_msg(char *msg, ...); void perror_msg(char *msg, ...); -- cgit v1.2.3