In version 5.2.1, the b
prefix and the (binary)
cast were introduced for forward compatibility with the PHP-6 project. However, that project never came to be and no one can tell if it will ever be the chosen approach in a possible future attempt to implement binary strings. Yet, these are still accepted by the language scanner although ignored from then on.
This RFC aims to deprecate the prefix as it produces no effect on the string literal and the binary cast because it is the same as casting to string.
The proposed implementation consists in throwing a E_DEPRECATED
during compilation when the prefix or the cast are used. At a later major version of PHP, the support for these should be removed.
With the implementation of this RFC, the following code:
<?php echo b'Goodbye, world!' . PHP_EOL; echo (binary)'<- Equivalent to (string)' . PHP_EOL;
Executed on an environment with the error level including E_DEPRECATED
will produce:
Deprecated: The usage of the 'b' prefix is deprecated in ... on line 3 Deprecated: The usage of the binary cast is deprecated in ... on line 4 Goodbye, world! <- Equivalent to (string)
Furthermore, tests and test iterations specifically intended for binary strings are also removed as they aim at a functionality that doesn't exist.
Finally, this RFC also includes a patch for the documentation to remove the reference to this cast in the Type Juggling page and another for the language specification.
Scripts where the prefix or the cast are used will now throw a E_DEPRECATED
notice during compilation. Once the deprecation phase is over and the prefix and cast are removed, these scripts will stop compiling.
The proposed target version is the next PHP-7.x
This deprecation and subsequent removal may have a greater impact given that PHAR archives using the default stub and generated in a version of PHP prior to 7.1 include (binary)
casts.
In the next PHP major version the deprecation phase should end and the prefix and cast should be removed.
This RFC requires a 2/3 majority.
Voting starts on 2017-02-03 13:00 UTC and closes on 2017-02-20 20:00 UTC.
This RFC is implemented by the following patches:
This deprecation is also proposed in PHP RFC: Deprecations for PHP 7.2. The reason for a separate RFC is the impact on the PHAR extension.