balazske marked 5 inline comments as done.
balazske added inline comments.

================
Comment at: clang/lib/StaticAnalyzer/Checkers/StreamChecker.cpp:37-40
+  // NoError: No error flag is set or stream is not open.
+  // EofError: EOF condition (feof returns true)
+  // OtherError: other (non-EOF) error (ferror returns true)
+  // AnyError: EofError or OtherError
----------------
Szelethus wrote:
> These too. Also, I'm not yet sure whether we need `OtherError` and 
> `AnyError`, as stated in a later inline.
I plan to use `AnyError` for failing functions that can have **EOF** and other 
error as result. At a later `ferror` or `feof` call a new state split follows 
to differentiate the error (instead of having to add 3 new states after the 
function, for success, EOF error and other error). If other operation is called 
we know anyway that some error happened.


================
Comment at: clang/lib/StaticAnalyzer/Checkers/StreamChecker.cpp:333-335
+  // Ignore the call if the stream is is not tracked.
+  if (!State->get<StreamMap>(StreamSym))
+    return;
----------------
balazske wrote:
> Szelethus wrote:
> > If we check in `preCall` whether the stream is opened why don't we 
> > conservatively assume it to be open?
> If we do that we get a resource leak error for example in the test function 
> `pr8081` (there is only a call to `fseek`). We can assume that if the 
> function gets the file pointer as argument it does not "own" it so the close 
> is not needed. Otherwise the false positive resource leaks come always in 
> functions that take a file argument and use file operations. Or this case 
> (the file pointer is passed as input argument, the file is not opened by the 
> function that is analyzed) can be handled specially, we can assume that there 
> is no error initially and closing the file is not needed.
This can be done in a next change. It involves more changes at other places. I 
think of inserting the state for the stream if it was not there before. But we 
need to save if this was such an insert or a normal `fopen` (and do not report 
resource leak for the "insert" case).


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D75356



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

Reply via email to