RedDocMD added a comment.

@steakhal, being picky with code from beginners is a good way to train them to 
write code I think, and so I must thank you for you scrutiny!
As for the test you pointed out, it is a wrong test. It is wrong now that I 
have a better understanding of the problem.
There are two options that can be taken I reckon:

- Simply make the stored `SVal` `Unknown` when we have a reinterpret-cast on 
pointer-to-member
- Model it properly to take care of all the semantics.

Both of them remove the bug. I would prefer the first one and leave a TODO for 
better modelling. Better modelling necessarily makes interpretation of 
pointer-to-member clumsy. Because previously, a pointer-to-member was always 
valid. If we include modelling for reinterpret-cast, then as far as I can see, 
the pointer-to-member may either be in a valid or invalid state. This would 
lead to a chain of other changes. Possible most certainly but I think a tad bit 
unnecessary, especially because this corner case makes the normal case handling 
more complex


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D96976

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

Reply via email to