Stars: 2440
Forks: 145
Pull Requests: 312
Issues: 134
Watchers: 38
Last Updated: 2023-09-14 12:59:47
This project backports features found in the latest PHP versions and provides compatibility layers for some extensions and functions. It is intended to be used when portability across PHP versions and extensions is desired.
Polyfills are provided for:
apcu extension when the legacy apc extension is installed;ctype extension when PHP is compiled without ctype;mbstring and iconv extensions;uuid extension;MessageFormatter class and the msgfmt_format_message functions;Normalizer class and the grapheme_* functions;utf8_encode and utf8_decode functions from the xml extension or PHP-7.2 core;Collator, NumberFormatter, Locale and IntlDateFormatter classes,
limited to the "en" locale;intl_error_name, intl_get_error_code, intl_get_error_message and
intl_is_failure functions;idn_to_ascii and idn_to_utf8 functions;Binary utility class to be used when compatibility with
mbstring.func_overload is required;spl_object_id and stream_isatty functions introduced in PHP 7.2;mb_ord, mb_chr and mb_scrub functions introduced in PHP 7.2 from the mbstring extensionsapi_windows_vt100_support function (Windows only) introduced in PHP 7.2;PHP_FLOAT_* constant introduced in PHP 7.2;PHP_OS_FAMILY constant introduced in PHP 7.2;is_countable function introduced in PHP 7.3;array_key_first and array_key_last functions introduced in PHP 7.3;hrtime function introduced in PHP 7.3;JsonException class introduced in PHP 7.3;get_mangled_object_vars, mb_str_split and password_algos functions
introduced in PHP 7.4;fdiv function introduced in PHP 8.0;get_debug_type function introduced in PHP 8.0;preg_last_error_msg function introduced in PHP 8.0;str_contains function introduced in PHP 8.0;str_starts_with and str_ends_with functions introduced in PHP 8.0;ValueError class introduced in PHP 8.0;UnhandledMatchError class introduced in PHP 8.0;FILTER_VALIDATE_BOOL constant introduced in PHP 8.0;get_resource_id function introduced in PHP 8.0;Attribute class introduced in PHP 8.0;Stringable interface introduced in PHP 8.0;PhpToken class introduced in PHP 8.0 when the tokenizer extension is enabled;array_is_list function introduced in PHP 8.1;enum_exists function introduced in PHP 8.1;MYSQLI_REFRESH_REPLICA constant introduced in PHP 8.1;ReturnTypeWillChange attribute introduced in PHP 8.1;CURLStringFile class introduced in PHP 8.1 (but only if PHP >= 7.4 is used);AllowDynamicProperties attribute introduced in PHP 8.2;SensitiveParameter attribute introduced in PHP 8.2;SensitiveParameterValue class introduced in PHP 8.2;Random\Engine interface introduced in PHP 8.2;Random\CryptoSafeEngine interface introduced in PHP 8.2;Random\Engine\Secure class introduced in PHP 8.2 (check arokettu/random-polyfill for more engines);odbc_connection_string_is_quoted function introduced in PHP 8.2;odbc_connection_string_should_quote function introduced in PHP 8.2;odbc_connection_string_quote function introduced in PHP 8.2;ini_parse_quantity function introduced in PHP 8.2;json_validate function introduced in PHP 8.3;Override attribute introduced in PHP 8.3;mb_str_pad function introduced in PHP 8.3;ldap_exop_sync function introduced in PHP 8.3;ldap_connect_wallet function introduced in PHP 8.3;stream_context_set_options function introduced in PHP 8.3;Date*Exception/Error classes introduced in PHP 8.3;It is strongly recommended to upgrade your PHP version and/or install the missing extensions whenever possible. This polyfill should be used only when there is no better choice or when portability is a requirement.
To write portable code between PHP5 and PHP7, some care must be taken:
\*Error exceptions must be caught before \Exception;error_clear_last(), the result of $e = error_get_last() must be
verified using isset($e['message'][0]) instead of null !== $e.When using Composer to manage your dependencies, you
should not require the symfony/polyfill package, but the standalone ones:
symfony/polyfill-apcu for using the apcu_* functions,symfony/polyfill-ctype for using the ctype functions,symfony/polyfill-php54 for using the PHP 5.4 functions,symfony/polyfill-php55 for using the PHP 5.5 functions,symfony/polyfill-php56 for using the PHP 5.6 functions,symfony/polyfill-php70 for using the PHP 7.0 functions,symfony/polyfill-php71 for using the PHP 7.1 functions,symfony/polyfill-php72 for using the PHP 7.2 functions,symfony/polyfill-php73 for using the PHP 7.3 functions,symfony/polyfill-php74 for using the PHP 7.4 functions,symfony/polyfill-php80 for using the PHP 8.0 functions,symfony/polyfill-php81 for using the PHP 8.1 functions,symfony/polyfill-php82 for using the PHP 8.2 functions,symfony/polyfill-php83 for using the PHP 8.3 functions,symfony/polyfill-iconv for using the iconv functions,symfony/polyfill-intl-grapheme for using the grapheme_* functions,symfony/polyfill-intl-idn for using the idn_to_ascii and idn_to_utf8 functions,symfony/polyfill-intl-icu for using the intl functions and classes,symfony/polyfill-intl-messageformatter for using the intl messageformatter,symfony/polyfill-intl-normalizer for using the intl normalizer,symfony/polyfill-mbstring for using the mbstring functions,symfony/polyfill-util for using the polyfill utility helpers.symfony/polyfill-uuid for using the uuid_* functions,Requiring symfony/polyfill directly would prevent Composer from sharing
correctly polyfills in dependency graphs. As such, it would likely install
more code than required.
This package is designed for low overhead and high quality polyfilling.
It adds only a few lightweight require statements to the bootstrap process
to support all polyfills. Implementations are then loaded on-demand when
needed during code execution.
If your project requires a minimum PHP version it is advisable to add polyfills
for lower PHP versions to the replace section of your composer.json.
This removes any overhead from these polyfills as they are no longer part of your project.
The same can be done for polyfills for extensions that you require.
If your project requires php 7.0, and needs the mb extension, the replace section would look something like this:
{
"replace": {
"symfony/polyfill-php54": "*",
"symfony/polyfill-php55": "*",
"symfony/polyfill-php56": "*",
"symfony/polyfill-php70": "*",
"symfony/polyfill-mbstring": "*"
}
}Polyfills are unit-tested alongside their native implementation so that feature and behavior parity can be proven and enforced in the long run.
This library is released under the MIT license.