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

[RFC] Optional interfaces #17288

Draft
wants to merge 3 commits into
base: master
Choose a base branch
from
Draft

Conversation

tontonsb
Copy link

@tontonsb tontonsb commented Dec 28, 2024

This is an implementation attempt of https://wiki.php.net/rfc/optional-interfaces

It's my first attempt at modifying PHP sources, so I am very open to any suggestions and guidance on how this should be actually solved. But for now I'll briefly explain my approach:

  • Types interface_name_list and interface_name are added to parser. interface_name_list is used instead of class_name_list for implements_list and interface_extends_list. The interface_name is a name that can be prefixed by a ? in which case it will set a ZEND_CLASS_NAME_OPTIONAL flag on the attr of that token.
  • The struct zend_interface_name is defined and used for interface_names. The difference from zend_class_name is that the zend_interface_name also holds a boolean is_optional which is set according to the ZEND_CLASS_NAME_OPTIONAL flag.
  • The inheritance mechanism uses the ZEND_FETCH_CLASS_SILENT flag on zend_fetch_class_by_name if the interface name is_optional. In case an optional interface fails to fetch, it's just skipped.

I'm not really sure what should be done for Opcache here and I haven't yet understood how to work with booleans there. I haven't looked into Reflection at all yet.

@tontonsb tontonsb requested a review from dstogov as a code owner December 28, 2024 20:11
@tontonsb tontonsb changed the title Add syntax for optional interfaces [RFC] Optional interfaces Dec 28, 2024
@tontonsb tontonsb marked this pull request as draft December 28, 2024 20:54
Copy link
Member

@nielsdos nielsdos left a comment

Choose a reason for hiding this comment

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

As you're asking for opcache help, this should resolve some questions and fix the tests (hopefully)

Zend/zend_inheritance.c Outdated Show resolved Hide resolved
ext/opcache/zend_persist.c Outdated Show resolved Hide resolved
ext/opcache/zend_file_cache.c Outdated Show resolved Hide resolved
@dstogov
Copy link
Member

dstogov commented Jan 9, 2025

The PR misses tests. The implementation looks simple. I don't see problems.
Please check if opcache inheritance cache works properly. We may have defined/unefined optional interfaces on one request and vice verse on the other.

@bernard-ng
Copy link

I had just read the rfc, since PHP8.3 we have the Override attribute if an interface is optional how will this attribute be managed?

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.

4 participants