mirror of
git://develop.git.wordpress.org/
synced 2025-01-16 20:38:35 +01:00
General: Backport polyfills for str_ends_with()
and str_starts_with()
.
Merges [52040], [56016], and [56015] to 4.3 branch. Props ocean90, SergeyBiryukov, desrosj, joemcgill, jorbin, mukesh27. git-svn-id: https://develop.svn.wordpress.org/branches/4.3@57440 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
eef28c2d4e
commit
13736901eb
@ -260,3 +260,49 @@ endif;
|
||||
if ( ! defined( 'JSON_PRETTY_PRINT' ) ) {
|
||||
define( 'JSON_PRETTY_PRINT', 128 );
|
||||
}
|
||||
|
||||
if ( ! function_exists( 'str_starts_with' ) ) {
|
||||
/**
|
||||
* Polyfill for `str_starts_with()` function added in PHP 8.0.
|
||||
*
|
||||
* Performs a case-sensitive check indicating if
|
||||
* the haystack begins with needle.
|
||||
*
|
||||
* @since 5.9.0
|
||||
*
|
||||
* @param string $haystack The string to search in.
|
||||
* @param string $needle The substring to search for in the `$haystack`.
|
||||
* @return bool True if `$haystack` starts with `$needle`, otherwise false.
|
||||
*/
|
||||
function str_starts_with( $haystack, $needle ) {
|
||||
if ( '' === $needle ) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return 0 === strpos( $haystack, $needle );
|
||||
}
|
||||
}
|
||||
|
||||
if ( ! function_exists( 'str_ends_with' ) ) {
|
||||
/**
|
||||
* Polyfill for `str_ends_with()` function added in PHP 8.0.
|
||||
*
|
||||
* Performs a case-sensitive check indicating if
|
||||
* the haystack ends with needle.
|
||||
*
|
||||
* @since 5.9.0
|
||||
*
|
||||
* @param string $haystack The string to search in.
|
||||
* @param string $needle The substring to search for in the `$haystack`.
|
||||
* @return bool True if `$haystack` ends with `$needle`, otherwise false.
|
||||
*/
|
||||
function str_ends_with( $haystack, $needle ) {
|
||||
if ( '' === $haystack ) {
|
||||
return '' === $needle;
|
||||
}
|
||||
|
||||
$len = strlen( $needle );
|
||||
|
||||
return substr( $haystack, -$len, $len ) === $needle;
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user