<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On 20 March 2016 at 20:06, Johan Engelen via Digitalmars-d <span dir="ltr"><<a href="mailto:digitalmars-d@puremagic.com" target="_blank">digitalmars-d@puremagic.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div class=""><div class="h5">On Sunday, 20 March 2016 at 17:57:12 UTC, Vincent R wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
On Sunday, 20 March 2016 at 16:16:18 UTC, Marco Leise wrote:<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
Am Sun, 20 Mar 2016 11:28:19 +0000<br>
schrieb Vincent R <<a href="mailto:lol@dlang.org" target="_blank">lol@dlang.org</a>>:<br>
<br>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
Hi,<br>
<br>
I would like to start a new project (a bonjour/zeroconf wrapper<br>
and a gui browser using it).<br>
For the gui part I would like to use my existing skills using<br>
wxWidgets wrapper (wxD).<br>
So I have started to report a problem a few months ago:<br>
<a href="https://forum.dlang.org/post/rtarlodeojnmedgsnscb@forum.dlang.org" rel="noreferrer" target="_blank">https://forum.dlang.org/post/rtarlodeojnmedgsnscb@forum.dlang.org</a><br>
<br>
But so far(DMD32 D Compiler v2.070.2) it's still not fixed.<br>
Do you think it will be fixed one day ?<br>
<br>
Thanks<br>
</blockquote>
<br>
Yes, I think it will be fixed one day, since - as you know<br>
by reading the very thread you linked - it is already reported<br>
and the GDC developers chimed in and considered it critical.<br>
There are also 118 open critical/blocker bugs that were<br>
reported before yours. Most of them by people here on the<br>
forums and you would need to explain to us why your bug<br>
deserves higher attention than the others (154 in total).<br>
<br>
Dlang is free open-source software and there is only a hand full of people who are fixing bugs in the compiler just for the sake of improving it. Most people contribute occasionally when they are interested in a solution to a particular problem.<br>
<br>
If you really need this fixed now ... you know the drill. I suggest you analyze the problem and start a discussion about it. Honestly asking why the compiler emits duplicate symbols in a reduced test case might have yielded you some good responses from the people who wrote the code.<br>
</blockquote>
<br>
Ok first maybe it's already reported to GDC but to me it's not only a gdc bug since it also happens with dmd. So I don't know how bugs are fixed in the differents compilers but I suppose they share the same frontend (maybe I am mistaken) and in this case I prefer not to wait for gdc developers to fix it but to see if for instance some dmd developers have some time to fix it.<br>
I just want to use the language and don't have time to dig inside its inner workings, so I think D is not for me. This project was the opportunity to learn the language by fixing an unmaintained library (wxD) but it's not as easy as I thought.<br>
</blockquote>
<br></div></div>
What may speed-up bug fixing a lot is preparing a nice testcase that is *as small as possible*.<br>
As you can see in the bug report [1], there is already a testcase. It is a good start, but it is not very minimal: contains a lot of comments etc. That is a lot of distraction / bother (for me at least). One way to help here is to minimize it further, and distill it down to the essential thing that appears to trigger the bug. You can do that without knowing any compiler internals.<br>
It can be very time consuming to make such a testcase, which may discourage developers fixing of your bug.<br>
<br>
[1] <a href="https://issues.dlang.org/show_bug.cgi?id=15324" rel="noreferrer" target="_blank">https://issues.dlang.org/show_bug.cgi?id=15324</a><br>
</blockquote></div><br></div><div class="gmail_extra"><br></div><div class="gmail_extra">I don't think it's a compiler bug, but it would help indefinitely if only the compiler semantic passes checked for conflicting function overrides upon declaration, rather than when they are called.<br><br></div><div class="gmail_extra">I can distil test case down to:<br><br>---<br>struct MultiIndexContainer()<br>{<br>    bool contains(int k) const<br>    {<br>        auto r = true;<br>        return r;<br>    }<br><br>    bool contains(int k) const<br>    {<br>        return false;<br>    }<br>}<br><br>void main()<br>{   <br>    MultiIndexContainer!() m;<br>}<br><br>---<br><br></div><div class="gmail_extra">If these were not templates, you'd get multiple definition errors.  But as that is not the case, these instead get put on comdat and merged. This as you've discovered gives you an entirely different kind of linker error, but it's simply a different side of the same coin.<br><br></div><div class="gmail_extra">The real bug is in the program logic.  Somehow, you have done the following (abridged)<br>---<br></div><div class="gmail_extra">alias Value ValueView;<br>alias typeof(Value.init) KeyType;<br></div><div class="gmail_extra">bool contains(ValueView value) const { ... }<br></div><div class="gmail_extra">bool contains(KeyType k) const { ... }<br></div><div class="gmail_extra">---<br></div><div class="gmail_extra"><br></div><div class="gmail_extra">You should add a constraint to ensure that ValueView != KeyType, or rename the methods so as they don't conflict, such as containsValue() and containsKey().<br></div><div class="gmail_extra"><br></div><div class="gmail_extra">I'll post this in the bug report too.<br></div><div class="gmail_extra"><br></div><div class="gmail_extra">Regards,<br></div><div class="gmail_extra">Iain.<br></div></div>