mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-20 15:21:28 +01:00
Move is_utf8_charset() into functions.php
This caused issues in maintenance mode, and it's not warranted to have its own module. This will live alongside `_canonical_charset()`, it's partner function. Fixes: #61182. Props: dmsnell, sergeybiryukov, swisspiddy. Follow-up to: [58148]. Built from https://develop.svn.wordpress.org/trunk@58169 git-svn-id: http://core.svn.wordpress.org/trunk@57632 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
c649fd77bd
commit
c4ff251f13
@ -7465,6 +7465,49 @@ function get_tag_regex( $tag ) {
|
|||||||
return sprintf( '<%1$s[^<]*(?:>[\s\S]*<\/%1$s>|\s*\/>)', tag_escape( $tag ) );
|
return sprintf( '<%1$s[^<]*(?:>[\s\S]*<\/%1$s>|\s*\/>)', tag_escape( $tag ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Indicates if a given slug for a character set represents the UTF-8
|
||||||
|
* text encoding. If not provided, examines the current blog's charset.
|
||||||
|
*
|
||||||
|
* A charset is considered to represent UTF-8 if it is a case-insensitive
|
||||||
|
* match of "UTF-8" with or without the hyphen.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* true === is_utf8_charset( 'UTF-8' );
|
||||||
|
* true === is_utf8_charset( 'utf8' );
|
||||||
|
* false === is_utf8_charset( 'latin1' );
|
||||||
|
* false === is_utf8_charset( 'UTF 8' );
|
||||||
|
*
|
||||||
|
* // Only strings match.
|
||||||
|
* false === is_utf8_charset( [ 'charset' => 'utf-8' ] );
|
||||||
|
*
|
||||||
|
* // Without a given charset, it depends on the site option "blog_charset".
|
||||||
|
* $is_utf8 = is_utf8_charset();
|
||||||
|
*
|
||||||
|
* @since 6.6.0
|
||||||
|
*
|
||||||
|
* @param ?string $blog_charset Slug representing a text character encoding, or "charset".
|
||||||
|
* E.g. "UTF-8", "Windows-1252", "ISO-8859-1", "SJIS".
|
||||||
|
* @return bool Whether the slug represents the UTF-8 encoding.
|
||||||
|
*/
|
||||||
|
function is_utf8_charset( $blog_charset = null ) {
|
||||||
|
$charset_to_examine = $blog_charset ?? get_option( 'blog_charset' );
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Only valid string values count: the absence of a charset
|
||||||
|
* does not imply any charset, let alone UTF-8.
|
||||||
|
*/
|
||||||
|
if ( ! is_string( $charset_to_examine ) ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
0 === strcasecmp( 'UTF-8', $charset_to_examine ) ||
|
||||||
|
0 === strcasecmp( 'UTF8', $charset_to_examine )
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieves a canonical form of the provided charset appropriate for passing to PHP
|
* Retrieves a canonical form of the provided charset appropriate for passing to PHP
|
||||||
* functions such as htmlspecialchars() and charset HTML attributes.
|
* functions such as htmlspecialchars() and charset HTML attributes.
|
||||||
|
@ -1,51 +0,0 @@
|
|||||||
<?php
|
|
||||||
/**
|
|
||||||
* WordPress API providing Unicode-relevant utilities.
|
|
||||||
*
|
|
||||||
* @since 6.6.0
|
|
||||||
*
|
|
||||||
* @package WordPress
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Indicates if a given slug for a character set represents the UTF-8
|
|
||||||
* text encoding. If not provided, examines the current blog's charset.
|
|
||||||
*
|
|
||||||
* A charset is considered to represent UTF-8 if it is a case-insensitive
|
|
||||||
* match of "UTF-8" with or without the hyphen.
|
|
||||||
*
|
|
||||||
* Example:
|
|
||||||
*
|
|
||||||
* true === is_utf8_charset( 'UTF-8' );
|
|
||||||
* true === is_utf8_charset( 'utf8' );
|
|
||||||
* false === is_utf8_charset( 'latin1' );
|
|
||||||
* false === is_utf8_charset( 'UTF 8' );
|
|
||||||
*
|
|
||||||
* // Only strings match.
|
|
||||||
* false === is_utf8_charset( [ 'charset' => 'utf-8' ] );
|
|
||||||
*
|
|
||||||
* // Without a given charset, it depends on the site option "blog_charset".
|
|
||||||
* $is_utf8 = is_utf8_charset();
|
|
||||||
*
|
|
||||||
* @since 6.6.0
|
|
||||||
*
|
|
||||||
* @param ?string $blog_charset Slug representing a text character encoding, or "charset".
|
|
||||||
* E.g. "UTF-8", "Windows-1252", "ISO-8859-1", "SJIS".
|
|
||||||
* @return bool Whether the slug represents the UTF-8 encoding.
|
|
||||||
*/
|
|
||||||
function is_utf8_charset( $blog_charset = null ) {
|
|
||||||
$charset_to_examine = $blog_charset ?? get_option( 'blog_charset' );
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Only valid string values count: the absence of a charset
|
|
||||||
* does not imply any charset, let alone UTF-8.
|
|
||||||
*/
|
|
||||||
if ( ! is_string( $charset_to_examine ) ) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (
|
|
||||||
0 === strcasecmp( 'UTF-8', $charset_to_examine ) ||
|
|
||||||
0 === strcasecmp( 'UTF8', $charset_to_examine )
|
|
||||||
);
|
|
||||||
}
|
|
@ -16,7 +16,7 @@
|
|||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '6.6-alpha-58168';
|
$wp_version = '6.6-alpha-58169';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
@ -106,7 +106,6 @@ if ( WP_CACHE && apply_filters( 'enable_loading_advanced_cache_dropin', true ) &
|
|||||||
wp_set_lang_dir();
|
wp_set_lang_dir();
|
||||||
|
|
||||||
// Load early WordPress files.
|
// Load early WordPress files.
|
||||||
require ABSPATH . WPINC . '/unicode.php';
|
|
||||||
require ABSPATH . WPINC . '/class-wp-list-util.php';
|
require ABSPATH . WPINC . '/class-wp-list-util.php';
|
||||||
require ABSPATH . WPINC . '/formatting.php';
|
require ABSPATH . WPINC . '/formatting.php';
|
||||||
require ABSPATH . WPINC . '/meta.php';
|
require ABSPATH . WPINC . '/meta.php';
|
||||||
|
Loading…
Reference in New Issue
Block a user