Re: C99 compliance for src/port/snprintf.c

From: Andres Freund <andres(at)anarazel(dot)de>
To: Thomas Munro <thomas(dot)munro(at)enterprisedb(dot)com>
Cc: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, David Steele <david(at)pgmasters(dot)net>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>
Subject: Re: C99 compliance for src/port/snprintf.c
Date: 2018-08-15 23:06:13
Message-ID: 20180815230613.4llck6f3fc5hpkkx@alap3.anarazel.de
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers pgsql-www

Hi,

On 2018-08-16 10:54:01 +1200, Thomas Munro wrote:
> Really? I am not an MSVC user but I had the impression that their C
> mode (/TC or files named .c) was stuck on C89/C90 as a matter of
> policy, as Herb Sutter explained here (though maybe the situation has
> changed since then):

They revised their position gradually, starting soon after. They claim
full C99 "language" (vs library, which is also pretty complete)
compliance now. I've not yet bothered to fully figure out which version
supports what however. Nor am I really sure about the whole flag thing,
it appears there's a gui element to choose, which we might need to mirror on
the xml level.

A bit of googling shows
https://docs.microsoft.com/en-us/previous-versions/visualstudio/visual-studio-2013/hh409293(v=vs.120)
"
Supports these ISO C99 language features:

_Bool

Compound literals.

Designated initializers.

Mixing declarations with code.
"

which I think is what we roughly would want. So it looks like msvc 2013
might be the relevant requirement.

> That's presumably why cfbot's appveyor build always complains about
> people declaring variables after statements.

IIRC even in older versions there's a flag to allow that.

> To allow that particular language feature, it looks like you have to
> tell it that your .c file is really a C++ program with /TP. But that
> opens a separate can of worms, doesn't it?

Yea, I don't think we want to go there by default soon.

Greetings,

Andres Freund

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Dian Fay 2018-08-15 23:46:49 docs: note ownership requirement for refreshing materialized views
Previous Message Tom Lane 2018-08-15 23:00:50 Re: C99 compliance for src/port/snprintf.c

Browse pgsql-www by date

  From Date Subject
Next Message Tom Lane 2018-08-16 00:15:58 Re: C99 compliance for src/port/snprintf.c
Previous Message Tom Lane 2018-08-15 23:00:50 Re: C99 compliance for src/port/snprintf.c