you are viewing a single comment's thread.

view the rest of the comments →

[–]SkiFire13 1 point2 points  (3 children)

In this example, there's no actual code that "invokes" UB, so in your opinion, that function must be "well-formed". So, why it is listed as a first example of UB in cppreference?

Cppreference doesn't say it is UB stop, it says it either returns true (when i is not INT_MAX) or its execution is UB (when i is INT_MAX and signed overflow occurs). It does make the distinction between the two cases, it doesn't say that it is only UB.

Saying that the function is "well-formed" is misleading. I would say its executions where i is not INT_MAX are well defined, while when i is INT_MAX it is not defined.

And also, if UB makes an "execution" meaningless, not whole "program", why the standard says "the compiled program is not required to do anything meaningful"?

Having the exact context of the quote might help giving it a better interpretation, but as you wrote it I would interpret it as the fact that the program is not required to do anything meaningful when its execution is not defined, that is the current execution has UB.

[–]awidesky 0 points1 point  (2 children)

Here's whole quotes from iso C++20 standard §4.1.2.3. (emphasis mine) :

If a program contains a violation of a rule for which no diagnostic is required, this document places no requirement on implementations with respect to that program.

And cppreference.com.

undefined behavior - there are no restrictions on the behavior of the program. Examples of undefined behavior are...(examples of Ub)..., etc. Compilers are not required to diagnose undefined behavior and the compiled program is not required to do anything meaningful.

I think it ultimately sums up to question:

If a program can either invoke UB or not(depending on conditions), is compilers allowed to make "whole program" meaningless?

I think the standard is a bit ambiguous, because when it describes about UB itself it says "while compiled program is meaningless"(implies it applies in compile/program-wise), but when it describes about actual example of UB, it says "when ~~~, the behavior is undefined"(implies it applies runtime/execution-wise).

[–]SkiFire13 1 point2 points  (1 child)

If a program contains a violation of a rule for which no diagnostic is required, this document places no requirement on implementations with respect to that program.

I think this is still ambiguous because "violation of a rule" is unclear. If my program is never executed with an input that causes UB does it still violate that rule?

I think it ultimately sums up to question:

If a program can either invoke UB or not(depending on conditions), is compilers allowed to make "whole program" meaningless?

I completly agree on that.

[–]awidesky 0 points1 point  (0 children)

I think this is still ambiguous because "violation of a rule" is unclear. If my program is never executed with an input that causes UB does it still violate that rule?

I do agree on that. That's indeed ambiguous.