@@new
André Bargull
andre.bargull at udo.edu
Thu Jun 19 06:39:18 PDT 2014
> > The most important thing here (I agree with Andreas R.) is -- if
> possible -- avoiding uninitialized object observability.
>
> I agree that uninitialized observability is a pain and has been a
> on-going source
> of reentrancy bugs in the the more complex built-in constructors. I
> want to
> explore whether making the constructor arguments available to @@create
> provides
> an alternative way to eliminate that issue.
That means depending on the class/built-in a subclass needs to override
either the @@create method or the constructor function or both?
For example let's take the Map built-in. The @@create method will
initialise [[MapData]] to an empty list early on, that way Map instances
are never observed uninitialised. Processing the iterable argument to
fill the Map may either occur in @@create or in the Map constructor
function. Subclasses will need to consult the specification to find out
which method needs to be overridden if the iterable argument needs to be
preprocessed.
For other (more special) built-ins like String/Number/Function/...,
@@create will need to perform the complete initialisation including
processing the arguments. Otherwise uninitialised objects are still
observable. As a result subclasses are required to override @@create and
overriding the constructor is a no-op (w.r.t. arguments handling).
More information about the es-discuss
mailing list