Error about @disabled constructor when there is a custom one
Dmitry Olshansky
dmitry.olsh at gmail.com
Tue Jan 22 11:02:04 PST 2013
22-Jan-2013 22:45, Minas Mina пишет:
> I have this structure:
>
> struct Scene
> {
> Array!Surface objects; // objects in the scene
> Array!Light lights; // lights in the scene
>
> /*private*/ BVHNode root; // root node of the BVH tree
>
> @disable this(); // disable the default constructor because space
> needs to be reserved for objects and lights
>
> this(size_t objectReserveSpace = 20, size_t lightReserveSpace = 3)
> {
> objects.reserve(objectReserveSpace);
> lights.reserve(lightReserveSpace);
> }
> }
>
>
>
> auto scene = Scene(); // error about @disabled constructor
That is the reason I dislike D's struct constructors as they currently
stand. Behold as the above is always rewritten to:
auto scene = Scene.init;
that is the same as
Scene scene;
And for Scene.init to work it has to have T.init for all of its members.
You've hit what I think is the design bug w.r.t. conflating 0-argument
constructor (including one with all default args) and T.init.
Short answer is: use static opCall instead. In the meantime let us all
pray some supreme gods so that 0-arg constructor support is introduced
later on. (because opCall doesn't have some powers of constructors such
as constructing const object)
> Yes, the default constructor is @disabled BUT I am not using that one. I
> want to use the other one - the custom constructor. I guess it signals
> an error because it has those defaults parameters. But shouldn't the
> compiler choose that one?
The official stance seems to be that the code shouldn't compile i.e.
accepts-invalid.
http://d.puremagic.com/issues/show_bug.cgi?id=3438
--
Dmitry Olshansky
More information about the Digitalmars-d
mailing list