aaron.ballman added inline comments.

================
Comment at: clang-tools-extra/clang-tidy/modernize/RedundantVoidArgCheck.cpp:51
                      this);
-  Finder->addMatcher(typedefNameDecl().bind(TypedefId), this);
+  Finder->addMatcher(typedefNameDecl(unless(isImplicit())).bind(TypedefId), 
this);
   auto ParenFunctionType = parenType(innerType(functionType()));
----------------
Might as well fix the clang-format issue.


================
Comment at: clang-tools-extra/clang-tidy/modernize/RedundantVoidArgCheck.cpp:149
   Token ProtoToken;
+  IdentifierTable &Idents = Result.Context->Idents;
+  int MacroLevel = 0;
----------------
I think a safer interface to this is to use a `const IdentifierTable &` here 
and in `isMacroIdentifier()`. Then, in `isMacroIdentifier()`, instead of using 
`get()` (which has no `const` overload because it can add an identifier to the 
table), you can use `find()`. This removes any possibility of accidentally 
adding identifiers to the table (even in future refactorings).


================
Comment at: 
clang-tools-extra/clang-tidy/modernize/RedundantVoidArgCheck.cpp:157-161
+      if (ProtoToken.is(tok::TokenKind::l_paren)) {
+        State = TokenState::LeftParen;
+      } else if (isMacroIdentifier(Idents, ProtoToken)) {
+        State = TokenState::MacroId;
+      }
----------------



================
Comment at: 
clang-tools-extra/clang-tidy/modernize/RedundantVoidArgCheck.cpp:164-168
       if (ProtoToken.is(tok::TokenKind::l_paren)) {
-        State = SawLeftParen;
+        State = TokenState::MacroLeftParen;
+      } else {
+        State = TokenState::Start;
+      }
----------------



================
Comment at: 
clang-tools-extra/clang-tidy/modernize/RedundantVoidArgCheck.cpp:173-177
+        if (isMacroIdentifier(Idents, ProtoToken)) {
+          State = TokenState::MacroId;
+        } else {
+          State = TokenState::MacroArguments;
+        }
----------------



================
Comment at: 
clang-tools-extra/clang-tidy/modernize/RedundantVoidArgCheck.cpp:180-184
+        if (MacroLevel == 0) {
+          State = TokenState::Start;
+        } else {
+          State = TokenState::MacroId;
+        }
----------------



================
Comment at: 
clang-tools-extra/clang-tidy/modernize/RedundantVoidArgCheck.cpp:215-219
       if (ProtoToken.is(tok::TokenKind::r_paren)) {
         removeVoidToken(VoidToken, Diagnostic);
       } else if (ProtoToken.is(tok::TokenKind::l_paren)) {
-        State = SawLeftParen;
+        State = TokenState::LeftParen;
       }
----------------



================
Comment at: 
clang-tools-extra/clang-tidy/modernize/RedundantVoidArgCheck.cpp:224-226
+  if (State == TokenState::Void && ProtoToken.is(tok::TokenKind::r_paren)) {
     removeVoidToken(VoidToken, Diagnostic);
   }
----------------



================
Comment at: 
clang-tools-extra/test/clang-tidy/checkers/modernize-redundant-void-arg.cpp:202
 // intentionally not LLVM style to check preservation of whitespace
+// clang-format off
 typedef
----------------
Unrelated change can be split out an NFC commit if you'd like, but we don't 
typically attempt to clang-format existing test files, so also not really 
necessary either.


================
Comment at: 
clang-tools-extra/test/clang-tidy/checkers/modernize-redundant-void-arg.cpp:561
+#define return_t(T) T
+return_t(void) func(void);
+// CHECK-MESSAGES: :[[@LINE-1]]:21: warning: redundant void argument list in 
function declaration
----------------
LegalizeAdulthood wrote:
> jrtc27 wrote:
> > LegalizeAdulthood wrote:
> > > LegalizeAdulthood wrote:
> > > > aaron.ballman wrote:
> > > > > LegalizeAdulthood wrote:
> > > > > > aaron.ballman wrote:
> > > > > > > Can you also add a test for:
> > > > > > > ```
> > > > > > > void func(return_t(void));
> > > > > > > ```
> > > > > > `:-)`
> > > > > > 
> > > > > > What are you suggesting the result should be?  Honestly, looking at 
> > > > > > that, I'm not sure myself `:)`
> > > > > > 
> > > > > > IMO, if I saw this in a code review, I would flag it because you're 
> > > > > > using a macro called "return type" to specify the type of an 
> > > > > > argument.
> > > > > LoL, yeah, the name `return_t` would certainly be novel to use in a 
> > > > > parameter list, but what I was hoping to test is whether we try to 
> > > > > fix the use of the macro within the parameter list or not. I *think* 
> > > > > it probably makes sense to issue the diagnostic, but I don't think it 
> > > > > makes sense to try to fix it because the macro could be defined 
> > > > > differently for different configurations. But the diagnostic is 
> > > > > silenced as well as the fix-it, I wouldn't lose a whole lot of sleep 
> > > > > over it.
> > > > Well it could conceivably be used to declare a function pointer 
> > > > argument like this:
> > > > 
> > > > `void func(return_t(void) (*fp)(void));`
> > > > 
> > > > In that case, my expectation is that the check would fix the void arg, 
> > > > but not the arg to the macro.
> > > OK, that was a good idea to add the test I described above because it 
> > > failed `:)`,
> > > so let me improve the check some more.
> > If you want a less-contrived example that shows up all over the place in 
> > crusty old C code that supports (or, perhaps, supported and let bitrot 
> > support for) pre-ANSI C compilers:
> > 
> > ```
> > #define __P(x) x
> > void foo __P((void));
> > ```
> > 
> > (the idea being that, for pre-ANSI C compilers, you'd instead define __P(x) 
> > as () to get `void foo ();`)
> Well, in (modern) C you don't want to remove the `void` in `(void)` at all.
> 
> This check applies only to C++ code, so we should be safe here.
> 
> I'll add a test case just to cover it -- I think the correct result should be
> that the check leaves this instance of `(void)` intact.
> Well, in (modern) C you don't want to remove the void in (void) at all.

In everything but `-ansi` mode, in fact (C89 supported prototypes). :-D

> I'll add a test case just to cover it -- I think the correct result should be 
> that the check leaves this instance of (void) intact.

Thanks for the coverage, and I agree, we shouldn't try mucking with a fix in 
the presence of a macro.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D116425/new/

https://reviews.llvm.org/D116425

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to