rfc:allow-constant-override-consistently
                This is an old revision of the document!
PHP RFC - Allow constant override consistently
- Version: 0.0.1
- Date: 2018-04-11
- Author: WesNetmo
- Status: Under Discussion
- First Published at: https://wiki.php.net/rfc/allow-constant-override-consistently
Introduction
Currently, a class constant can be overridden in inheritors, but the same cannot be achieved when interfaces are involved.
// The following works: class A1 { const X = 1; } class B1 extends A1 { const X = 2; } // This doesn't: interface A2 { const X = 1; } interface B2 extends A2 { const X = 2; } interface A3 { const X = 1; } class B3 implements A3 { const X = 2; }
Even if this restriction had a purpose, it's not really effective since the restriction has only effect in direct inheritors:
interface A3 { const X = 1; } abstract class B3 implements A3 { } // Can't override here class B4 extends B3 { const X = 2; } // But can do here
Proposal
This RFC proposes to normalize the behavior so that constant override is allowed everywhere. This is not an invite at reckless overriding but simply a matter of consistency. Class constants are constants only within the class they are defined in; inheritors inherit them by default but the user can optionally override them if desired.
Backward Incompatible Changes
None.
Proposed PHP Version:
7.3
Voting
2/3 majority will be required.
References
rfc/allow-constant-override-consistently.1523413589.txt.gz · Last modified:  (external edit)