Make fn designators in ?: decay to ptrs

This
    _Generic((__typeof(1?f:f)*){0}, void (**)(void): (void)0);
should compile like it does in gcc and clang.
This commit is contained in:
Petr Skocik 2018-11-29 12:43:01 +01:00
parent 3058d4116e
commit 49dfb5755a
2 changed files with 29 additions and 5 deletions

View File

@ -5565,7 +5565,10 @@ static void expr_cond(void)
if (!g) if (!g)
gexpr(); gexpr();
if ( ((type1=vtop->type).t&VT_BTYPE)==VT_FUNC ) {
mk_pointer(&vtop->type);
type1=vtop->type; type1=vtop->type;
}
sv = *vtop; /* save value to handle it later */ sv = *vtop; /* save value to handle it later */
vtop--; /* no vpop so that FP stack is not flushed */ vtop--; /* no vpop so that FP stack is not flushed */
skip(':'); skip(':');
@ -5583,7 +5586,10 @@ static void expr_cond(void)
if (c == 1) if (c == 1)
nocode_wanted--; nocode_wanted--;
if ( ((type2=vtop->type).t&VT_BTYPE)==VT_FUNC ) {
mk_pointer(&vtop->type);
type2=vtop->type; type2=vtop->type;
}
t1 = type1.t; t1 = type1.t;
bt1 = t1 & VT_BTYPE; bt1 = t1 & VT_BTYPE;
t2 = type2.t; t2 = type2.t;
@ -5643,9 +5649,6 @@ static void expr_cond(void)
0<pointed_type(&type1)->ref->c ? 0<pointed_type(&type1)->ref->c ?
pointed_type(&type1)->ref->c : pointed_type(&type2)->ref->c; pointed_type(&type1)->ref->c : pointed_type(&type2)->ref->c;
} }
} else if (bt1 == VT_FUNC || bt2 == VT_FUNC) {
/* XXX: test function pointer compatibility */
type = bt1 == VT_FUNC ? type1 : type2;
} else if (bt1 == VT_STRUCT || bt2 == VT_STRUCT) { } else if (bt1 == VT_STRUCT || bt2 == VT_STRUCT) {
/* XXX: test structure compatibility */ /* XXX: test structure compatibility */
type = bt1 == VT_STRUCT ? type1 : type2; type = bt1 == VT_STRUCT ? type1 : type2;

View File

@ -1,6 +1,27 @@
#include <stdio.h> #include <stdio.h>
#include <assert.h> #include <assert.h>
char arr[1];
static void f (void){}
void (*fp)(void) = f;
void call_fp()
{
(fp?f:f)();
(fp?fp:fp)();
(fp?fp:&f)();
(fp?&f:fp)();
(fp?&f:&f)();
_Generic(0?arr:arr, char*: (void)0);
_Generic(0?&arr[0]:arr, char*: (void)0);
_Generic(0?arr:&arr[0], char*: (void)0);
_Generic(1?arr:arr, char*: (void)0);
_Generic(1?&arr[0]:arr, char*: (void)0);
_Generic(1?arr:&arr[0], char*: (void)0);
_Generic((__typeof(1?f:f)*){0}, void (**)(void): (void)0);
(fp?&f:f)();
(fp?f:&f)();
}
int main() int main()
{ {
int Count; int Count;