<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">2013/2/27 deadalnix <span dir="ltr"><<a href="mailto:deadalnix@gmail.com" target="_blank">deadalnix@gmail.com</a>></span><br><blockquote class="gmail_quote" style="margin-top:0px;margin-right:0px;margin-bottom:0px;margin-left:0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div class=""><div class="h5">On Wednesday, 27 February 2013 at 06:15:29 UTC, dennis luehring wrote:<br>
<blockquote class="gmail_quote" style="margin-top:0px;margin-right:0px;margin-bottom:0px;margin-left:0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
Am <a href="tel:27.02.2013%2006" value="+12702201306" target="_blank">27.02.2013 06</a>:54, schrieb deadalnix:<br>
<blockquote class="gmail_quote" style="margin-top:0px;margin-right:0px;margin-bottom:0px;margin-left:0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><blockquote class="gmail_quote" style="margin-top:0px;margin-right:0px;margin-bottom:0px;margin-left:0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
In current D, the ambiguity is _already_ resolved - if you want<br>
to function<br>
address, use & operator.<br>
<br>
</blockquote>
<br>
D behave very much like C on that regard, so I don't really see<br>
how this can be true.<br>
</blockquote>
<br>
void (*functionPtr)();<br>
<br>
//both are valid and working in C<br>
functionPtr xyz = &foo;<br>
functionPtr zxy = foo; //<- this is solved in D<br>
</blockquote>
<br></div></div>
I don't think D solved that. Only partially. Both are conflated here for instance :<br>
<br>
void foo() {}<br>
foo(); <=> (&foo)();<br>
<br>
Is another presentation of the same conflation.<br>
<br>
The DIP propose to effectively solve that by removing completely the entity represented by foo in &foo . You can't have conflation with something that do not exists.<br>
</blockquote></div><br></div><div class="gmail_extra">In D, function symbol and function pointer are distinct entities. The former is just accessible by its name and it has _no_ runtime value. The latter is a runtime value which generated by applying address operator to function symbol.</div>
<div class="gmail_extra"><br></div><div class="gmail_extra">Also in C, essentially these entities are distinct, but C's semantic analyzer will implicitly apply address operator against the use of function name. Finally 'foo' has the same meaning as '&foo'. That has still introduced confusion to many programmer's.</div>
<div class="gmail_extra"><br></div><div class="gmail_extra">Back to D, the two entities explicitly separated syntactically, and the use of function name is newly assigned as 'property call' (note that, the definition of 'property' is still debatable). So, applying DIP27 is just equivalent to discarding property feature.<br>
</div><div class="gmail_extra"><br></div><div class="gmail_extra">Kenji Hara</div></div>