DMD producing huge binaries

ZombineDev via Digitalmars-d digitalmars-d at puremagic.com
Fri May 20 08:53:08 PDT 2016


On Friday, 20 May 2016 at 15:39:18 UTC, Rene Zwanenburg wrote:
> On Friday, 20 May 2016 at 12:08:37 UTC, ZombineDev wrote:
>> @Rene
>> How do you expect the compiler to know the exact return type, 
>> only by looking at this signature:
>> auto transmogrify(string str);
>>
>> A possible implementation might be this:
>> auto transmogrify(string str)
>> {
>>    return str.map!someFunc.filter!otherFunc.joiner();
>> }
>>
>> or something completly different.
>
> I was thinking of something along the lines of this:
>
> =======
> size_t frobnicate(int i)
> {
> 	return 0;
> }
>
> auto frobnicator(T)(T t)
> {
> 	static struct Result
> 	{
> 		int index;
> 		
> 		size_t front()
> 		{
> 			return frobnicate(index);
> 		}
> 		
> 		enum empty = false;
> 		
> 		void popFront()
> 		{
> 			++index;
> 		}
> 	}
> 	
> 	return Result(t.index);
> }
> =======
>
> Automatically generating a header with DMD gives me:
>
> =======
> size_t frobnicate(int i);
> auto frobnicator(T)(T t)
> {
> 	static struct Result
> 	{
> 		int index;
> 		size_t front();
> 		enum empty = false;
> 		void popFront();
> 	}
> 	return Result(t.index);
> }
> =======
>
> Now frobnicator returns a different type for the same T 
> depending on whether you're using the .d or the .di file. I'm 
> not sure if this is a problem, but it sounds like something 
> that can come back to bite you in edge cases.

The only issue is code bloat. It also happens with separate 
compilation, becuase the compiler can't know if the template has 
already been instantiated in a different compilation unit.
Only in a single compilation unit/invocation the compiler can 
reliably see all the places where the same template instance is 
used. In that case, the actual mangled name shouldn't matter, 
AFAIU.


More information about the Digitalmars-d mailing list