I18N: Improve `_load_textdomain_just_in_time()` logic when there are no translation files.
Fixes a performance issue where the JIT logic is invoked for every translation call if the there are no translations in the current locale. With this change, the information is cached by adding `Noop_Translations` instances to the global `$l10n` array. This way, `get_translations_for_domain()` returns earlier, thus avoiding subsequent `_load_textdomain_just_in_time()` calls. Props swissspidy, johnbillion, ocean90. Fixes #58321. Built from https://develop.svn.wordpress.org/trunk@55865 git-svn-id: http://core.svn.wordpress.org/trunk@55377 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
4581452e2b
commit
30593b01b4
|
@ -97,7 +97,7 @@ class WP_Textdomain_Registry {
|
||||||
*/
|
*/
|
||||||
public function has( $domain ) {
|
public function has( $domain ) {
|
||||||
return (
|
return (
|
||||||
! empty( $this->current[ $domain ] ) ||
|
isset( $this->current[ $domain ] ) ||
|
||||||
empty( $this->all[ $domain ] ) ||
|
empty( $this->all[ $domain ] ) ||
|
||||||
in_array( $domain, $this->domains_with_translations, true )
|
in_array( $domain, $this->domains_with_translations, true )
|
||||||
);
|
);
|
||||||
|
|
|
@ -834,6 +834,12 @@ function unload_textdomain( $domain, $reloadable = false ) {
|
||||||
do_action( 'unload_textdomain', $domain, $reloadable );
|
do_action( 'unload_textdomain', $domain, $reloadable );
|
||||||
|
|
||||||
if ( isset( $l10n[ $domain ] ) ) {
|
if ( isset( $l10n[ $domain ] ) ) {
|
||||||
|
if ( $l10n[ $domain ] instanceof NOOP_Translations ) {
|
||||||
|
unset( $l10n[ $domain ] );
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
unset( $l10n[ $domain ] );
|
unset( $l10n[ $domain ] );
|
||||||
|
|
||||||
if ( ! $reloadable ) {
|
if ( ! $reloadable ) {
|
||||||
|
@ -1307,6 +1313,8 @@ function get_translations_for_domain( $domain ) {
|
||||||
$noop_translations = new NOOP_Translations();
|
$noop_translations = new NOOP_Translations();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$l10n[ $domain ] = &$noop_translations;
|
||||||
|
|
||||||
return $noop_translations;
|
return $noop_translations;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1322,7 +1330,7 @@ function get_translations_for_domain( $domain ) {
|
||||||
*/
|
*/
|
||||||
function is_textdomain_loaded( $domain ) {
|
function is_textdomain_loaded( $domain ) {
|
||||||
global $l10n;
|
global $l10n;
|
||||||
return isset( $l10n[ $domain ] );
|
return isset( $l10n[ $domain ] ) && ! $l10n[ $domain ] instanceof NOOP_Translations;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '6.3-alpha-55864';
|
$wp_version = '6.3-alpha-55865';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 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.
|
||||||
|
|
Loading…
Reference in New Issue