qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH 2/3] qobject: assume base of a qobject is at off


From: Paolo Bonzini
Subject: Re: [Qemu-devel] [PATCH 2/3] qobject: assume base of a qobject is at offset 0
Date: Wed, 21 Mar 2018 15:49:13 +0100
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0

On 21/03/2018 15:21, Marc-André Lureau wrote:
>>> Yeah, I tried a few of those approaches. Here the problem is that
>>> QObject doesn't have base field. So you get a compile time error with
>>> a QObject * as argument.
>>
>> So the compiler requires &(x)->base to resolve even when it is not on the
>> branch that gets selected?
> 
> Unfortunately, yes, all branches must compile apparently (I know)...

Ugh, and that's indeed true of _Generic too.  These don't compile:

  struct s1 { int y; };
  struct s2 { int z; };

  #define f(x)  _Generic(x, struct s1: (x).y, struct s2: (x).z)

  int f1(struct s1 *s) { return f(*s); }
  int f2(struct s2 *s) { return f(*s); }

:(  Then I guess Marc-André's realization is ugly but unavoidable.

Paolo



reply via email to

[Prev in Thread] Current Thread [Next in Thread]