Deutsch   English   Français   Italiano  
<877c35pa37.fsf@nosuchdomain.example.com>

View for Bookmarking (what is this?)
Look up another Usenet article

Path: news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail
From: Keith Thompson <Keith.S.Thompson+u@gmail.com>
Newsgroups: comp.lang.c
Subject: Re: Bart's Language
Date: Sun, 27 Apr 2025 14:29:16 -0700
Organization: None to speak of
Lines: 51
Message-ID: <877c35pa37.fsf@nosuchdomain.example.com>
References: <vracit$178ka$1@dont-email.me> <vrbo88$1j3e0$1@paganini.bofh.team>
	<vrbtve$2irc9$1@dont-email.me> <vrc2d5$1jjrf$1@paganini.bofh.team>
	<vrc4eb$2p28t$1@dont-email.me> <vri6co$26v8m$2@paganini.bofh.team>
	<87a59fs2xm.fsf@nosuchdomain.example.com> <86wmb58mi6.fsf@linuxsc.com>
MIME-Version: 1.0
Content-Type: text/plain
Injection-Date: Sun, 27 Apr 2025 23:29:18 +0200 (CEST)
Injection-Info: dont-email.me; posting-host="d1d161cc54a14e120d5ad6e14bc561fa";
	logging-data="1720196"; mail-complaints-to="abuse@eternal-september.org";	posting-account="U2FsdGVkX1+Xway3o8yTUgor71Qv3uEF"
User-Agent: Gnus/5.13 (Gnus v5.13)
Cancel-Lock: sha1:QcmNdkV5YBKWngMOO5vCNCyXhuI=
	sha1:CHfkfNljxA8pSA7Qd3LeXWBHUQw=

Tim Rentsch <tr.17687@z991.linuxsc.com> writes:
> Keith Thompson <Keith.S.Thompson+u@gmail.com> writes:
>> antispam@fricas.org (Waldek Hebisch) writes:
>> [...]
>>> Well, it is rather easy to see if variable is used within its
>>> own initialization, so practically it is minor gap.  Of course,
>>> there is problem with C standard:  IIUC depending on rest of
>>> the code declarations as above are merely undefined behaviour
>>> or even produce unspecified value.  So C compiler is
>>> forbidden to stop compilation are report compile time error.
>>
>> Valid responses to undefined behavior include "terminating a translation
>> or execution (with the issuance of a diagnostic message)".
>
> That's true, but doing so is allowed only if the circumstances
> of undefined behavior have occurred.  In the case of compiling
> a declaration such as
>
>     int a = a;
>
> no undefined behavior has as yet occurred.

N3096 6.3.2.1p2 (lvalue conversion):

    If the lvalue designates an object of automatic storage duration
    that could have been declared with the register storage class (never
    had its address taken), and that object is uninitialized (not
    declared with an initializer and no assignment to it has been
    performed prior to use), the behavior is undefined.

Strictly speaking, `a` doesn't meet the definition of
"uninitialized", since it is declared with an initializer, but
its value is accessed before the initialization has been executed.
I'm not entirely certain that `int a = a;` has undefined behavior,
but it's unclear that the behavior is defined.

>> In other
>> words, if a compiler is able to prove that a program has undefined
>> behavior (that will occur on each execution), it can reject it at
>> compile time.
>
> The program can be rejected, but not because of the rule about
> terminating a translation.  The program can be rejected because
> the program is not strictly conforming, and implementations are
> not required to accept programs that are not strictly conforming.

I disagree, but we've gone over this before with no resolution.

-- 
Keith Thompson (The_Other_Keith) Keith.S.Thompson+u@gmail.com
void Void(void) { Void(); } /* The recursive call of the void */