NoQ accepted this revision.
NoQ added a comment.
This revision is now accepted and ready to land.

This looks fantastic, thanks!

> Note: I don't have commit access.

I can commit this for you but i believe you should totally ask for it 
<https://llvm.org/docs/DeveloperPolicy.html#obtaining-commit-access>.



================
Comment at: test/Analysis/more-dtors-cfg-output.cpp:50
+// CXX14: (CXXConstructExpr{{.*}}, struct Foo)
+// CXX14: ~Foo() (Temporary object destructor)
+// CHECK: ~Foo() (Implicit destructor)
----------------
comex wrote:
> NoQ wrote:
> > Maybe also add `CXX20-NOT` so that to make sure that the destructor *isn't* 
> > there? (i think this applies to a lot of other tests)
> The `-implicit-check-not=destructor` handles that: it complains if any line 
> containing "destructor" isn't covered by a CHECK.
Ahaa, i see what you did here!


================
Comment at: test/Analysis/more-dtors-cfg-output.cpp:251-252
+void default_ctor_with_default_arg() {
+  // FIXME: The CFG records a construction of the array type but a destruction
+  // of the base type, which is inconsistent.  It really should should be
+  // emitting a loop, which should also contain the construction/destruction of
----------------
comex wrote:
> NoQ wrote:
> > Is it just mismatching dump styles or is it an actual error?
> Oops – it's actually just the printing code for implicit destructors that 
> does:
> 
> ```
> if (const ArrayType *AT = ACtx.getAsArrayType(T))
>   T = ACtx.getBaseElementType(AT);
> ```
> 
> I'm not sure why that's there: perhaps because `~Foo[]()` is not valid C++ 
> syntax, but there's plenty of other places in the printing code that can 
> print invalid syntax, and printing just `~Foo()` is misleading.
> For now, until this code is overhauled to emit loops for constructors and 
> destructors, I think it makes the most sense to remove those two lines.  I'll 
> do that in the updated patch.
I don't care if it's valid C++ syntax as long as it's readable/testable.

Another possible variant is `~Foo() (Array destructor)`, we seem to do this a 
lot.


================
Comment at: test/Analysis/more-dtors-cfg-output.cpp:273
+#if CXX2A
+// Boilerplate needed to test co_return:
+
----------------
comex wrote:
> NoQ wrote:
> > Feel free to move this into 
> > `test/Analysis/inputs/system-header-simulator-cxx.h`, we could always use 
> > more mocks in there.
> Well, `TestPromise` is a bit specific to this test.  In particular, the 
> `return_value` method would normally return `void`, but I have it return a 
> `Foo`, which just gets discarded, in order to check that the corresponding 
> destructor call is recorded properly.
> 
> The non-test-specific boilerplate is <10 lines of code.  I could add it to 
> `system-header-simulator-cxx.h`, but then I'd have to figure out how to make 
> sure that this test file doesn't get confused by CFG output from any inline 
> functions defined there, especially given the `-implicit-check-not` flag.  
> Right now almost all function implementations in the header are within a 
> template and thus won't produce CFG (or IR or other analysis) output by 
> themselves, so the solution would probably consist of merely adding a comment 
> to `system-header-simulator-cxx.h`, requesting that any future additions be 
> either similarly templated or hidden behind an #ifdef.  That's definitely 
> feasible, but it doesn't seem worth dealing with for such a small amount of 
> code. :)
> 
> However, I need to fix the indentation and improve the wording of the comment 
> in `coreturn`.
Ok np then!


Repository:
  rC Clang

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

https://reviews.llvm.org/D66404



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

Reply via email to