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: use named constants for the different...
details: https://anonhg.NetBSD.org/src/rev/444ea650276a
branches: trunk
changeset: 981319:444ea650276a
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Mar 07 20:30:48 2021 +0000
description:
indent: use named constants for the different types of keywords
This reduces the magic numbers in the code. Most of these had their
designated constant name written in a nearby comment anyway.
The one instance where arithmetic was performed on this new enum type
(in indent.c) was a bit tricky to understand.
The combination rw_continue_or_inline_or_restrict looks strange, the
'continue' should intuitively belong to the other control flow keywords
in rw_break_or_goto_or_return.
No functional change.
diffstat:
usr.bin/indent/indent.c | 12 +--
usr.bin/indent/indent_codes.h | 14 ++--
usr.bin/indent/indent_globs.h | 21 ++++++-
usr.bin/indent/lexi.c | 118 ++++++++++++++++++++---------------------
4 files changed, 89 insertions(+), 76 deletions(-)
diffs (truncated from 305 to 300 lines):
diff -r d738c260ce21 -r 444ea650276a usr.bin/indent/indent.c
--- a/usr.bin/indent/indent.c Sun Mar 07 20:06:48 2021 +0000
+++ b/usr.bin/indent/indent.c Sun Mar 07 20:30:48 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: indent.c,v 1.30 2021/03/07 10:56:18 rillig Exp $ */
+/* $NetBSD: indent.c,v 1.31 2021/03/07 20:30:48 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.30 2021/03/07 10:56:18 rillig Exp $");
+__RCSID("$NetBSD: indent.c,v 1.31 2021/03/07 20:30:48 rillig Exp $");
#elif defined(__FreeBSD__)
__FBSDID("$FreeBSD: head/usr.bin/indent/indent.c 340138 2018-11-04 19:24:49Z oshogbo $");
#endif
@@ -642,10 +642,8 @@
else if (ps.want_blank &&
((ps.last_token != ident && ps.last_token != funcname) ||
opt.proc_calls_space ||
- /* offsetof (1) is never allowed a space; sizeof (2) gets
- * one iff -bs; all other keywords (>2) always get a space
- * before lparen */
- ps.keyword + opt.Bill_Shannon > 2))
+ (ps.keyword == rw_sizeof ? opt.Bill_Shannon :
+ ps.keyword != rw_0 && ps.keyword != rw_offsetof)))
*e_code++ = ' ';
ps.want_blank = false;
*e_code++ = token[0];
@@ -664,7 +662,7 @@
* initialization */
}
/* parenthesized type following sizeof or offsetof is not a cast */
- if (ps.keyword == 1 || ps.keyword == 2)
+ if (ps.keyword == rw_offsetof || ps.keyword == rw_sizeof)
ps.not_cast_mask |= 1 << ps.p_l_follow;
break;
diff -r d738c260ce21 -r 444ea650276a usr.bin/indent/indent_codes.h
--- a/usr.bin/indent/indent_codes.h Sun Mar 07 20:06:48 2021 +0000
+++ b/usr.bin/indent/indent_codes.h Sun Mar 07 20:30:48 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: indent_codes.h,v 1.7 2021/03/07 10:56:18 rillig Exp $ */
+/* $NetBSD: indent_codes.h,v 1.8 2021/03/07 20:30:48 rillig Exp $ */
/*-
* SPDX-License-Identifier: BSD-4-Clause
@@ -43,12 +43,12 @@
typedef enum token_type {
end_of_file,
newline,
- lparen,
- rparen,
- unary_op,
- binary_op,
- postop,
- question,
+ lparen, /* '(' or '[' */
+ rparen, /* ')' or ']' */
+ unary_op, /* e.g. '+' or '&' */
+ binary_op, /* e.g. '<<' or '+' or '&&' or '/=' */
+ postop, /* trailing '++' or '--' */
+ question, /* the '?' from a '?:' expression */
casestmt,
colon,
semicolon,
diff -r d738c260ce21 -r 444ea650276a usr.bin/indent/indent_globs.h
--- a/usr.bin/indent/indent_globs.h Sun Mar 07 20:06:48 2021 +0000
+++ b/usr.bin/indent/indent_globs.h Sun Mar 07 20:30:48 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: indent_globs.h,v 1.13 2021/03/07 10:56:18 rillig Exp $ */
+/* $NetBSD: indent_globs.h,v 1.14 2021/03/07 20:30:48 rillig Exp $ */
/*-
* SPDX-License-Identifier: BSD-4-Clause
@@ -221,6 +221,23 @@
* are printed */
} opt;
+enum rwcode {
+ rw_0,
+ rw_offsetof,
+ rw_sizeof,
+ rw_struct_or_union_or_enum,
+ rw_type,
+ rw_for_or_if_or_while,
+ rw_do_or_else,
+ rw_switch,
+ rw_case_or_default,
+ rw_break_or_goto_or_return,
+ rw_storage_class,
+ rw_typedef,
+ rw_continue_or_inline_or_restrict
+};
+
+
extern int found_err;
extern int n_real_blanklines;
extern int prefix_blankline_requested;
@@ -308,7 +325,7 @@
int want_blank; /* set to true when the following token should
* be prefixed by a blank. (Said prefixing is
* ignored in some cases.) */
- int keyword; /* the type of a keyword or 0 */
+ enum rwcode keyword; /* the type of a keyword or 0 */
int dumped_decl_indent;
int in_parameter_declaration;
int tos; /* pointer to top of stack */
diff -r d738c260ce21 -r 444ea650276a usr.bin/indent/lexi.c
--- a/usr.bin/indent/lexi.c Sun Mar 07 20:06:48 2021 +0000
+++ b/usr.bin/indent/lexi.c Sun Mar 07 20:30:48 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: lexi.c,v 1.20 2021/03/07 11:32:05 rillig Exp $ */
+/* $NetBSD: lexi.c,v 1.21 2021/03/07 20:30:48 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.20 2021/03/07 11:32:05 rillig Exp $");
+__RCSID("$NetBSD: lexi.c,v 1.21 2021/03/07 20:30:48 rillig Exp $");
#elif defined(__FreeBSD__)
__FBSDID("$FreeBSD: head/usr.bin/indent/lexi.c 337862 2018-08-15 18:19:45Z pstef $");
#endif
@@ -70,7 +70,7 @@
struct templ {
const char *rwd;
- int rwcode;
+ enum rwcode rwcode;
};
/*
@@ -79,48 +79,48 @@
*/
struct templ specials[] =
{
- {"_Bool", 4},
- {"_Complex", 4},
- {"_Imaginary", 4},
- {"auto", 10},
- {"bool", 4},
- {"break", 9},
- {"case", 8},
- {"char", 4},
- {"complex", 4},
- {"const", 4},
- {"continue", 12},
- {"default", 8},
- {"do", 6},
- {"double", 4},
- {"else", 6},
- {"enum", 3},
- {"extern", 10},
- {"float", 4},
- {"for", 5},
- {"global", 4},
- {"goto", 9},
- {"if", 5},
- {"imaginary", 4},
- {"inline", 12},
- {"int", 4},
- {"long", 4},
- {"offsetof", 1},
- {"register", 10},
- {"restrict", 12},
- {"return", 9},
- {"short", 4},
- {"signed", 4},
- {"sizeof", 2},
- {"static", 10},
- {"struct", 3},
- {"switch", 7},
- {"typedef", 11},
- {"union", 3},
- {"unsigned", 4},
- {"void", 4},
- {"volatile", 4},
- {"while", 5}
+ {"_Bool", rw_type},
+ {"_Complex", rw_type},
+ {"_Imaginary", rw_type},
+ {"auto", rw_storage_class},
+ {"bool", rw_type},
+ {"break", rw_break_or_goto_or_return},
+ {"case", rw_case_or_default},
+ {"char", rw_type},
+ {"complex", rw_type},
+ {"const", rw_type},
+ {"continue", rw_continue_or_inline_or_restrict},
+ {"default", rw_case_or_default},
+ {"do", rw_do_or_else},
+ {"double", rw_type},
+ {"else", rw_do_or_else},
+ {"enum", rw_struct_or_union_or_enum},
+ {"extern", rw_storage_class},
+ {"float", rw_type},
+ {"for", rw_for_or_if_or_while},
+ {"global", rw_type},
+ {"goto", rw_break_or_goto_or_return},
+ {"if", rw_for_or_if_or_while},
+ {"imaginary", rw_type},
+ {"inline", rw_continue_or_inline_or_restrict},
+ {"int", rw_type},
+ {"long", rw_type},
+ {"offsetof", rw_offsetof},
+ {"register", rw_storage_class},
+ {"restrict", rw_continue_or_inline_or_restrict},
+ {"return", rw_break_or_goto_or_return},
+ {"short", rw_type},
+ {"signed", rw_type},
+ {"sizeof", rw_sizeof},
+ {"static", rw_storage_class},
+ {"struct", rw_struct_or_union_or_enum},
+ {"switch", rw_switch},
+ {"typedef", rw_typedef},
+ {"union", rw_struct_or_union_or_enum},
+ {"unsigned", rw_type},
+ {"void", rw_type},
+ {"volatile", rw_type},
+ {"while", rw_for_or_if_or_while}
};
const char **typenames;
@@ -313,7 +313,7 @@
if (++buf_ptr >= buf_end)
fill_buffer();
}
- state->keyword = 0;
+ state->keyword = rw_0;
if (state->last_token == structure && !state->p_l_follow) {
/* if last token was 'struct' and we're not
* in parentheses, then this token
@@ -339,7 +339,7 @@
strcmp(u, "_t") == 0) || (typename_top >= 0 &&
bsearch(s_token, typenames, typename_top + 1,
sizeof(typenames[0]), strcmp_type))) {
- state->keyword = 4; /* a type name */
+ state->keyword = rw_type;
state->last_u_d = true;
goto found_typename;
}
@@ -347,39 +347,37 @@
state->keyword = p->rwcode;
state->last_u_d = true;
switch (p->rwcode) {
- case 7: /* it is a switch */
+ case rw_switch:
return lexi_end(swstmt);
- case 8: /* a case or default */
+ case rw_case_or_default:
return lexi_end(casestmt);
-
- case 3: /* a "struct" */
- /* FALLTHROUGH */
- case 4: /* one of the declaration keywords */
+ case rw_struct_or_union_or_enum:
+ case rw_type:
found_typename:
if (state->p_l_follow) {
/* inside parens: cast, param list, offsetof or sizeof */
state->cast_mask |= (1 << state->p_l_follow) & ~state->not_cast_mask;
}
if (state->last_token == period || state->last_token == unary_op) {
- state->keyword = 0;
+ state->keyword = rw_0;
break;
}
- if (p != NULL && p->rwcode == 3)
+ if (p != NULL && p->rwcode == rw_struct_or_union_or_enum)
return lexi_end(structure);
if (state->p_l_follow)
break;
return lexi_end(decl);
- case 5: /* if, while, for */
+ case rw_for_or_if_or_while:
return lexi_end(sp_paren);
- case 6: /* do, else */
+ case rw_do_or_else:
return lexi_end(sp_nparen);
- case 10: /* storage class specifier */
+ case rw_storage_class:
return lexi_end(storage);
- case 11: /* typedef */
+ case rw_typedef:
return lexi_end(type_def);
default: /* all others are treated like any other
@@ -410,7 +408,7 @@
isalpha((unsigned char)*buf_ptr)) &&
(state->last_token == semicolon || state->last_token == lbrace ||
state->last_token == rbrace)) {
Home |
Main Index |
Thread Index |
Old Index