Date: Fri, 1 May 2009 10:00:32 -0700 From: "Matthew Fleming" <matthew.fleming@isilon.com> To: "Bakul Shah" <bakul@bitblocks.com> Cc: FreeBSD Hackers <freebsd-hackers@freebsd.org> Subject: RE: C++ incompatability, was C99: Suggestions for style(9) Message-ID: <06D5F9F6F655AD4C92E28B662F7F853E02ACA852@seaxch09.desktop.isilon.com> In-Reply-To: <20090501163108.576465B3B@mail.bitblocks.com> References: <49F4070C.2000108@gmx.de><20090428114754.GB89235@server.vk2pj.dyndns.org> <49FAE4EA.1010205@gmx.de> <06D5F9F6F655AD4C92E28B662F7F853E02ACA843@seaxch09.desktop.isilon.com> <20090501163108.576465B3B@mail.bitblocks.com>
next in thread | previous in thread | raw e-mail | index | archive | help
> > [snip exciting discussion on style]
> >
> > > There are several C99 features used already, e.g. designated
initializers:
> > > bla bli = { .blub = "foo", .arr[0] = 42 };
> > > Do you suggest that this should not be used, because it is
inconsistent
> > > with all the other existing compound initialisations?
> >
> > Regarding this great feature of C99, sadly, it's not C++ compatible.
So
> > while designated initializers in a C source file are great, in a
header
> > file they will give a compile error if included in e.g. a C++ kernel
> > module (which otherwise would work fine).
>
> Why would you put initializers in a header file? If included
> in more than one file, the linker will complain that the
> initialized variable is multiply defined. If creating header
> files that get included in in only one file *and* you want to
> use initializers, why not use the right language for include
> file code.
Macros, like MALLOC_DEFINE, DB_COMMAND, etc., define initialized
variables when used. These can't be changed to use named initializers
without breaking C++.
Thanks,
matthew
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?06D5F9F6F655AD4C92E28B662F7F853E02ACA852>
