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 +++++--------------- 1 file changed, 5 insertions(+), 15 deletions(-) (limited to 'lib/lib.c') 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; } -- cgit v1.2.3