whisperity wrote:

> And to determine if it's bad one needs to understand how the result of the 
> lookup or the individual elements of the iteration are used.

And the issue here is that, in the extreme case, even a completely omniscient 
call graph oracle would still fail at proving immunity to non-determinism even 
in your second case, because the determinism requirement could come from 
something like `FileCheck` ran externally to the code that executed a 
non-deterministic order.

I'm unsure as to what the right approach would be here. I was thinking about 
instead marking every variable or field declared with a type like 
`known-unordered-container-type <T*>` instead of the for loops themselves, but 
then we are essentially trying to say that this partial specialisation is 
"deprecated" in a way... "you shouldn't put pointers into this because no 
matter what you do, it will have a non-deterministic order"... and???

But your second example, @steakhal, touches on the problem nicely. What if we 
tried to match archetypes of "container elements are printed" or "container 
elements are sent to the network"? It will never be a complete list, but we 
*could* reasonably assume (at least this is a safe-ish generalisation, and for 
everything else, there is NOLINT...) that if the order escapes via some I/O, 
then non-determinism is... maybe if not outright __bad__, but definitely 
uncanny, if for nothing else, due to the troubles it causes when debugging. 😉 

https://github.com/llvm/llvm-project/pull/110471
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to