Flávio Etrusco wrote:
On Fri, Apr 16, 2010 at 4:54 PM, José Mejuto <joshy...@gmail.com> wrote:
Hello FPC-Pascal,

Friday, April 16, 2010, 9:06:45 PM, you wrote:

FE> Published methods can be found with TObject.MethodAddress, that's how
FE> the lfm hook event handlers (and why Form event handlers are
FE> published).

Yes, but thats for streamable objects like TForm, or any component,
but I think that that's not the case of TWSxxxx objects which are the
widgetset interface, and also all of them are "class procedure".

Marc says in Lazarus that a "virtual class tree" is formed with such
published methods, I do not know the need of it or the mission, but if
it is OK it is OK ;) for me.

--
Best regards,
 José

Sure, I was just saying that in a different context. I found Marc's
observation very weird, and I'm (still) going to check it.

Its not my observation, but my implementations :)



Imagine the following "base" widgetdset tree (best viewed with a fixed font)

TWSBase
 |
 + TWSWinControl
 |  |
 |  + TWSButton
 |
 + TWSSomeOther


Now we have a widgetset, say XXX, implementing these classes

when you use the normal inheritence you get a tree like:

TWSBase - TWSXXXBase
 |
 + TWSWinControl - TWSXXXWinControl
 |  |
 |  + TWSButton - TWSXXXButton
 |
 + TWSSomeOther - TWSXXXSomeOther

Now you see a problem here. You would expect TWSXXXButton to be derived from TWSXXXWinControl, but it isn't, so it doesn't have the TWSXXXWinControl implementation.

Now comes the "vitrual" class tree lazarus uses. Based on RTTI it creates its own VMT tables, rewriting the tree to:

TWSBase
 |
 + TWSXXXBase
    |
    + TWSWinControl
    |  |
    |  + TWSXXXWinControl
    |     |
    |     + TWSButton
    |        |
    |        + TWSXXXButton
    |
    + TWSSomeOther
       |
       + TWSXXXSomeOther


Now TWSXXXButton is derived from TWSXXXWinControl

Marc
_______________________________________________
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
http://lists.freepascal.org/mailman/listinfo/fpc-pascal

Reply via email to