Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.bin/indent indent: add nonnull memory allocation functions
details: https://anonhg.NetBSD.org/src/rev/0aaed2e4178b
branches: trunk
changeset: 987370:0aaed2e4178b
user: rillig <rillig%NetBSD.org@localhost>
date: Sat Sep 25 08:23:31 2021 +0000
description:
indent: add nonnull memory allocation functions
The only functional change is a single error message.
diffstat:
usr.bin/indent/indent.c | 58 +++++++++++++++++++++++++++-----------------
usr.bin/indent/indent.h | 6 +++-
usr.bin/indent/io.c | 8 ++---
usr.bin/indent/lexi.c | 26 ++++++-------------
usr.bin/indent/pr_comment.c | 8 ++---
5 files changed, 54 insertions(+), 52 deletions(-)
diffs (254 lines):
diff -r b4c4db54e4d3 -r 0aaed2e4178b usr.bin/indent/indent.c
--- a/usr.bin/indent/indent.c Sat Sep 25 08:04:13 2021 +0000
+++ b/usr.bin/indent/indent.c Sat Sep 25 08:23:31 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: indent.c,v 1.67 2021/09/25 08:04:13 rillig Exp $ */
+/* $NetBSD: indent.c,v 1.68 2021/09/25 08:23:31 rillig Exp $ */
/*-
* SPDX-License-Identifier: BSD-4-Clause
@@ -46,7 +46,7 @@
#include <sys/cdefs.h>
#ifndef lint
#if defined(__NetBSD__)
-__RCSID("$NetBSD: indent.c,v 1.67 2021/09/25 08:04:13 rillig Exp $");
+__RCSID("$NetBSD: indent.c,v 1.68 2021/09/25 08:23:31 rillig Exp $");
#elif defined(__FreeBSD__)
__FBSDID("$FreeBSD: head/usr.bin/indent/indent.c 340138 2018-11-04 19:24:49Z oshogbo $");
#endif
@@ -126,9 +126,7 @@
size_t nsize = code.l - code.s + 400 + desired_size;
size_t code_len = code.e - code.s;
- code.buf = realloc(code.buf, nsize);
- if (code.buf == NULL)
- err(1, NULL);
+ code.buf = xrealloc(code.buf, nsize);
code.e = code.buf + code_len + 1;
code.l = code.buf + nsize - 5;
code.s = code.buf + 1;
@@ -142,9 +140,7 @@
size_t nsize = lab.l - lab.s + 400 + desired_size;
size_t label_len = lab.e - lab.s;
- lab.buf = realloc(lab.buf, nsize);
- if (lab.buf == NULL)
- err(1, NULL);
+ lab.buf = xrealloc(lab.buf, nsize);
lab.e = lab.buf + label_len + 1;
lab.l = lab.buf + nsize - 5;
lab.s = lab.buf + 1;
@@ -362,18 +358,10 @@
ps.last_nl = true; /* this is true if the last thing scanned was
* a newline */
ps.last_token = semicolon;
- com.buf = malloc(bufsize);
- if (com.buf == NULL)
- err(1, NULL);
- lab.buf = malloc(bufsize);
- if (lab.buf == NULL)
- err(1, NULL);
- code.buf = malloc(bufsize);
- if (code.buf == NULL)
- err(1, NULL);
- token.buf = malloc(bufsize);
- if (token.buf == NULL)
- err(1, NULL);
+ com.buf = xmalloc(bufsize);
+ lab.buf = xmalloc(bufsize);
+ code.buf = xmalloc(bufsize);
+ token.buf = xmalloc(bufsize);
alloc_typenames();
init_constant_tt();
com.l = com.buf + bufsize - 5;
@@ -389,9 +377,7 @@
com.s = com.e = com.buf + 1;
token.s = token.e = token.buf + 1;
- in_buffer = malloc(10);
- if (in_buffer == NULL)
- err(1, NULL);
+ in_buffer = xmalloc(10);
in_buffer_limit = in_buffer + 8;
buf_ptr = buf_end = in_buffer;
line_no = 1;
@@ -1571,3 +1557,29 @@
debug_printf("%s", suffix);
}
#endif
+
+static void *
+nonnull(void *p)
+{
+ if (p == NULL)
+ err(EXIT_FAILURE, NULL);
+ return p;
+}
+
+void *
+xmalloc(size_t size)
+{
+ return nonnull(malloc(size));
+}
+
+void *
+xrealloc(void *p, size_t new_size)
+{
+ return nonnull(realloc(p, new_size));
+}
+
+char *
+xstrdup(const char *s)
+{
+ return nonnull(strdup(s));
+}
diff -r b4c4db54e4d3 -r 0aaed2e4178b usr.bin/indent/indent.h
--- a/usr.bin/indent/indent.h Sat Sep 25 08:04:13 2021 +0000
+++ b/usr.bin/indent/indent.h Sat Sep 25 08:23:31 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: indent.h,v 1.16 2021/03/14 00:33:25 rillig Exp $ */
+/* $NetBSD: indent.h,v 1.17 2021/09/25 08:23:31 rillig Exp $ */
/*-
* SPDX-License-Identifier: BSD-2-Clause-FreeBSD
@@ -68,3 +68,7 @@
void set_defaults(void);
void set_option(char *);
void set_profile(const char *);
+
+void *xmalloc(size_t);
+void *xrealloc(void *, size_t);
+char *xstrdup(const char *);
diff -r b4c4db54e4d3 -r 0aaed2e4178b usr.bin/indent/io.c
--- a/usr.bin/indent/io.c Sat Sep 25 08:04:13 2021 +0000
+++ b/usr.bin/indent/io.c Sat Sep 25 08:23:31 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: io.c,v 1.56 2021/09/25 08:04:13 rillig Exp $ */
+/* $NetBSD: io.c,v 1.57 2021/09/25 08:23:31 rillig Exp $ */
/*-
* SPDX-License-Identifier: BSD-4-Clause
@@ -46,7 +46,7 @@
#include <sys/cdefs.h>
#ifndef lint
#if defined(__NetBSD__)
-__RCSID("$NetBSD: io.c,v 1.56 2021/09/25 08:04:13 rillig Exp $");
+__RCSID("$NetBSD: io.c,v 1.57 2021/09/25 08:23:31 rillig Exp $");
#elif defined(__FreeBSD__)
__FBSDID("$FreeBSD: head/usr.bin/indent/io.c 334927 2018-06-10 16:44:18Z pstef $");
#endif
@@ -413,9 +413,7 @@
if (p >= in_buffer_limit) {
size_t size = (in_buffer_limit - in_buffer) * 2 + 10;
size_t offset = p - in_buffer;
- in_buffer = realloc(in_buffer, size);
- if (in_buffer == NULL)
- errx(1, "input line too long");
+ in_buffer = xrealloc(in_buffer, size);
p = in_buffer + offset;
in_buffer_limit = in_buffer + size - 2;
}
diff -r b4c4db54e4d3 -r 0aaed2e4178b usr.bin/indent/lexi.c
--- a/usr.bin/indent/lexi.c Sat Sep 25 08:04:13 2021 +0000
+++ b/usr.bin/indent/lexi.c Sat Sep 25 08:23:31 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lexi.c,v 1.50 2021/09/25 08:04:13 rillig Exp $ */
+/* $NetBSD: lexi.c,v 1.51 2021/09/25 08:23:31 rillig Exp $ */
/*-
* SPDX-License-Identifier: BSD-4-Clause
@@ -46,7 +46,7 @@
#include <sys/cdefs.h>
#ifndef lint
#if defined(__NetBSD__)
-__RCSID("$NetBSD: lexi.c,v 1.50 2021/09/25 08:04:13 rillig Exp $");
+__RCSID("$NetBSD: lexi.c,v 1.51 2021/09/25 08:23:31 rillig Exp $");
#elif defined(__FreeBSD__)
__FBSDID("$FreeBSD: head/usr.bin/indent/lexi.c 337862 2018-08-15 18:19:45Z pstef $");
#endif
@@ -211,9 +211,7 @@
size_t nsize = token.l - token.s + 400 + desired_size;
size_t token_len = token.e - token.s;
- token.buf = realloc(token.buf, nsize);
- if (token.buf == NULL)
- err(1, NULL);
+ token.buf = xrealloc(token.buf, nsize);
token.e = token.buf + token_len + 1;
token.l = token.buf + nsize - 5;
token.s = token.buf + 1;
@@ -681,30 +679,25 @@
alloc_typenames(void)
{
- typenames = malloc(sizeof(typenames[0]) * (typename_count = 16));
- if (typenames == NULL)
- err(1, NULL);
+ typenames = xmalloc(sizeof(typenames[0]) * (typename_count = 16));
}
void
add_typename(const char *key)
{
int comparison;
- const char *copy;
if (typename_top + 1 >= typename_count) {
- typenames = realloc((void *)typenames,
+ typenames = xrealloc((void *)typenames,
sizeof(typenames[0]) * (typename_count *= 2));
- if (typenames == NULL)
- err(1, NULL);
}
if (typename_top == -1)
- typenames[++typename_top] = copy = strdup(key);
+ typenames[++typename_top] = xstrdup(key);
else if ((comparison = strcmp(key, typenames[typename_top])) >= 0) {
/* take advantage of sorted input */
if (comparison == 0) /* remove duplicates */
return;
- typenames[++typename_top] = copy = strdup(key);
+ typenames[++typename_top] = xstrdup(key);
} else {
int p;
@@ -714,9 +707,6 @@
return;
memmove(&typenames[p + 1], &typenames[p],
sizeof(typenames[0]) * (++typename_top - p));
- typenames[p] = copy = strdup(key);
+ typenames[p] = xstrdup(key);
}
-
- if (copy == NULL)
- err(1, NULL);
}
diff -r b4c4db54e4d3 -r 0aaed2e4178b usr.bin/indent/pr_comment.c
--- a/usr.bin/indent/pr_comment.c Sat Sep 25 08:04:13 2021 +0000
+++ b/usr.bin/indent/pr_comment.c Sat Sep 25 08:23:31 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pr_comment.c,v 1.39 2021/09/25 08:04:13 rillig Exp $ */
+/* $NetBSD: pr_comment.c,v 1.40 2021/09/25 08:23:31 rillig Exp $ */
/*-
* SPDX-License-Identifier: BSD-4-Clause
@@ -46,7 +46,7 @@
#include <sys/cdefs.h>
#ifndef lint
#if defined(__NetBSD__)
-__RCSID("$NetBSD: pr_comment.c,v 1.39 2021/09/25 08:04:13 rillig Exp $");
+__RCSID("$NetBSD: pr_comment.c,v 1.40 2021/09/25 08:23:31 rillig Exp $");
#elif defined(__FreeBSD__)
__FBSDID("$FreeBSD: head/usr.bin/indent/pr_comment.c 334927 2018-06-10 16:44:18Z pstef $");
#endif
@@ -67,9 +67,7 @@
size_t nsize = com.l - com.s + 400 + desired_size;
size_t com_len = com.e - com.s;
- com.buf = realloc(com.buf, nsize);
- if (com.buf == NULL)
- err(1, NULL);
+ com.buf = xrealloc(com.buf, nsize);
com.s = com.buf + 1;
com.e = com.s + com_len;
com.l = com.buf + nsize - 5;
Home |
Main Index |
Thread Index |
Old Index