http://gcc.gnu.org/bugzilla/show_bug.cgi?id=49669

Jonathan Wakely <redi at gcc dot gnu.org> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |jason at gcc dot gnu.org

--- Comment #5 from Jonathan Wakely <redi at gcc dot gnu.org> 2011-07-07 
16:39:56 UTC ---
(In reply to comment #4)
> Say, since you're here, if I change the definition of x from "Foo[2]" to
> "std::array<Foo,2>", should I be allowed to initialize it with
> 
>    Goo::Goo() : x{{Foo(4), Foo(5)}} { }

I think that should be valid

> At the moment, _only_ the following seems to work:
> 
>    Goo::Goo() : x({{Foo(4), Foo(5)}}) { }

Hmm, that creates a temporary array<Foo,2> and uses that to initialize x, I
don't think that should be necessary.

> In particular, initialization of "Foo[2]" and "std::array<Foo,2>" is anything
> but "uniform" :-)

It will never be completely uniform, because one is an array and one is an
aggregate containing an array, but I think any of these should be valid:

struct Foo { explicit Foo(int) { } };

struct TwoFoo { Foo elems[2]; };

TwoFoo x{ Foo(1), Foo(1) };
TwoFoo y{ { Foo(1), Foo(1) } };
TwoFoo z( { Foo(1), Foo(1) } );    // ?

struct Goo
{
    Foo a[2];
    TwoFoo x, y, z;

    Goo()
        : a{ Foo(1), Foo(2) }
        , x{ Foo(1), Foo(2) }
        , y{ { Foo(1), Foo(2) } }
        , z( { Foo(1), Foo(2) } )  // ?
    { }
};

Jason, when you get around to looking at this ICE, could you comment on the
initialization question above?  Thanks!

Reply via email to