aaron.ballman added inline comments.

================
Comment at: clang/examples/Attribute/Attribute.cpp:35
+    Spellings.push_back({ParsedAttr::AS_GNU, "example"});
+    Spellings.push_back({ParsedAttr::AS_CXX11, "::example"});
+    Spellings.push_back({ParsedAttr::AS_CXX11, "plugin::example"});
----------------
john.brawn wrote:
> aaron.ballman wrote:
> > This is not a valid spelling for an attribute (we should probably assert 
> > that an attribute-scoped-token does not have an empty scope).
> "::example" is actually how an unscoped spelling is specified - normalizeName 
> in Basic/Attributes.cpp adds a "::" to the start if there's no scope, and the 
> tablegen-generated getAttrKind expects it as well.
It's not how an unscoped spelling is specified by either C or C++ -- in both 
languages, that would be an error. I don't think we want to leak this 
implementation detail out to the user as it will be confusing to them.


================
Comment at: clang/examples/Attribute/Attribute.cpp:42
+    // This attribute appertains to functions only.
+    if (!D || !isa<FunctionDecl>(D)) {
+      S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type_str)
----------------
john.brawn wrote:
> aaron.ballman wrote:
> > I don't think `D` can ever be null, can it?
> I don't know, but this is how the auto-generated diagAppertainsToDecl 
> functions do it.
I'll fix that up -- I just verified that `D` can never be null. 
`Sema::ProcessDeclAttributeList` dereferences `D` unconditionally and has for a 
long time.


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

https://reviews.llvm.org/D31343



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

Reply via email to