vsavchenko added inline comments.

================
Comment at: clang/include/clang/Basic/Attr.td:2366
   let Args = [VariadicStringArgument<"DiagnosticIdentifiers">];
   let Documentation = [SuppressDocs];
 }
----------------
aaron.ballman wrote:
> The documentation will need to be updated for this. I have no idea if that 
> may be a bit awkward because we're documenting two different suppression 
> mechanisms (that do roughly the same thing).
I decided not to change it yet because I was not sure that this is going to be 
the final solution.


================
Comment at: clang/lib/Sema/SemaDeclAttr.cpp:4567
 static void handleSuppressAttr(Sema &S, Decl *D, const ParsedAttr &AL) {
-  if (!checkAttributeAtLeastNumArgs(S, AL, 1))
+  if (AL.isCXX11Attribute() && !checkAttributeAtLeastNumArgs(S, AL, 1))
     return;
----------------
aaron.ballman wrote:
> The behavior here will be that `[[gsl::suppress]]` in C++11 mode and 
> `[[clang::suppress]]` in C++11 mode require at least one argument, while 
> `[[clang::supress]]` in C2x mode and `__attribute__((suppress))` in all 
> language modes allow any number of arguments (including zero). That doesn't 
> seem like what you want. I think you need something more like:
> ```
> // The [[gsl::suppress]] spelling requires at least one argument, but the GNU
> // and [[clang::suppress]] spellings do not require any arguments.
> if (AL.hasScope() && AL.getScopeName()->isStr("gsl") &&
>     !checkAttributeAtLeastNumArgs(S, AL, 1))
>   return;
> ```
That's much better, thanks!


================
Comment at: clang/lib/Sema/SemaStmtAttr.cpp:56
                                 SourceRange Range) {
-  if (A.getNumArgs() < 1) {
+  if (A.isCXX11Attribute() && A.getNumArgs() < 1) {
     S.Diag(A.getLoc(), diag::err_attribute_too_few_arguments) << A << 1;
----------------
aaron.ballman wrote:
> Same issue here.
> 
> (In other news, it looks like this attribute could stand to be updated to be 
> a `DeclOrStmtAttr` once D92800 lands -- that's not your problem to solve, 
> more just an observation.)
This is actually something that I wanted to ask out of curiosity, how it works 
as a declaration attribute if it's declared as `StmtAttr`


================
Comment at: clang/lib/Sema/SemaStmtAttr.cpp:69
     // FIXME: Warn if the rule name is unknown. This is tricky because only
-    // clang-tidy knows about available rules.
+    // clang-tidy and static analyzer know about available rules.
     DiagnosticIdentifiers.push_back(RuleName);
----------------
aaron.ballman wrote:
> 
Sure


================
Comment at: clang/lib/StaticAnalyzer/Core/BugReporter.cpp:2885
+
+  if (It != Attrs.end()) {
+    return cast<SuppressAttr>(*It);
----------------
aaron.ballman wrote:
> The coding standard has us elide braces on single-line ifs (same comment 
> applies elsewhere).
Sure!


================
Comment at: clang/lib/StaticAnalyzer/Core/BugReporter.cpp:2897
+                                                           ASTContext &AC) {
+  PathDiagnosticLocation Location = BR.getLocation();
+
----------------
xazax.hun wrote:
> What will this location return? In case of a leak warning, we might get a 
> different instance of the same warning on separate paths. We usually pick the 
> shortest path, but it can change when we slightly alter the source code. 
> Maybe we want the user to put the suppression at the uniqueing location when 
> such location exist? (The allocation in case of a leak warnings.) I think 
> that would result in a better user experience and more robust suppression 
> mechanism. An open question is how to educate the user about the correct way 
> of suppression. Should we emit a suppress location to the user explicitly?
Ah, leaks.  I thought about those, and probably should've mentioned it here.
I think it is counter-intuitive to have separate locations for warnings 
themselves and for suppressions.  Because this would be the first place where 
the user will try to put suppression.  It is not obvious what to do with 
locations when we report that something didn't happen when it should've.  But 
this group of checkers is relatively small, usually we do have a precise 
location where something bad happens.  So, I believe that leaks should be 
addressed separately and not affect design for suppressions for the vast 
majority of checkers.
Speaking of leaks, `RetainReleaseChecker` reports leaks on the allocation and 
they can be suppressed that way.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D93110

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

Reply via email to