On Tue, 18 Mar 2014 18:47:18 +0100 Dimitry Andric wrote:
> On 18 Mar 2014, at 16:38, Tijl Coosemans <t...@freebsd.org> wrote:
>> With -fms-extensions clang 3.4 seems to define a built-in type named
>> __wchar_t.  This conflicts with __wchar_t in /usr/include/machine/_types.h
>> 
>> 
>> % cat test.c 
>> #include <sys/types.h>
>> % cc -c test.c -fms-extensions
>> In file included from test.c:1:
>> In file included from /usr/include/sys/types.h:44:
>> In file included from /usr/include/machine/endian.h:6:
>> In file included from /usr/include/x86/endian.h:37:
>> In file included from /usr/include/sys/_types.h:33:
>> In file included from /usr/include/machine/_types.h:6:
>> /usr/include/x86/_types.h:145:14: error: cannot combine with previous 'int'
>>      declaration specifier
>> typedef int             __wchar_t;
>>                        ^
>> 1 error generated.
>> 
>> 
>> What is the best way to resolve this?  Maybe rename the FreeBSD __wchar_t
>> to ___wchar_t?
> 
> Maybe just don't use -fms-extensions, at least not in combination with
> our system headers?  It is not needed for the base system anymore, see
> r260020, r260102 and r260322.  E.g. clang does not need -fms-extensions
> to stop complaining about anonymous unions, like gcc.
> 
> Otherwise, the only solution is indeed to rename our __wchar_t.  The
> following type names are reserved in Microsoft mode:
> 
> __int8
> __int16
> __int32
> __wchar_t

I have a port that uses -fms-extensions for something like this:

struct a {
        int aa;
};
struct b {
        struct a;
        int bb;
};
void
test( struct b *arg ) {
        arg->aa = 1; /* clang errors on this without -fms-extensions */
        arg->bb = 2;
}

Maybe it's a bug (inconsistency) in clang that it accepts the definition
of struct b but it doesn't accept accessing the aa field?  It cannot be
accessed in any other way than in the example above.

Anyway, -fms-extensions should work too so I think I'll go ahead and
rename __wchar_t.
_______________________________________________
freebsd-toolchain@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-toolchain
To unsubscribe, send any mail to "freebsd-toolchain-unsubscr...@freebsd.org"

Reply via email to