xazax.hun added inline comments.

================
Comment at: clang/lib/StaticAnalyzer/Checkers/StreamChecker.cpp:33-45
+  enum KindTy {
+    Opened, /// Stream is opened.
+    Closed, /// Closed stream (an invalid stream pointer after it was closed).
+    OpenFailed /// The last open operation has failed.
+  } State;
+
+  /// The error state of a stream.
----------------
Szelethus wrote:
> balazske wrote:
> > Szelethus wrote:
> > > Hmm, now that I think of it, could we just merge these 2 enums? Also, I 
> > > fear that indexers would accidentally assign the comment to the enum 
> > > after the comma:
> > > 
> > > ```lang=cpp
> > >     Opened, /// Stream is opened.
> > >     Closed, /// Closed stream (an invalid stream pointer after it was 
> > > closed).
> > >     OpenFailed /// The last open operation has failed.
> > > ```
> > > ` /// Stream is opened` might be assigned to `Closed`. How about this:
> > > ```lang=cpp
> > >     /// Stream is opened.
> > >     Opened,
> > >     /// Closed stream (an invalid stream pointer after it was closed).
> > >     Closed,
> > >     /// The last open operation has failed.
> > >     OpenFailed
> > > ```
> > Probably these can be merged, it is used for a stream that is in an 
> > indeterminate state after failed `freopen`, but practically it is handled 
> > the same way as a closed stream. But this change would be done in another 
> > revision.
> I meant to merge the two enums (`StreamState` and `ErrorKindTy`) and the 
> fields associated with them (`State` and `ErrorState`). We could however 
> merge `Closed` and `OpenFailed`, granted that we put a `NoteTag` to 
> `evalFreopen`. But I agree, that should be another revision's topic :)
Since you mentioned that ErrorState is only applicable to Open streams, I am 
also +1 on merging the enums. These two states are not orthogonal, no reason 
for them to be separate.


================
Comment at: clang/lib/StaticAnalyzer/Checkers/StreamChecker.cpp:394
+        StreamSym, StreamState::getOpenedWithOtherError());
+    C.addTransition(StateEof);
+    C.addTransition(StateOther);
----------------
As you probably know we are splitting the execution paths here. This will 
potentially result in doubling the analysis tome for a function for each `feof` 
call. Since state splits can be really bad for performance we need good 
justification for each of them.
So the questions are:
* Is it really important to differentiate between eof and other error or is it 
possible to just have an any error state?
* Do we find more bugs in real world code that justifies these state splits?


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D75682



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

Reply via email to