NoQ added a comment.

In D104616#2830349 <https://reviews.llvm.org/D104616#2830349>, @xazax.hun wrote:

> In D104616#2829705 <https://reviews.llvm.org/D104616#2829705>, @RedDocMD 
> wrote:
>
>> If `(ptr1 == ptr2)` is false, we can't say anything really.
>
> Well, I think it depends. If one of the pointers is null, for some platforms, 
> we can. E.g. null < non-null is probably true on most architectures, and 
> similarly non-null < null is false. Also null <= anyptr is probably true on 
> the platforms we care about.
>
>> If they are not the same, the only way == can return true if the two smart 
>> pointers were initialized from the same raw pointer. This is of course a 
>> fatal bug in itself.
>
> Is it? E.g. two default constructed unique_ptrs both should have null as the 
> underlying pointer, they should be considered equal, are not the same object, 
> and this is not a fatal bug.

Why not simply delegate this job to `assume(evalBinOp(...))` over raw pointer 
values, which already has all this logic written down nicely?


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D104616

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

Reply via email to