<div class="gmail_quote">On 27 August 2012 03:51, Walter Bright <span dir="ltr"><<a href="mailto:newshound2@digitalmars.com" target="_blank">newshound2@digitalmars.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im">On 8/26/2012 5:06 PM, Manu wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">type that is technically equivalent, but foo's type would have the bonus default</blockquote></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im">
arg in its type record, just as a function pointer that were declared explicitly.<br>
</div></blockquote>
<br>
That's the way it used to work. The problem is, what are those types? Are they the same types or not? You're saying sometimes they are the same type, sometimes they are not. It's a mess.</blockquote><div><br>
</div><div>They are always equivalent. The default args are more like metadata.</div><div><br></div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">At what point does the compiler become confused? They never interact... The<br>
expected behaviour seems obvious to me, foo and bar should effectively be:<br>
    int function(int a = 1) foo = ..;<br>
    int function(int a) bar = ...;<br>
</blockquote>
<br></div>
It seems obvious only in the trivial case. What if you passed foo to a function? Now what type is it? What is the mangling for the type?</blockquote><div><br></div><div>Well the function you pass foo to will define the type is receives.</div>
<div>If it receives by template, then it'll receive the default args, if it defines the function pointer type it receives explicitly (or uses another compatible definition), the default args may be lost (or different) in the new instance across the function call.</div>
<div><br></div><div>I don't see why it needs to be mangled in. The linker doesn't care.</div><div><br></div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im">    The trouble for function pointers, is that any default args would need to be<br>
    part of the type, not the declaration.<br>
<br>
<br></div><div class="im">
I thought they were part of the type already? I would have thought that's where<br>
they should be. Why is their new home more 'proper'?<br>
</div></blockquote>
<br>
Because are the types the same or not?<br></blockquote><div><br></div><div>They're equivalent, but not identical; one has some metadata the other doesn't have.</div><div><br></div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im">    I know it broke code (for many others, too), and I'm very sorry about that,<br>
    but I don't see another way out.<br>
<br>
<br></div><div class="im">
It's a rather major breakage. I've seen you reject far more important changes<br>
solely on the grounds that they are a breaking change before...<br>
</div></blockquote>
<br>
Unfortunately, it was already broken, as the bug report showed. It's a matter of where the crack shows up.<br></blockquote><div><br></div><div>Does the bug report actually demonstrate how it was causing anybody any problems? It seemed a rather contrived scenario that just illustrated that there was a bug.</div>
<div>Also, I think it could be fixed so the scenario in the bug report worked as expected (I still don't understand why it did't work in the first place).</div></div>