aaron.ballman added inline comments.

================
Comment at: clang-tools-extra/clang-tidy/ClangTidyDiagnosticConsumer.cpp:352
+      // Allow specifying a few checks with a glob expression, ignoring
+      // negative globs (which would effectively disable the suppression)
+      GlobList Globs(ChecksStr, /*KeepNegativeGlobs=*/false);
----------------



================
Comment at: clang-tools-extra/clang-tidy/ClangTidyDiagnosticConsumer.cpp:406
+      if (!NolintBegins.empty() &&
+          (NolintBegins.back().second == NolintChecksStr)) {
+        NolintBegins.pop_back();
----------------



================
Comment at: clang-tools-extra/clang-tidy/ClangTidyDiagnosticConsumer.cpp:455-456
+  for (const auto NolintBegin : NolintBegins) {
+    auto Error = createNolintError(Context, SM, NolintBegin.first, true);
     SuppressionErrors.emplace_back(Error);
   }
----------------



================
Comment at: clang-tools-extra/clang-tidy/ClangTidyDiagnosticConsumer.cpp:349
+      // Allow specifying a few checks with a glob expression.
+      GlobList Globs(ChecksStr);
+      if (!Globs.contains(CheckName))
----------------
carlosgalvezp wrote:
> salman-javed-nz wrote:
> > carlosgalvezp wrote:
> > > aaron.ballman wrote:
> > > > carlosgalvezp wrote:
> > > > > salman-javed-nz wrote:
> > > > > > What happens when `CheckStr` is empty?
> > > > > > How has Clang-Tidy treated `// NOLINT()` in the past? Does this 
> > > > > > patch change the behaviour? What //should // be the "right" 
> > > > > > behaviour?
> > > > > Very good question! Currently on master `// NOLINT()` will *not* 
> > > > > suppress warnings. However `// NOLINT(` will. My patch shouldn't 
> > > > > change existing behavior - an empty list of globs will return false 
> > > > > when calling `contains`.
> > > > > 
> > > > > I'll add a unit test to cover this case!
> > > > (All of this is a bit orthogonal to this patch, so no changes requested 
> > > > here.)
> > > > 
> > > > Naively, I would expect `NOLINT()` to be an error because it expects an 
> > > > argument and none was given. (I'd expect `NOLINT(` to also be an error 
> > > > because the syntax is malformed.)
> > > Fully agree! If I find some time I can give it a try on a separate patch
> > The NOLINT syntax was borrowed from Google's cpplint.py. cpplint uses a 
> > regex search to find NOLINT expressions, but it's pretty naive, leading to 
> > quirks like `NOLINT(` being accepted as a valid expression. Clang-Tidy has 
> > inherited the same quirks by being interoperable with cpplint's syntax.
> > 
> > How important it is to maintain compatibility with the more funky aspects 
> > of cpplint's `NOLINT` behaviour, I'm not sure. The two programs' syntaxes 
> > aren't fully compatible nowadays anyway. To give an example, cpplint 
> > doesn't support multiple checks separated by commas on the same line. This 
> > glob feature will be another divergence. 
> > 
> > Just something to think about for next time.
> I'd gladly decouple clang-tidy and cpplint. Personally I don't find the 
> benefit of running both, clang-tidy is way superior.
> 
> How important it is to maintain compatibility with the more funky aspects of 
> cpplint's NOLINT behaviour, I'm not sure.

I think the important thing is for users who use both tools to not have a bad 
experience because clang-tidy is yelling at them about NOLINT comment syntax. 
Fixing a syntax issue to make clang-tidy happy only to break cpplint (and vice 
versa) would leave users stuck.

I don't have a copy of cpplint handy, so I'm not able to validate my own 
suggestions for diagnostics here. If you hear a suggestion that would lead us 
down the "warring diagnostics" path, please push back!


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

https://reviews.llvm.org/D111208

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

Reply via email to