psionic12 marked 4 inline comments as done.
psionic12 added inline comments.


================
Comment at: clang/examples/Attribute/Attribute.cpp:81
+    D->addAttr(AnnotateAttr::Create(S.Context, "example", &Arg0,
+                                    Attr.getNumArgs(), Attr.getRange()));
     return AttributeApplied;
----------------
aaron.ballman wrote:
> This looks dangerous to me -- if there are two or three arguments supplied, 
> then this code will result in a buffer overrun.
Oh, didn't noticed that, but I checked the code it's hard to get the address of 
the argument buffer, all APIs about it is private, even if `ArgsUnion const 
*getArgsBuffer() const`, which I think is not very reasonable. Do you think I 
should copy all the arguments to a new buffer (not very effective), or do you 
think I should contribute a patch to make the API public?

There's a third way, `getTrailingObjects()` is public in TrailingObjects, it is 
possible to cast an `ParsedAttr` to a `TrailingObjects`, but I think it's too 
hacky.


================
Comment at: clang/test/Frontend/plugin-attribute.cpp:1
-// RUN: %clang -fplugin=%llvmshlibdir/Attribute%pluginext -emit-llvm -S %s -o 
- 2>&1 | FileCheck %s --check-prefix=ATTRIBUTE
-// RUN: not %clang -fplugin=%llvmshlibdir/Attribute%pluginext -emit-llvm 
-DBAD_ATTRIBUTE -S %s -o - 2>&1 | FileCheck %s --check-prefix=BADATTRIBUTE
+// RUN: %clang -fplugin=%llvmshlibdir/Attribute%pluginext -DGOOD_ATTR 
-fsyntax-only -Xclang -verify=goodattr %s
+// RUN: %clang -fplugin=%llvmshlibdir/Attribute%pluginext -DBAD_ATTR 
-fsyntax-only -Xclang -verify=badattr %s
----------------
aaron.ballman wrote:
> I don't think we need a GOOD_ATTR and BAD_ATTR run line any longer. Instead, 
> you can use a single RUN line with `-verify` (no `=`) and use 
> `expected-error` and `expected-warning` on the lines that need the 
> diagnostics. This means you can also get rid of the `@ line number` 
> constructs and just write the expected comments on the source lines with 
> diagnostics.
Seems the `GOOD_ATTR` and `BAD_ATTR` need to be exist since we use `-ast-dump` 
now, we need a clean build without error diagnostics to generate a nice AST.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D92006

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

Reply via email to