summaryrefslogtreecommitdiff
path: root/nasmlib/alloc.c
diff options
context:
space:
mode:
authorH. Peter Anvin (Intel) <hpa@zytor.com>2018-12-12 14:34:34 -0800
committerH. Peter Anvin (Intel) <hpa@zytor.com>2018-12-12 14:34:34 -0800
commiteb5b3ae0d3383cef2651ae642ad297bc1dc6f228 (patch)
treec16780b9a0ef1bf47009c452733dba699cd94c38 /nasmlib/alloc.c
parent64471097ca7598e8238f9e5ed25b3afaa9b10f2c (diff)
downloadnasm-eb5b3ae0d3383cef2651ae642ad297bc1dc6f228.tar.gz
nasmlib: Add nasm_(v)asprintf()
Add a version of (v)asprintf(), which allocates a string on the heap. Unlike the standard version of (v)asprintf(), we return the pointer; if one wants the length of the string then one can simply use the %n pattern. Signed-off-by: H. Peter Anvin (Intel) <hpa@zytor.com>
Diffstat (limited to 'nasmlib/alloc.c')
-rw-r--r--nasmlib/alloc.c154
1 files changed, 154 insertions, 0 deletions
diff --git a/nasmlib/alloc.c b/nasmlib/alloc.c
new file mode 100644
index 00000000..2f3f9519
--- /dev/null
+++ b/nasmlib/alloc.c
@@ -0,0 +1,154 @@
+/* ----------------------------------------------------------------------- *
+ *
+ * Copyright 1996-2018 The NASM Authors - All Rights Reserved
+ * See the file AUTHORS included with the NASM distribution for
+ * the specific copyright holders.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following
+ * conditions are met:
+ *
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
+ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
+ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
+ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ * ----------------------------------------------------------------------- */
+
+/*
+ * nasmlib.c library routines for the Netwide Assembler
+ */
+
+#include "compiler.h"
+#include "nasmlib.h"
+#include "error.h"
+#include "alloc.h"
+
+no_return nasm_alloc_failed(void)
+{
+ nasm_fatal("out of memory");
+}
+
+void *nasm_malloc(size_t size)
+{
+ return validate_ptr(malloc(size));
+}
+
+void *nasm_calloc(size_t size, size_t nelem)
+{
+ return validate_ptr(calloc(size, nelem));
+}
+
+void *nasm_zalloc(size_t size)
+{
+ return validate_ptr(calloc(1, size));
+}
+
+void *nasm_realloc(void *q, size_t size)
+{
+ return validate_ptr(q ? realloc(q, size) : malloc(size));
+}
+
+void nasm_free(void *q)
+{
+ if (q)
+ free(q);
+}
+
+char *nasm_strdup(const char *s)
+{
+ char *p;
+ size_t size = strlen(s) + 1;
+
+ p = nasm_malloc(size);
+ return memcpy(p, s, size);
+}
+
+char *nasm_strndup(const char *s, size_t len)
+{
+ char *p;
+
+ len = strnlen(s, len);
+ p = nasm_malloc(len+1);
+ p[len] = '\0';
+ return memcpy(p, s, len);
+}
+
+char *nasm_strcat(const char *one, const char *two)
+{
+ char *rslt;
+ size_t l1 = strlen(one);
+ size_t l2 = strlen(two);
+ rslt = nasm_malloc(l1 + l2 + 1);
+ memcpy(rslt, one, l1);
+ memcpy(rslt + l1, two, l2+1);
+ return rslt;
+}
+
+char *nasm_strcatn(const char *str1, ...)
+{
+ va_list ap;
+ char *rslt; /* Output buffer */
+ size_t s; /* Total buffer size */
+ size_t n; /* Number of arguments */
+ size_t *ltbl; /* Table of lengths */
+ size_t l, *lp; /* Length for current argument */
+ const char *p; /* Currently examined argument */
+ char *q; /* Output pointer */
+
+ n = 0; /* No strings encountered yet */
+ p = str1;
+ va_start(ap, str1);
+ while (p) {
+ n++;
+ p = va_arg(ap, const char *);
+ }
+ va_end(ap);
+
+ ltbl = nasm_malloc(n * sizeof(size_t));
+
+ s = 1; /* Space for final NULL */
+ p = str1;
+ lp = ltbl;
+ va_start(ap, str1);
+ while (p) {
+ *lp++ = l = strlen(p);
+ s += l;
+ p = va_arg(ap, const char *);
+ }
+ va_end(ap);
+
+ q = rslt = nasm_malloc(s);
+
+ p = str1;
+ lp = ltbl;
+ va_start(ap, str1);
+ while (p) {
+ l = *lp++;
+ memcpy(q, p, l);
+ q += l;
+ p = va_arg(ap, const char *);
+ }
+ va_end(ap);
+ *q = '\0';
+
+ nasm_free(ltbl);
+
+ return rslt;
+}