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: convert big macros to functions
details: https://anonhg.NetBSD.org/src/rev/7cf8e5ba1988
branches: trunk
changeset: 981352:7cf8e5ba1988
user: rillig <rillig%NetBSD.org@localhost>
date: Mon Mar 08 20:15:42 2021 +0000
description:
indent: convert big macros to functions
Each of these buffers is only modified in a single file. This makes it
unnecessary to declare the macros in the global header.
diffstat:
usr.bin/indent/indent.c | 60 ++++++++++++++++++++++++++++++++----------
usr.bin/indent/indent_globs.h | 54 +-------------------------------------
usr.bin/indent/lexi.c | 33 +++++++++++++++++------
usr.bin/indent/pr_comment.c | 36 ++++++++++++++++++++-----
4 files changed, 99 insertions(+), 84 deletions(-)
diffs (truncated from 426 to 300 lines):
diff -r 170d3afb1b22 -r 7cf8e5ba1988 usr.bin/indent/indent.c
--- a/usr.bin/indent/indent.c Mon Mar 08 20:12:04 2021 +0000
+++ b/usr.bin/indent/indent.c Mon Mar 08 20:15:42 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: indent.c,v 1.33 2021/03/08 19:06:48 rillig Exp $ */
+/* $NetBSD: indent.c,v 1.34 2021/03/08 20:15:42 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.33 2021/03/08 19:06:48 rillig Exp $");
+__RCSID("$NetBSD: indent.c,v 1.34 2021/03/08 20:15:42 rillig Exp $");
#elif defined(__FreeBSD__)
__FBSDID("$FreeBSD: head/usr.bin/indent/indent.c 340138 2018-11-04 19:24:49Z oshogbo $");
#endif
@@ -133,6 +133,36 @@
* files */
char bakfile[MAXPATHLEN] = "";
+static void
+check_size_code(size_t desired_size)
+{
+ if (e_code + (desired_size) >= l_code) {
+ int nsize = l_code - s_code + 400 + desired_size;
+ int code_len = e_code - s_code;
+ codebuf = (char *)realloc(codebuf, nsize);
+ if (codebuf == NULL)
+ err(1, NULL);
+ e_code = codebuf + code_len + 1;
+ l_code = codebuf + nsize - 5;
+ s_code = codebuf + 1;
+ }
+}
+
+static void
+check_size_label(size_t desired_size)
+{
+ if (e_lab + (desired_size) >= l_lab) {
+ int nsize = l_lab - s_lab + 400 + desired_size;
+ int label_len = e_lab - s_lab;
+ labbuf = (char *)realloc(labbuf, nsize);
+ if (labbuf == NULL)
+ err(1, NULL);
+ e_lab = labbuf + label_len + 1;
+ l_lab = labbuf + nsize - 5;
+ s_lab = labbuf + 1;
+ }
+}
+
int
main(int argc, char **argv)
{
@@ -584,7 +614,7 @@
* in a line. fix it */
int len = e_com - s_com;
- CHECK_SIZE_CODE(len + 3);
+ check_size_code(len + 3);
*e_code++ = ' ';
memcpy(e_code, s_com, len);
e_code += len;
@@ -603,8 +633,8 @@
/*-----------------------------------------------------*\
| do switch on type of token scanned |
\*-----------------------------------------------------*/
- CHECK_SIZE_CODE(3); /* maximum number of increments of e_code
- * before the next CHECK_SIZE_CODE or
+ check_size_code(3); /* maximum number of increments of e_code
+ * before the next check_size_code or
* dump_line() is 2. After that there's the
* final increment for the null character. */
switch (type_code) { /* now, decide what to do with the token */
@@ -720,7 +750,7 @@
{
int len = e_token - s_token;
- CHECK_SIZE_CODE(len);
+ check_size_code(len);
memcpy(e_code, token, len);
e_code += len;
}
@@ -731,7 +761,7 @@
{
int len = e_token - s_token;
- CHECK_SIZE_CODE(len + 1);
+ check_size_code(len + 1);
if (ps.want_blank)
*e_code++ = ' ';
memcpy(e_code, token, len);
@@ -782,7 +812,7 @@
{
int len = e_code - s_code;
- CHECK_SIZE_LAB(len + 3);
+ check_size_label(len + 3);
memcpy(e_lab, s_code, len);
e_lab += len;
*e_lab++ = ':';
@@ -1073,7 +1103,7 @@
{
int len = e_token - s_token;
- CHECK_SIZE_CODE(len + 1);
+ check_size_code(len + 1);
if (ps.want_blank)
*e_code++ = ' ';
memcpy(e_code, s_token, len);
@@ -1087,7 +1117,7 @@
{
int len = e_token - s_token;
- CHECK_SIZE_CODE(len + 1);
+ check_size_code(len + 1);
if (ps.want_blank)
*e_code++ = ' ';
memcpy(e_code, token, len);
@@ -1128,7 +1158,7 @@
(s_lab != e_lab) ||
(s_code != e_code))
dump_line();
- CHECK_SIZE_LAB(1);
+ check_size_label(1);
*e_lab++ = '#'; /* move whole line to 'label' buffer */
{
int in_comment = 0;
@@ -1142,7 +1172,7 @@
fill_buffer();
}
while (*buf_ptr != '\n' || (in_comment && !had_eof)) {
- CHECK_SIZE_LAB(2);
+ check_size_label(2);
*e_lab = *buf_ptr++;
if (buf_ptr >= buf_end)
fill_buffer();
@@ -1210,7 +1240,7 @@
buf_end = sc_end;
sc_end = NULL;
}
- CHECK_SIZE_LAB(1);
+ check_size_label(1);
*e_lab = '\0'; /* null terminate line */
ps.pcase = false;
}
@@ -1343,13 +1373,13 @@
if (tabs_to_var) {
int tpos;
- CHECK_SIZE_CODE(cur_dec_ind / opt.tabsize);
+ check_size_code(cur_dec_ind / opt.tabsize);
while ((tpos = opt.tabsize * (1 + pos / opt.tabsize)) <= cur_dec_ind) {
*e_code++ = '\t';
pos = tpos;
}
}
- CHECK_SIZE_CODE(cur_dec_ind - pos + 1);
+ check_size_code(cur_dec_ind - pos + 1);
while (pos < cur_dec_ind) {
*e_code++ = ' ';
pos++;
diff -r 170d3afb1b22 -r 7cf8e5ba1988 usr.bin/indent/indent_globs.h
--- a/usr.bin/indent/indent_globs.h Mon Mar 08 20:12:04 2021 +0000
+++ b/usr.bin/indent/indent_globs.h Mon Mar 08 20:15:42 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: indent_globs.h,v 1.15 2021/03/07 20:40:18 rillig Exp $ */
+/* $NetBSD: indent_globs.h,v 1.16 2021/03/08 20:15:42 rillig Exp $ */
/*-
* SPDX-License-Identifier: BSD-4-Clause
@@ -54,58 +54,6 @@
extern FILE *input; /* the fid for the input file */
extern FILE *output; /* the output file */
-#define CHECK_SIZE_CODE(desired_size) \
- if (e_code + (desired_size) >= l_code) { \
- int nsize = l_code-s_code + 400 + desired_size; \
- int code_len = e_code-s_code; \
- codebuf = (char *) realloc(codebuf, nsize); \
- if (codebuf == NULL) \
- err(1, NULL); \
- e_code = codebuf + code_len + 1; \
- l_code = codebuf + nsize - 5; \
- s_code = codebuf + 1; \
- }
-#define CHECK_SIZE_COM(desired_size) \
- if (e_com + (desired_size) >= l_com) { \
- int nsize = l_com-s_com + 400 + desired_size; \
- int com_len = e_com - s_com; \
- int blank_pos; \
- if (last_bl != NULL) \
- blank_pos = last_bl - combuf; \
- else \
- blank_pos = -1; \
- combuf = (char *) realloc(combuf, nsize); \
- if (combuf == NULL) \
- err(1, NULL); \
- e_com = combuf + com_len + 1; \
- if (blank_pos > 0) \
- last_bl = combuf + blank_pos; \
- l_com = combuf + nsize - 5; \
- s_com = combuf + 1; \
- }
-#define CHECK_SIZE_LAB(desired_size) \
- if (e_lab + (desired_size) >= l_lab) { \
- int nsize = l_lab-s_lab + 400 + desired_size; \
- int label_len = e_lab - s_lab; \
- labbuf = (char *) realloc(labbuf, nsize); \
- if (labbuf == NULL) \
- err(1, NULL); \
- e_lab = labbuf + label_len + 1; \
- l_lab = labbuf + nsize - 5; \
- s_lab = labbuf + 1; \
- }
-#define CHECK_SIZE_TOKEN(desired_size) \
- if (e_token + (desired_size) >= l_token) { \
- int nsize = l_token-s_token + 400 + desired_size; \
- int token_len = e_token - s_token; \
- tokenbuf = (char *) realloc(tokenbuf, nsize); \
- if (tokenbuf == NULL) \
- err(1, NULL); \
- e_token = tokenbuf + token_len + 1; \
- l_token = tokenbuf + nsize - 5; \
- s_token = tokenbuf + 1; \
- }
-
extern char *labbuf; /* buffer for label */
extern char *s_lab; /* start ... */
extern char *e_lab; /* .. and end of stored label */
diff -r 170d3afb1b22 -r 7cf8e5ba1988 usr.bin/indent/lexi.c
--- a/usr.bin/indent/lexi.c Mon Mar 08 20:12:04 2021 +0000
+++ b/usr.bin/indent/lexi.c Mon Mar 08 20:15:42 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lexi.c,v 1.24 2021/03/07 22:11:01 rillig Exp $ */
+/* $NetBSD: lexi.c,v 1.25 2021/03/08 20:15:42 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.24 2021/03/07 22:11:01 rillig Exp $");
+__RCSID("$NetBSD: lexi.c,v 1.25 2021/03/08 20:15:42 rillig Exp $");
#elif defined(__FreeBSD__)
__FBSDID("$FreeBSD: head/usr.bin/indent/lexi.c 337862 2018-08-15 18:19:45Z pstef $");
#endif
@@ -171,6 +171,21 @@
[0] = "uuiifuufiuuiiuiiiiiuiuuuuu",
};
+static void
+check_size_token(size_t desired_size)
+{
+ if (e_token + (desired_size) >= l_token) {
+ int nsize = l_token - s_token + 400 + desired_size;
+ int token_len = e_token - s_token;
+ tokenbuf = (char *)realloc(tokenbuf, nsize);
+ if (tokenbuf == NULL)
+ err(1, NULL);
+ e_token = tokenbuf + token_len + 1;
+ l_token = tokenbuf + nsize - 5;
+ s_token = tokenbuf + 1;
+ }
+}
+
static int
strcmp_type(const void *e1, const void *e2)
{
@@ -277,7 +292,7 @@
break;
}
s = table[i][s - 'A'];
- CHECK_SIZE_TOKEN(1);
+ check_size_token(1);
*e_token++ = *buf_ptr++;
if (buf_ptr >= buf_end)
fill_buffer();
@@ -297,7 +312,7 @@
} else
break;
}
- CHECK_SIZE_TOKEN(1);
+ check_size_token(1);
/* copy it over */
*e_token++ = *buf_ptr++;
if (buf_ptr >= buf_end)
@@ -420,7 +435,7 @@
/* Scan a non-alphanumeric token */
- CHECK_SIZE_TOKEN(3); /* things like "<<=" */
+ check_size_token(3); /* things like "<<=" */
*e_token++ = *buf_ptr; /* if it is only a one-character token, it is
* moved here */
*e_token = '\0';
@@ -448,7 +463,7 @@
diag(1, "Unterminated literal");
Home |
Main Index |
Thread Index |
Old Index