[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