Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Investigate a sync way to access if a Node is connected to a Display #1620

Open
zepumph opened this issue Mar 13, 2024 · 2 comments
Open

Investigate a sync way to access if a Node is connected to a Display #1620

zepumph opened this issue Mar 13, 2024 · 2 comments

Comments

@zepumph
Copy link
Member

zepumph commented Mar 13, 2024

From #1615, it can be quite dangerous to listen to the Node.changedInstanceEmitter from scene graph code, since Instances are updated in updateDisplay, and that function is very dependent on scene graph state not changing as a side effect to that function.

@jonathanolson felt like our current usages of Node.changedInstanceEmitter could be instead swapped out with logic that knows if a Node is connected. Some of these usages depend on knowing the exact Display instance, but some don't. The investigation will see if there is a performance-friendly way to access this info synchronously (without needing to wait for updateDisplay() to call).

Not exactly sure about the priority, but right now all of the usages we have are not buggy given the current cases, but it would be easy for a buggy case to sneak in without us realizing it in the future.

@jonathanolson
Copy link
Contributor

Updated DisplayedProperty, added DisplayedTrailsProperty that doesn't rely on instances. @zepumph does this resolve the issue?

zepumph added a commit that referenced this issue Apr 5, 2024
Signed-off-by: Michael Kauzmann <[email protected]>
zepumph added a commit that referenced this issue Apr 8, 2024
Signed-off-by: Michael Kauzmann <[email protected]>
@zepumph
Copy link
Member Author

zepumph commented Apr 8, 2024

New changes and file look good. Review comments are done and committed.

It does seem quite heavy weight, but it probably isn't too bad in the vast majority of cases (that only have one or two trails anyways).

  • I am still trying to understand this block here, and how requirePdomVisible behaves, and just the basic way that this works:

if (
( requireVisible && !root.visible ) ||
( requirePdomVisible && !root.pdomVisible ) ||
( requireEnabled && !root.enabled ) ||
( requireInputEnabled && !root.inputEnabled )
) {
return;
}

I'm having trouble thinking that this covers all cases. Don't you just want a mode where you are able to "know all trails" that cause this Node to be rendered? Using logical OR to opt out feels strange to me, but I think it may be ok.

My biggest concern, along the same lines as the above note, is this block here:

// REVIEW: I'm officially confused about this feature. What is the value of "either or", why not be able to
// support both visual and PDOM in the same Property? If this is indeed best, please be sure to explain where
// the option is defined.
const parents = followPdomOrder && root.pdomParent ? [ root.pdomParent ] : root.parents;

I do not think that we should be exchanging the PDOM parent for the visual one. I guess it depends on what the use case is, but I feel like, for the Property in general, it makes a lot of sense to be able to know all the trails, this means recursing though the PDOMParent AND the visual one.

Perhaps a sync conversation would be best. Up to you and let me know!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants