struct { int a, b; } f(int x, int y) // OK
{
return { x, y };
}
auto g(int x, int y) -> struct { int a, b; } // error C2332
{
return { x, y };
}
int main()
{
auto n = f(1, 2).a; // OK
}
My compiler is VC++ 2013 RC.
Why is g
wrong while f
is OK?
Is this a bug of VC++?
Actually, in C++, it's illegal to define a type in a parameter or return type, named or not. See C++11[diff.decl]:
Change: In C++, types may not be defined in return or parameter types. In C, these type definitions are allowed
So the actual problem is the first case being accepted, not the second one being rejected.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With