ASDenysPetrov added inline comments.

================
Comment at: clang/lib/StaticAnalyzer/Core/RegionStore.cpp:1643-1654
+  const VarRegion *VR = dyn_cast<VarRegion>(R->getSuperRegion());
+  SmallVector<SVal, 2> SValOffsets;
+  SValOffsets.push_back(R->getIndex());
+  if (const ElementRegion *ER = dyn_cast<ElementRegion>(R->getSuperRegion())) {
+    const ElementRegion *LastER = nullptr;
+    do {
+      SValOffsets.push_back(ER->getIndex());
----------------
steakhal wrote:
> I dislike this part of code. It has side effects all over the place.
> Please use immediately called lambdas to describe your intentions in a more 
> //pure// manner.
> 
> Besides that, when I see `ElementRegions`, I'm always scared. They sometimes 
> represent reinterpret casts.
> Since you have dealt with so many casts and region store stuff in the past, 
> I'm assuming you have thought about this here.
> Although, I'm still scared slightly, and I'd like to have evidence of this 
> thought process. Likely some assertions or at least some comments? Could you 
> @ASDenysPetrov elaborate on this?
> Please use immediately called lambdas.
I'll do.
> They sometimes represent reinterpret casts. ...  I'm assuming you have 
> thought about this here.
Yes. This is my another revision in the stack. You are welcome: D110927


================
Comment at: clang/lib/StaticAnalyzer/Core/RegionStore.cpp:1656
+
+  // TODO: Add a test case for this check.
+  if (!VR)
----------------
martong wrote:
> Please address this TODO.
I found the tests:
  - Analysis/MemRegion.cpp
  - Analysis/ctor.mm
  - Analysis/mpichecker.cpp
  - Analysis/string.c
They cover this check.



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

https://reviews.llvm.org/D111654

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

Reply via email to