Re: [PATCH] riscv: Add header include guards to insn.h

From: Joe Perches
Date: Wed Feb 01 2023 - 22:33:40 EST


On Thu, 2023-02-02 at 08:52 +0800, liaochang (A) wrote:
>
> 在 2023/2/1 17:42, Conor Dooley 写道:
> > Hi,
> >
> > On Wed, Feb 01, 2023 at 05:37:24PM +0800, liaochang (A) wrote:
> > > 在 2023/1/30 22:53, Conor Dooley 写道:
> > > > On Sun, Jan 29, 2023 at 05:42:42PM +0800, Liao Chang wrote:
> > > > > Add header include guards to insn.h to prevent repeating declaration of
> > > > > any identifiers in insn.h.
> > > >
> > > > I'm curious, did you spot this "by hand" while doing other work, or do
> > > > you have a tool that found it for you?
> > >
> > > I found this "by hand", inspired by scripts/checkdeclares.pl, i write a tiny tool
> > > to analyse the missing header guards in header file.
> >
> > Ohh, cool! I'd love to add this one to the checks on patchwork so that
> > we do not end up adding any more of these. If this is based on
> > checkdeclares, is it GPLv2?
>
> Definitely, it is GPLv2,i will appending licence identifier and copyright info later.
>
> Hi,@Joe Perches, is it ok to integrate this tool to scripts?

Don't see why not.
Perhaps submit it as a real patch to Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx>

Trivial notes below:

> > > #!/usr/bin/env perl
> > > use strict;
> > >
> > > sub usage {
> > > print "Usage: checkguards.pl file1.h ...\n";
> > > print "Warn of missing header guards\n";
> > > exit 1;
> > > }
> > >
> > > if ($#ARGV < 0) {
> > > usage();
> > > }
> > >
> > > foreach my $file (@ARGV) {
> > > open(my $f, '<', $file)
> > > or die "Cannot open $file: $!.\n";
> > >
> > > my $scan_area = 1;
> > > my $guards_warn = 0;
> > >
> > > # The lines of header file are divided into several areas as follows:
> > > #
> > > # ... area1 ...
> > > # #ifndef _HEADER_GUARD
> > > # ... area2 ...
> > > # #define _HEADER_GUARD
> > > # ... area3 ...
> > > # #endif /* _HEADER_GUARD */
> > > # ... area4 ...
> > > # EOF
> > > #
> > > # If any statement is found in area1, area2, and area4, it
> > > # throws a warning of illegal usage of header guard usage.

Not illegal, invalid

> > > while (<$f>) {
> > > if (m/^(.*);\s*$/o) {
> > > if ($scan_area == 1 || $scan_area == 2 || $scan_area == 4) {
> > > ++$guards_warn;
> > > }
> > > } elsif (m/^\s*(#ifndef\s+)[a-zA-Z0-9_]*_H[_]*\s*$/o) {
> > > ++$scan_area;
> > > } elsif (m/^\s*(#define\s+)[a-zA-Z0-9_]*_H[_]*\s*$/o) {
> > > ++$scan_area;
> > > } elsif (m/^\s*(#endif)\s*\/\*\s*[a-zA-Z0-9_]*_H[_]*\s*\*\/\s*$/o) {
> > > ++$scan_area;
> > > }
> > > }
> > >
> > > close($f);
> > >
> > > if ($guards_warn) {
> > > print "Illegal usage of header guard found in $file.\n";

here too

There are also uses like #if !defined(FOO)
There can be spaces before and after the #

It might also be useful to have a check for missing header guards.