Correct me, if I'm wrong, but in XE8'th flavour of FMX, Freeing component implicitly cause all its children (i.e. Components, to which the one, being deleted, is Parent) to be freed as well? Even if these ones are owned by some other component...
Correct me, if I'm wrong, but in XE8'th flavour of FMX, Freeing component implicitly cause all its children (i.e. Components, to which the one, being deleted, is Parent) to be freed as well? Even if these ones are owned by some other component...
What a twist!
http://www.youtube.com/watch?v=4LGu1sOvxYs
http://www.youtube.com/watch?v=4LGu1sOvxYs
What a twist!
http://www.youtube.com/watch?v=4LGu1sOvxYs
http://www.youtube.com/watch?v=4LGu1sOvxYs
If you're referring to what I think you are referring to, that's been there from the off, and follows the VCL (assuming you're talking about desktop/non-ARC)...
ReplyDeleteHm, I thought, that ownership chain ruled the object instances lifetime, not Parent-Children relations.
ReplyDeleteВсеволод Громов both do - the VCL behaviour follows similar logic for windows (HWNDs) at the API level.
ReplyDeleteChris Rolliston How does the parent-child relationship control TComponent descendants' lifetimes? I also thought it was ownership, always. I know in the VCL HWND changes require recreation of underlying resources, but not recreation of objects...
ReplyDeleteChris Rolliston but these handles are being recreated at need.
ReplyDeleteParent can be different from Owner. Last time I checked, which admittedly is ages ago, they were independent.
ReplyDeleteWhat's peculiar here, in FMX, if control C is owned by A, and parented by B, and B is being deleted, it will delete C as well (see DeleteChildren in pas source code).
ReplyDeleteI've encountered another side-effect of this approach, while working with third-party control. As soon as actual unparenting and deletion is (I think) delayed in FMX, I got strange situation, in which, despite C->Parent is assigned 0 before B is deleted, the deletion of B results in deletion of C anyway. But only if code is executed normally. If I set code breakpoint right at C->Parent = 0 line, then subsequent deletion of B does not result in deletion of C.
FMX sometimes is really annoying in side effects, caused by miscellaneous delayed operations executed in unexpected order.
David Millington , Jeroen Wiert Pluimers - I didn't claim the VCL follows the API 'logic' because it has to, just that it follows the same pattern: when a parent control is destroyed, it frees all its child controls irrespective of whether the child has an owner or not (see the implementation of TWinControl.Destroy); likewise, when a parent HWND is destroyed, it destroys all its child HWNDs.
ReplyDeleteMy guess is that the VCL designers were intentionally following the API pattern (perhaps recreating HWNDs at will wasn't implemented at that point in the pre-release code?), but that's just a guess. Personally I'd rather the behaviour wasn't like this (it still catches me out every so often), but that particular ship sailed 20 years ago...
Всеволод Громов - interesting, while I very much agree with your general point about side effects from out-of-order operations, I haven't actually seen your concrete example before though (so far as I know explicit unparenting operations don't ever get delayed, but I may be wrong). Do you have a test case?
ReplyDeleteI've tried to create sample, closely mimicking the 3-rd party control usecase. Unfortunately, 'feature' refuses to reproduce there.
ReplyDelete