Bring in reallocarray() from OpenBSD
authorsin <sin@2f30.org>
Wed, 6 Jan 2016 17:02:28 +0000 (17:02 +0000)
committersin <sin@2f30.org>
Wed, 6 Jan 2016 17:03:42 +0000 (17:03 +0000)
Makefile
compat.h
config.mk
reallocarray.c [new file with mode: 0644]
strlcat.c
strlcpy.c

index eff0f5a3d0a702353168b6aa9110bf58b5d62ddd..7d6454a739632a7a239a1d7c71d94db6f61dc196 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -6,6 +6,7 @@ SRC = \
        stagit.c\
        stagit-index.c
 COMPATSRC = \
+       reallocarray.c\
        strlcat.c\
        strlcpy.c
 BIN = \
index 0947de62a4defa146048684794247b187c089901..f619c16e1f54a20f999711e52f3394254b133c49 100644 (file)
--- a/compat.h
+++ b/compat.h
@@ -3,4 +3,6 @@
 size_t strlcat(char *, const char *, size_t);
 #undef strlcpy
 size_t strlcpy(char *, const char *, size_t);
+#undef reallocarray
+void *reallocarray(void *, size_t, size_t);
 #endif
index 934db3b3d0ac244b36e9cde0d186b1fd30e108c4..6e84946c8d0bba14ad28a580e1133143b009b4d7 100644 (file)
--- a/config.mk
+++ b/config.mk
@@ -28,8 +28,8 @@ LDFLAGS = ${LIBS}
 
 # uncomment for compat
 CFLAGS += -DCOMPAT
-# uncomment if your libc doesn't support strlcat, strlcpy.
-COMPATOBJ = strlcat.o strlcpy.o
+# uncomment if your libc doesn't support reallocarray, strlcat, strlcpy.
+COMPATOBJ = reallocarray.o strlcat.o strlcpy.o
 
 # compiler and linker
 #CC = cc
diff --git a/reallocarray.c b/reallocarray.c
new file mode 100644 (file)
index 0000000..b92dae5
--- /dev/null
@@ -0,0 +1,39 @@
+/*
+ * Copyright (c) 2008 Otto Moerbeek <otto@drijf.net>
+ *
+ * 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 <sys/types.h>
+#include <errno.h>
+#include <stdint.h>
+#include <stdlib.h>
+
+#include "compat.h"
+
+/*
+ * This is sqrt(SIZE_MAX+1), as s1*s2 <= SIZE_MAX
+ * if both s1 < MUL_NO_OVERFLOW and s2 < MUL_NO_OVERFLOW
+ */
+#define MUL_NO_OVERFLOW        (1UL << (sizeof(size_t) * 4))
+
+void *
+reallocarray(void *optr, size_t nmemb, size_t size)
+{
+       if ((nmemb >= MUL_NO_OVERFLOW || size >= MUL_NO_OVERFLOW) &&
+           nmemb > 0 && SIZE_MAX / nmemb < size) {
+               errno = ENOMEM;
+               return NULL;
+       }
+       return realloc(optr, size * nmemb);
+}
index 14c53a1f69c2fd43b66f504b6682383f5542a86d..bbfa64f6d0428528f21ca193a663d59fcc7bf437 100644 (file)
--- a/strlcat.c
+++ b/strlcat.c
@@ -19,6 +19,8 @@
 #include <sys/types.h>
 #include <string.h>
 
+#include "compat.h"
+
 /*
  * Appends src to string dst of size dsize (unlike strncat, dsize is the
  * full size of dst, not space left).  At most dsize-1 characters
index e9a7fe4be7359d0d4226952e174ff64eb4d52b18..ab420b6e3b65e1099b0ab10ebb268510245850a7 100644 (file)
--- a/strlcpy.c
+++ b/strlcpy.c
@@ -19,6 +19,8 @@
 #include <sys/types.h>
 #include <string.h>
 
+#include "compat.h"
+
 /*
  * Copy string src to buffer dst of size dsize.  At most dsize-1
  * chars will be copied.  Always NUL terminates (unless dsize == 0).