[devel] union in C99
Led
=?iso-8859-1?q?ledest_=CE=C1_gmail=2Ecom?=
Вт Сен 23 22:32:39 MSD 2008
On Tuesday, 23 September 2008 21:22:47 Kirill A. Shutemov wrote:
> On Tue, Sep 23, 2008 at 07:22:41PM +0300, Led wrote:
> > потребовалось сделать что-то типа такого:
> > - int i_bframe_adaptive;
> > + union {
> > + int i_bframe_adaptive;
> > + int b_bframe_adaptive __attribute__((__deprecated__));
> > + };
> >
> > это поля structx 264_param_t . Но при -std=c99 получаем:
> > libx264.c:165: error: 'x264_param_t' has no member named
> > 'i_bframe_adaptive'
> >
> > Как это сейчас правильно реализуется?
>
> Как вариант, можно попробовать что-то типа такого:
>
> - int i_bframe_adaptive;
> +#define i_bframe_adaptive bframe_adaptive.i
> +#define i_bframe_adaptive bframe_adaptive.b
> + union {
> + int i;
> + int b __attribute__((__deprecated__));
> + } bframe_adaptive;
Спасибо. Да, такой вариант я тоже рассматривал, но с define'ами не очень
красиво получается - в этом случае будет тупо подменяться все
i_bframe_adaptive/b_bframe_adaptive, даже если это не поля структуры
x264_param_t. Пока остановился на варианте:
+#ifdef __GNUC__
+ __extension__ union {
+ int i_bframe_adaptive;
+ int b_bframe_adaptive __attribute__((__deprecated__));
+ };
+#else
int i_bframe_adaptive;
+#endif
--
Led
Подробная информация о списке рассылки Devel