[PATCH] D33841: [clang-tidy] redundant 'extern' keyword check
Roman Lebedev via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Jun 5 09:05:30 PDT 2019
lebedev.ri added inline comments.
================
Comment at: clang-tidy/readability/RedundantExternCheck.cpp:30
+
+ if (FD->getStorageClass() != SC_Extern)
+ return;
----------------
Can you do that in `registerMatchers()`?
================
Comment at: clang-tidy/readability/RedundantExternCheck.cpp:43-44
+
+ if (FD->getBeginLoc().isMacroID())
+ return;
+
----------------
Similarly, do this in `registerMatchers()`
================
Comment at: clang-tidy/readability/RedundantExternCheck.cpp:49
+ *Result.SourceManager, getLangOpts());
+
+ int Offset = Text.find("extern");
----------------
`StringLiteral Extern = StringLiteral("extern");`
================
Comment at: clang-tidy/readability/RedundantExternCheck.cpp:50
+
+ int Offset = Text.find("extern");
+
----------------
Extern
================
Comment at: clang-tidy/readability/RedundantExternCheck.cpp:53
+ SourceRange ExternRange(BeginLoc.getLocWithOffset(Offset),
+ BeginLoc.getLocWithOffset(Offset + strlen("extern")));
+
----------------
Extern.size()
================
Comment at: clang-tidy/readability/RedundantExternCheck.cpp:59
+
+ if (!ExternText.equals("extern")) // Final check: typedefs, etc.
+ return;
----------------
Extern
================
Comment at: docs/clang-tidy/checks/readability-redundant-extern.rst:10
+
+The default language linkage is C++, so without any additional parameters it is redundant (extern "C++" can also be redundant, but it depends on the context). In C context (extern "C") the situation is the same, extern keyword is redundant for function declarations
+
----------------
Please 80-char wrap
================
Comment at: docs/clang-tidy/checks/readability-redundant-extern.rst:14
+
+ extern void h();
+
----------------
More examples? A namespace one?
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D33841/new/
https://reviews.llvm.org/D33841
More information about the llvm-commits
mailing list