Compiler patch for runtime reflection
Vladimir Panteleev
vladimir at thecybershadow.net
Sun Oct 23 05:51:50 PDT 2011
On Sun, 23 Oct 2011 14:06:42 +0300, Timon Gehr <timon.gehr at gmx.ch> wrote:
>> I don't see how my generateReflectionForModule idea requires any
>> modification of the reflected code. The module can generate RTTI for all
>> types used recursively from the starting point. If more precision is
>> needed, it can be specified as generateReflectionForModule/etc.
>> parameters.
>>
>
> The module can generate RTTI for all types recursively from the starting
> point iff that information is statically available. It does not have to
> be. A module that comes as .di + static library binary could return a
> reference to a private class that has a publicly exported base class.
> How would you generate RTTI for a statically invisible class?
The only way to prevent such problems is to have RTTI generated by the
compiler and enabled always or by default.
However, is such functionality even desirable? It is equivalent to having
a back door for accessing private class members (implementation details in
general).
--
Best regards,
Vladimir mailto:vladimir at thecybershadow.net
More information about the Digitalmars-d
mailing list