<!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>