shithub: rgbds

Download patch

ref: c6187be210fabe0b377d57c9ce8dd19e18551160
parent: f9f3bb77618267d94cc2e5102c35e9d036cfcde0
author: Antonio Niño Díaz <[email protected]>
date: Fri Jan 26 19:02:44 EST 2018

Remove dependency of strlcpy()

There was only one place where `strlcpy` was still used.

Signed-off-by: Antonio Niño Díaz <[email protected]>

--- a/LICENSE.rst
+++ b/LICENSE.rst
@@ -26,6 +26,3 @@
 
 extern/reallocarray.c is derived from the OpenBSD Project,
 http://www.openbsd.org, and is released under the ISC license.
-
-extern/strlcpy.c is derived from the OpenBSD Project, http://www.openbsd.org,
-and is released under the BSD license.
--- a/Makefile
+++ b/Makefile
@@ -58,7 +58,6 @@
 	src/asm/symbol.o \
 	src/extern/err.o \
 	src/extern/reallocarray.o \
-	src/extern/strlcpy.o \
 	src/extern/utf8decoder.o \
 	src/extern/version.o
 
--- a/include/extern/strl.h
+++ /dev/null
@@ -1,23 +1,0 @@
-/*
- * This file is part of RGBDS.
- *
- * Copyright (c) 2015-2018, RGBDS contributors.
- *
- * SPDX-License-Identifier: MIT
- */
-
-#ifndef EXTERN_STRL_H
-#define EXTERN_STRL_H
-
-#ifdef STRL_IN_LIBC
-
-#include <string.h>
-
-#else /* STRL_IN_LIBC */
-
-#define strlcpy rgbds_strlcpy
-size_t strlcpy(char *dst, const char *src, size_t dsize);
-
-#endif /* STRL_IN_LIBC */
-
-#endif /* EXTERN_STRL_H */
--- a/src/asm/fstack.c
+++ b/src/asm/fstack.c
@@ -24,7 +24,6 @@
 #include "asm/symbol.h"
 
 #include "extern/err.h"
-#include "extern/strl.h"
 
 #include "types.h"
 
@@ -226,8 +225,12 @@
 	if (NextIncPath == MAXINCPATHS)
 		fatalerror("Too many include directories passed from command line");
 
-	if (strlcpy(IncludePaths[NextIncPath++], s, _MAX_PATH) >= _MAX_PATH)
+	if (strlen(s) >= sizeof(IncludePaths[0]))
 		fatalerror("Include path too long '%s'", s);
+
+	strncpy(IncludePaths[NextIncPath], s, sizeof(IncludePaths[0]));
+
+	NextIncPath++;
 }
 
 FILE *fstk_FindFile(char *fname)
--- a/src/extern/strlcpy.c
+++ /dev/null
@@ -1,52 +1,0 @@
-/* $OpenBSD: strlcpy.c,v 1.12 2015/01/15 03:54:12 millert Exp $ */
-
-/*
- * Copyright (c) 1998, 2015 Todd C. Miller <[email protected]>
- *
- * Permission to use, copy, modify, and distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
- * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
- * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
-
-#include <string.h>
-#include <sys/types.h>
-
-/*
- * Copy string src to buffer dst of size dsize.  At most dsize-1
- * chars will be copied.  Always NUL terminates (unless dsize == 0).
- * Returns strlen(src); if retval >= dsize, truncation occurred.
- */
-size_t rgbds_strlcpy(char *dst, const char *src, size_t dsize)
-{
-	const char *osrc = src;
-	size_t nleft = dsize;
-
-	/* Copy as many bytes as will fit. */
-	if (nleft != 0) {
-		while (--nleft != 0) {
-			char n = *src++;
-			*dst++ = n;
-
-			if (n == '\0')
-				break;
-		}
-	}
-
-	/* Not enough room in dst, add NUL and traverse rest of src. */
-	if (nleft == 0) {
-		if (dsize != 0)
-			*dst = '\0'; /* NUL-terminate dst */
-		while (*src++)
-			;
-	}
-
-	return (src - osrc - 1); /* count does not include NUL */
-}