Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/xlint/lint1 lint: split check_global_variable into s...



details:   https://anonhg.NetBSD.org/src/rev/20947b2c20d5
branches:  trunk
changeset: 1017824:20947b2c20d5
user:      rillig <rillig%NetBSD.org@localhost>
date:      Sun Jan 10 18:22:52 2021 +0000

description:
lint: split check_global_variable into several functions

This reduces the indentation and allows the messages in the comments to
contain the complete text instead of only an abbreviated prefix.

No functional change.

diffstat:

 usr.bin/xlint/lint1/decl.c |  88 +++++++++++++++++++++++++--------------------
 1 files changed, 49 insertions(+), 39 deletions(-)

diffs (126 lines):

diff -r cc14976ff189 -r 20947b2c20d5 usr.bin/xlint/lint1/decl.c
--- a/usr.bin/xlint/lint1/decl.c        Sun Jan 10 18:13:42 2021 +0000
+++ b/usr.bin/xlint/lint1/decl.c        Sun Jan 10 18:22:52 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: decl.c,v 1.119 2021/01/10 18:13:42 rillig Exp $ */
+/* $NetBSD: decl.c,v 1.120 2021/01/10 18:22:52 rillig Exp $ */
 
 /*
  * Copyright (c) 1996 Christopher G. Demetriou.  All Rights Reserved.
@@ -38,7 +38,7 @@
 
 #include <sys/cdefs.h>
 #if defined(__RCSID) && !defined(lint)
-__RCSID("$NetBSD: decl.c,v 1.119 2021/01/10 18:13:42 rillig Exp $");
+__RCSID("$NetBSD: decl.c,v 1.120 2021/01/10 18:22:52 rillig Exp $");
 #endif
 
 #include <sys/param.h>
@@ -79,8 +79,8 @@
 static void    check_variable_usage(int, sym_t *);
 static void    check_label_usage(sym_t *);
 static void    check_tag_usage(sym_t *);
-static void    check_global_variable(sym_t *);
-static void    check_global_variable_size(sym_t *);
+static void    check_global_variable(const sym_t *);
+static void    check_global_variable_size(const sym_t *);
 
 /*
  * initializes all global vars used in declarations
@@ -3126,7 +3126,48 @@
 }
 
 static void
-check_global_variable(sym_t *sym)
+check_unused_static_global_variable(const sym_t *sym)
+{
+       curr_pos = sym->s_def_pos;
+       if (sym->s_type->t_tspec == FUNC) {
+               if (sym->s_def == DEF) {
+                       if (!sym->s_inline)
+                               /* static function %s unused */
+                               warning(236, sym->s_name);
+               } else {
+                       /* static function %s declared but not defined */
+                       warning(290, sym->s_name);
+               }
+       } else if (!sym->s_set) {
+               /* static variable %s unused */
+               warning(226, sym->s_name);
+       } else {
+               /* static variable %s set but not used */
+               warning(307, sym->s_name);
+       }
+}
+
+static void
+check_static_global_variable(const sym_t *sym)
+{
+       if (sym->s_type->t_tspec == FUNC && sym->s_used && sym->s_def != DEF) {
+               curr_pos = sym->s_use_pos;
+               /* static function called but not defined: %s() */
+               error(225, sym->s_name);
+       }
+
+       if (!sym->s_used)
+               check_unused_static_global_variable(sym);
+
+       if (!tflag && sym->s_def == TDEF && sym->s_type->t_const) {
+               curr_pos = sym->s_def_pos;
+               /* const object %s should have initializer */
+               warning(227, sym->s_name);
+       }
+}
+
+static void
+check_global_variable(const sym_t *sym)
 {
 
        if (sym->s_scl == TYPEDEF || sym->s_scl == ENUMCON)
@@ -3139,43 +3180,12 @@
 
        check_global_variable_size(sym);
 
-       if (sym->s_scl == STATIC) {
-               if (sym->s_type->t_tspec == FUNC) {
-                       if (sym->s_used && sym->s_def != DEF) {
-                               curr_pos = sym->s_use_pos;
-                               /* static func. called but not def... */
-                               error(225, sym->s_name);
-                       }
-               }
-               if (!sym->s_used) {
-                       curr_pos = sym->s_def_pos;
-                       if (sym->s_type->t_tspec == FUNC) {
-                               if (sym->s_def == DEF) {
-                                       if (!sym->s_inline)
-                                               /* static function %s unused */
-                                               warning(236, sym->s_name);
-                               } else {
-                                       /* static function %s declared but... */
-                                       warning(290, sym->s_name);
-                               }
-                       } else if (!sym->s_set) {
-                               /* static variable %s unused */
-                               warning(226, sym->s_name);
-                       } else {
-                               /* static variable %s set but not used */
-                               warning(307, sym->s_name);
-                       }
-               }
-               if (!tflag && sym->s_def == TDEF && sym->s_type->t_const) {
-                       curr_pos = sym->s_def_pos;
-                       /* const object %s should have initializer */
-                       warning(227, sym->s_name);
-               }
-       }
+       if (sym->s_scl == STATIC)
+               check_static_global_variable(sym);
 }
 
 static void
-check_global_variable_size(sym_t *sym)
+check_global_variable_size(const sym_t *sym)
 {
 
        if (sym->s_def == TDEF) {



Home | Main Index | Thread Index | Old Index