balazske added inline comments.

================
Comment at: clang/lib/StaticAnalyzer/Checkers/StreamChecker.cpp:507-511
+  // FIXME: Use a return value from EvalFn instead of isDifferent.
+  // Some functions should not change state and not have any other
+  // (invalidation, including errno) effect.
+  // For example if 'feof' is used with unknown stream we know that errno does
+  // not change (and presumably no other state that is otherwise invalidated).
----------------
Szelethus wrote:
> Okay, but how does `CheckerContext::isDifferent()` misbehave in that case?
I do not know exactly why I put this this FIXME here. I was probably thinking 
about a situation when `errno` does not change in any case and the modeled 
function (`feof`) has no other effect. But `feof` should not change `errno` 
only if the stream is valid, and if the stream is unknown it may be invalid. 
Now the `evalCall` returns false, a default evaluation follows and `errno` is 
invalidated, this is how it should work. The FIXME can be removed.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D137790

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

Reply via email to