Date: Sat, 29 Jul 2017 22:16:46 -0700 From: Mark Millard <markmi@dsl-only.net> To: Tijl Coosemans <tijl@FreeBSD.org> Cc: toolchain@FreeBSD.org, Dimitry Andric <dim@FreeBSD.org> Subject: Re: [package - head-amd64-default][games/simutrans] Failed for simutrans-120.2.2 in build Message-ID: <C6F2D60F-5FEC-4858-99B8-E3B04EB467A6@dsl-only.net> In-Reply-To: <3E4B30BB-A9E5-480E-835D-DA6797FC230C@dsl-only.net> References: <201707272142.v6RLg1G4099900@beefy12.nyi.freebsd.org> <20170728135510.2c6de57f@kalimero.tijl.coosemans.org> <F47E0976-759A-45A0-8421-8FD4402A9980@FreeBSD.org> <20170729015914.184c2660@kalimero.tijl.coosemans.org> <D780E949-FB27-4A84-8E10-75D1E7A8EA06@dsl-only.net> <20170729212706.33841c4c@kalimero.tijl.coosemans.org> <D4345C7E-29E1-42CC-B970-82EF6439237A@dsl-only.net> <20170729230641.6cecd29d@kalimero.tijl.coosemans.org> <3E4B30BB-A9E5-480E-835D-DA6797FC230C@dsl-only.net>
next in thread | previous in thread | raw e-mail | index | archive | help
[I oversimplified one point.] On 2017-Jul-29, at 3:24 PM, Mark Millard <markmi at dsl-only.net> wrote: > On 2017-Jul-29, at 2:06 PM, Tijl Coosemans <tijl at FreeBSD.org> = wrote: >=20 >> On Sat, 29 Jul 2017 12:43:59 -0700 Mark Millard <markmi at = dsl-only.net> wrote: >>> On 2017-Jul-29, at 12:27 PM, Tijl Coosemans <tijl at FreeBSD.org> = wrote: >>>>> . . . >>>>=20 >>>> But none of this should be exposed to C++98 code. =20 >>>=20 >>> Only if the compiler is told to compile the code as >>> C++98 code or it is known that C++98 is the default >>> target version for the compiler. >>>=20 >>> The compiler command that you published as part of >>> the error report provides no such explicit control >>> of what language/library version rules are to be >>> used: >>>=20 >>> c++ -O2 -pipe -fstack-protector -fno-strict-aliasing -O2 -pipe = -fstack-protector -fno-strict-aliasing -DNDEBUG -Wall -W -Wcast-qual = -Wpointer-arith -Wcast-align -DUSE_C -DREVISION=3D8163 = -I/usr/local/include/SDL -I/usr/local/include -D_REENTRANT = -D_THREAD_SAFE -DCOLOUR_DEPTH=3D16 -c -MMD -o = build/default/squirrel/squirrel/sqvm.o squirrel/squirrel/sqvm.cc >>>=20 >>> So if the default is to compile for C++11 or later >>> the results of using the C++11 rules are the expected >>> results here. >>>=20 >>>> These names were not >>>> reserved in the C++98 standard so C++98 code is free to use them. = If >>>> libc++ cannot compile such valid C++98 code it is simply not = compliant >>>> with that standard. Note that in this case we were lucky to see a >>>> diagnostic. C++98 code may use these names in a way that doesn't = cause >>>> an error. Who's going to review our 27000 ports to make sure they = are >>>> still compiled correctly? =20 >>>=20 >>> Unless you tell the compiler to use C++98 rules you get the >>> rules of whatever version it targets by default. >>>=20 >>>>> For targeting -std=3Dc++11 or later in compiles >>>>> __enable_if and __is_arithemtic and __type >>>>> would be wrong in these places and require >>>>> code using the standard to use the names >>>>> that have the __ prefixes, in violation of >>>>> the standard's specifications. That includes >>>>> having no explicit -std=3D but depending on a >>>>> default that happens to end up with c++11 or >>>>> later as the version to target. =20 >>>>=20 >>>> Of course things like __enable_if are for internal use only. In = C++11 >>>> mode enable_if needs to be made available. =20 >>>=20 >>> And if the compiler default version target was >>> C++11 or later then what it did was what it should >>> have done. >>=20 >> Since you've written three times the same thing here let me reply = with >> three times the same thing: >=20 > Very true that I should not have bothered to try to > write something in all 3 places. >=20 > Your sequence gives additional information in each > of your 3 and so does not have my mistake. >=20 >> - Adding -std=3Dc++98 still fails to compile with the same errors. >>=20 >> - The compiler default is C++98: >> % c++ -x c++ -E -dM /dev/null | grep __cplusplus >> #define __cplusplus 199711L >>=20 >> - A quick look at the libc++ headers makes it immediately obvious = they >> expose and use C++11 features in C++98 mode. >>=20 >> And of course these were the very first things I checked before = writing >> my first email. >=20 > Good to know. >=20 > Under C++03 (and before) the basic requirements for macro names > are different (and matching what you are attempting): 17.4.3.1.1 > Macro Names says: >=20 > "A translation unit that includes a header shall not contain any = macros > that define names declared or defined in that header." >=20 > This greatly narrows the range of potential conflicts. >=20 > (But my understanding is that the rule was changed in part > because headers implicitly including content from other > standard headers is classified as okay in the early standards > as well and so overall the early standards were not fully > consistent, given how macros are specified to operate.) >=20 > There is the issue that even for C++03 and before: >=20 > "Clauses 18 through 27 do not specify the representation of classes > . . . An implementation may define static or non-static class members, > or both, as needed to implement the semantics of the member functions > specified in clauses 18 through 27." >=20 > So far as I know (unlike C) C++ makes no requirements that imply > the "extra" names involved in such must not be valid names in > programs, although it allows for such. (Such as using __ prefixes > or _<upper-case-letter> prefixes. Or for the global namespace: _ > prefixes. These are reserved but not required to be used by the > implementation from what I can tell.) So as far as I know > such "pollution" is an implementation quality issue but not a > standards conformance issue so long as the naming does not > mess up programs' use of the required naming from the standard. >=20 > So what you report about "type" being in use as an identifier > in the library of itself looks greatly unfortunate to me but also > does not seem to be a violation of the C++98, C++03, or other > standard versions. (Drat.) >=20 > I've also not found anything indicating that extra declarations > and definitions (such as from C++11 for compiles targeting C++98 > or C++03) would be a violation of a standard, such as C++98 or > C++03. (At least for any addition that does not prevent programs' > use of required aspects of the library.) >=20 > This was a surprise to me. But so far I've not found anything to > point to for a "this is wrong by the rules of the standard" > submittal against libc++. That makes it less likely to change in > the future. I should have noted two contexts that do explicitly specify that "names reserved to the implementation" be used: 17.4.4.7 Derived classes says both: "It is unspecified whether a class in the C++ Standard Library it itself derived from other classes (with names reserved to the implementation)." "It is unspecified whether a class described in the C++ Standard Library as derived from another class is derived from that class directly, or through other classes (with names reserved to the implementation) that are derived from the specified base class." These quotes are from ISO/EIC 14882:2003. More modern ones that I've looked at also include a 3rd context: "Implementations are permitted to provide addition predefined variables with names that are reserve to the implementation (5.10)." Otherwise having extra names is not restricted to using "names reserved to the implementation", even in C++98 and C++03 as far as I can tell. (I do not have a copy of the C++98 standard with me so I'm using C++03's instead.) =3D=3D=3D Mark Millard markmi at dsl-only.net
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?C6F2D60F-5FEC-4858-99B8-E3B04EB467A6>