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

Separate out proxied SplFixedArray handlers #18199

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

nielsdos
Copy link
Member

See individual commits

@nielsdos nielsdos marked this pull request as ready for review March 30, 2025 19:28
@nielsdos nielsdos requested a review from Girgias as a code owner March 30, 2025 19:28
Copy link
Member

@Girgias Girgias left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The one thing I'm not sure about, is removing the proxied object handle as this conflicts with the design for the container/offset RFC as it removes them. But this might be something that I should change it that implementation anyway.

@nielsdos
Copy link
Member Author

The one thing I'm not sure about, is removing the proxied object handle as this conflicts with the design for the container/offset RFC as it removes them.

I'm kinda confused by this statement.
I'm just changing the object handlers to the slower ones when it's a subclass, something that's orthogonal to your RFC. If the dimension handler APIs are kept in your RFC, then this has no problem. If you replace them by proper zend functions, then we don't even need the dimension handlers as we can just implement a zend function which the user can override

@nielsdos
Copy link
Member Author

Although I would note that I would recommend against using real zend functions unless you find a way to reduce the overhead of internal function calls for those. (frameless?)

@Girgias
Copy link
Member

Girgias commented Mar 30, 2025

Although I would note that I would recommend against using real zend functions unless you find a way to reduce the overhead of internal function calls for those. (frameless?)

The main issue is that internal classes need to take care to support child classes that may implement these interfaces. And I haven't found a good way around that.

@nielsdos
Copy link
Member Author

Ok. So let's wait for the proxy stuff and land the rest of this PR? WDYT?

Copy link
Member

@Girgias Girgias left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sounds good to me. :)

This avoids checks if we know upfront that the instances are not
inherited.
@nielsdos
Copy link
Member Author

Merged as 9e52d16 and d20e3e6 and rebased this one

@nielsdos nielsdos changed the title Further SplFixedArray optimizations Separate out proxied SplFixedArray handlers Mar 31, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants