NoQ added a comment.

In D64991#1595853 <https://reviews.llvm.org/D64991#1595853>, @Szelethus wrote:

> `CFGElementRef`


Wait, is it a thing already?? Did i miss anything???

> This analysis isn't conservative enough yet, I really should include function 
> calls with non-const references into the gen set, but hey, at this point I'm 
> optimistic that it can be done.

"Conservative" is not a property of the algorithm; it depends on how is the 
algorithm used. For some purposes you'll want to add an extra definition when 
you're not sure if it'll be a definition, for other purposes you'll want to 
only have definitions in which you are 100% certain in the set.



================
Comment at: clang/lib/Analysis/ReachingDefinitions.cpp:68
+    auto Assignments =
+        match(stmt(forEachDescendant(AssignmentM)), *S, *Context);
+    if (!Assignments.empty()) {
----------------
I don't think you really need this. Every assignment would anyway appear in the 
CFG as a separate element. And also `forEachDescendant()` may accidentally scan 
items in different CFG blocks (i.e., if the whole statement is a `?:` or a 
logical op).


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

https://reviews.llvm.org/D64991



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

Reply via email to