Deutsch English Français Italiano |
<vt6gp0$16ejo$1@dont-email.me> View for Bookmarking (what is this?) Look up another Usenet article |
Path: ...!eternal-september.org!feeder3.eternal-september.org!news.eternal-september.org!eternal-september.org!.POSTED!not-for-mail From: bart <bc@freeuk.com> Newsgroups: comp.lang.c Subject: Re: "A diagram of C23 basic types" Date: Wed, 9 Apr 2025 20:11:28 +0100 Organization: A noiseless patient Spider Lines: 105 Message-ID: <vt6gp0$16ejo$1@dont-email.me> References: <87y0wjaysg.fsf@gmail.com> <vsj1m8$1f8h2$1@dont-email.me> <vsj2l9$1j0as$1@dont-email.me> <vsjef3$1u4nk$1@dont-email.me> <vsjg6t$20pdb$1@dont-email.me> <vsjgjn$1v1n4$1@dont-email.me> <vsjk4k$24q5m$1@dont-email.me> <vsjlcp$230a5$1@dont-email.me> <vsjmdl$277bk$1@dont-email.me> <VsdHP.1828827$TBhc.1078002@fx16.iad> <vskjlo$34st8$1@dont-email.me> <20250402220614.431@kylheku.com> <85mscxlqnb.fsf@nosuchdomain.example.com> <vsl9sn$3vdjj$2@dont-email.me> <20250403121946.134@kylheku.com> <vsms75$1i8ud$1@dont-email.me> <vsnhq6$291i3$4@dont-email.me> <20250409124900.00000fa1@yahoo.com> <vt5r34$inuo$7@dont-email.me> <vt6an7$13tvo$1@dont-email.me> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit Injection-Date: Wed, 09 Apr 2025 21:11:29 +0200 (CEST) Injection-Info: dont-email.me; posting-host="86cd0c292c528f4b59336ead25869004"; logging-data="1260152"; mail-complaints-to="abuse@eternal-september.org"; posting-account="U2FsdGVkX18qPmtnAqOwNI3g23QOXhM5" User-Agent: Mozilla Thunderbird Cancel-Lock: sha1:fqQBQX+l0mew6zjktM5Mkm6mqfU= Content-Language: en-GB In-Reply-To: <vt6an7$13tvo$1@dont-email.me> Bytes: 5007 On 09/04/2025 18:26, BGB wrote: > On 4/9/2025 8:01 AM, David Brown wrote: >> On 09/04/2025 11:49, Michael S wrote: >>> On Fri, 4 Apr 2025 02:57:10 -0000 (UTC) >>> Lawrence D'Oliveiro <ldo@nz.invalid> wrote: >>> >>>> On Thu, 3 Apr 2025 21:48:40 +0100, bart wrote: >>>> >>>>> Commas are overwhelmingly used to separate list elements in >>>>> programming languages. >>>> >>>> Not just separate, but terminate. >>> >>> I disagree. I am in favor of optional trailing commas rather than >>> mandatory ones. >> >> I am certainly in favour of them for things like initialiser lists and >> enum declarations. >> >>> >>>> All the reasonable languages allow >>>> trailing commas. >>> >>> Are your sure that C Standard does not allow trailing commas? >>> That is, they are obviously legal in initializer lists. >>> All compilers that I tried reject trailing comma in function calls. >>> >> ... >>> But is it (rejection) really required by the Standard? I don't know. >>> >>> >> >> Yes. The syntax (in 6.5.2p1) is : >> >> postfix-expression: >> ... >> postfix-expression ( argument-expression-list opt ) >> ... >> >> argument-expression-list : >> argument-expression >> argument-expression-list , argument-expression >> >> >> >> I don't think it is unreasonable to suggest that it might be nice to >> allow a trailing comma, at least in variadic function calls, but the >> syntax of C does not allow it. >> > > Yeah, pretty much. > > > It might have also been interesting if C allowed optional named arguments: > int foo(int x=3, int y=4) > { > return x+y; > } > > foo() => 7 > foo(.y=2) => 5 > > Likely would be following any fixed arguments (if present), and likely > (for sake of implementation sanity) named arguments and varargs being > mutually exclusive (alternative being that named arguments precede > varargs if both are used). > > Well, at least ".y=val" as "y: val" likely wouldn't go over well even if > it is what several other languages with this feature used (well or, > "y=val", which is used in some others). > > In the most likely case, the named argument form would be transformed > into the equivalent fixed argument form at compile time. > So: "foo(.y=2)" would be functionally equivalent to "foo(3,2)". There are all sorts of problems in adding this to C. For example, this is legal: void F(int a, float b, char* c); void F(int c, float a, char* b); void F(int b, float c, char* a) {} The sets of parameter names are all different (and that's in the same file!); which is the official set? Another is to do with defining default values (essential if named arguments are to be fully used). First, similar thing to the above: void F(int a = x + y); void F(int a = DEFAULT); Which expression is to be used? Another is: void F(int a = x + y); ... void F(int a = x + y); The names 'x' and 'y' would normally refer to whatever x/y names are in scope at the declaration site. But if multiple declarations exist at different locations, different x/y could be visible; which will be used? Usually it is not meaningful to have x/y be the names in scope at the call-site; the author of the function will have no idea which x/y names will have in scope, if there are any at all.