<p>Am 23.05.2016 11:37 schrieb "LacaK" <<a href="mailto:lacak@zoznam.sk">lacak@zoznam.sk</a>>:<br>
><br>
> Dňa 20.5.2016 o 14:42 Sven Barth napísal(a):<br>
><br>
>><br>
>> Am 19.05.2016 08:52 schrieb "LacaK" <<a href="mailto:lacak@zoznam.sk">lacak@zoznam.sk</a> <mailto:<a href="mailto:lacak@zoznam.sk">lacak@zoznam.sk</a>>>:<br>
>> ><br>
>> ><br>
>> >><br>
>> >> >> Additionally, it's possible that it's not possible to inline generic routines in regular routines,<br>
>> >> ><br>
>> >> > It is not my case.<br>
>> >> > I use this generic in another generic and then it is specialized in interface section of same unit.<br>
>> >> ><br>
>> >> > Later this specialized object is used in another class type, which comes after specialization.<br>
>> >> > So this object is not used in regular procedure, but in methods of another class ...<br>
>> >> ><br>
>> >> > I did also attempt to put all this stuff (with generics and specializations) into separate unit and then I have used this unit ( in interface section ) in "main" unit<br>
>> >> > But still does not inline ...<br>
>> >><br>
>> >> You need to call the function in another unit than where the specialization is.<br>
>> >><br>
>> > Yes I do it so (in attached example it is in one unit, but in my real generic and specialization is in separate unit, that is used by another in interface section)<br>
>> ><br>
>> ><br>
>> >> Maybe provide a small (compileable) example that shows what you're doing so that we can check that ourselves.<br>
>> >><br>
>> > Attached<br>
>><br>
>> Moving GT and T1 to a separate unit results in inlined code, as expected (tested with 2.6.4, 3.0.0 and 3.1.1), also if T2 is in another separate unit.<br>
>><br>
><br>
> Yes I can confirm, that this works .<br>
> So if I have specialized object type (with inline methods), which is used by another type in same unit inline methods are not inlined ?<br>
> (assume, that specialized type is defined before type which uses it in interface section and is implemented also before in implementation section)</p>
<p>Your assumption is correct.</p>
<p>> Can this be fixed or is this some kind of design limitation, which can not be bypassed (nor in future) ?</p>
<p>This *might* get fixed in the future. After all by definition inlining is completely up to the compiler, so even if you add "inline" to some method or function there is no guarantee that it will be inlined.</p>
<p>Regards,<br>
Sven</p>