martong marked 2 inline comments as done.
martong added inline comments.

================
Comment at: 
clang/include/clang/StaticAnalyzer/Core/PathSensitive/ConstraintManager.h:156
+  private:
+    llvm::SmallSet<const ProgramState *, 4> Aux;
+  };
----------------
steakhal wrote:
> Have you considered [[ 
> https://www.llvm.org/docs/ProgrammersManual.html#llvm-adt-smallptrset-h | 
> llvm::SmallPtrSet]] ?
Actually, a SmallSet of pointers is transparently implemented with a 
SmallPtrSet.


================
Comment at: clang/lib/StaticAnalyzer/Core/ConstraintManager.cpp:56-59
+  const ProgramState *RawSt = State.get();
+  if (AssumeStack.hasCycle(RawSt))
+    return {State, State};
+  AssumeStack.push(RawSt);
----------------
steakhal wrote:
> Why don't you return `RawSt` on the early return path instead? That seems to 
> contain more information than `State`, right?
> 
> You lookup twice the location of the `RawSt` entry; once in the `hasCycle()` 
> and again in the `push()`.
> I would recommend doing an unconditional `insert()` directly and reusing the 
> returned bool part of the pair to observe if it did actually insert.
> Why don't you return `RawSt` on the early return path instead? That seems to 
> contain more information than `State`, right?
No, `RawSt` contains the same information as `State`.

> You lookup twice the location of the `RawSt` entry; once in the `hasCycle()` 
> and again in the `push()`.
> I would recommend doing an unconditional `insert()` directly and reusing the 
> returned bool part of the pair to observe if it did actually insert.

I am considering to change the container to a `SmallVector` instead. I'd like 
to keep the interface of `hasCycle` and `push` and `pop` because those express 
the intention more clearly. And SmallSet falls back to a simple linear search 
anyway if size is less than N.




Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D126560

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

Reply via email to