<!DOCTYPE html><html><head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<br>
<br>
<blockquote type="cite" cite="mid:CABR7qmfyp+sYhR_Jii_VqcCa9kdrBYSd5Tu+6norX2mh2gHkNw@mail.gmail.com">
<div style="font-family:Helvetica,Arial;font-size:13px">Understood,
and I remember the debates along these lines. But what I’m
hoping to suggest - maybe it’s simplistic - is to in no way
change how the language/VM implement this feature, but ‘just'
describe it differently without introducing a new concept
(‘implicit') to the poor developer. Eliminating a keyword and an
idea.</div>
</blockquote>
<br>
Indeed, we tried to do this many times, and came up short every
time. That's not to say there isn't a way, but we banged our heads
against it good and hard over a long time. <br>
<br>
If you look at my reply to (I think) David on another mail today,
you'll see that there really are three distinct situations
(identity, value but not implicitly constructible, value and
implicitly constructible) that have different treatments and
consequences. So this "extra concept" will show up somewhere, its
just a matter of where we can put it so that it seems least
annoying. We felt that making it a constructor modifier
"downleveled" its importance compared to making it a class modifier,
but the concept has to be there somewhere, unless we want to give up
on a lot of potential optimizations.<br>
<br>
There's a reason this has taken so long; the problem has layers of
subtlety that were difficult to tease apart. It was almost like a
Spanish Inquisition sketch: "The chief impediment to flattening is
identity. Identity and nullity. The three main impediments are
identity, nullity, and initialization safety. AMONGST our
impediments, are such diverse elements as identity, nullity,
initialization safety, and atomicity....<br>
<br>
Each time we discovered a new one, we tried various moves: denial,
lumping, and eventually, acceptance; then began the long slow
process of normalization. We *think* we've now gotten things so
that each axis is independent and is defined as a useful semantic
even separate from performance, but ... there could still be more
turns of this crank. <br>
<br>
(And, as a perverse incentive, the more clearly we separate the
various considerations, the more likely someone is to ask "surely we
can get rid of X, no?")<br>
<br>
<br>
</body>
</html>