i18n: Prevent is_textdomain_loaded()
from returning true even if there are no translations for the domain.
In `get_translations_for_domain()` don't fill the global `$l10n` with `NOOP_Translations` instances, return a `NOOP_Translations` instance instead. Props nacin, jrf. Fixes #21319. git-svn-id: https://develop.svn.wordpress.org/trunk@36538 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
3e7f4fba19
commit
35579fa786
@ -793,10 +793,16 @@ function load_child_theme_textdomain( $domain, $path = false ) {
|
||||
*/
|
||||
function get_translations_for_domain( $domain ) {
|
||||
global $l10n;
|
||||
if ( !isset( $l10n[$domain] ) ) {
|
||||
$l10n[$domain] = new NOOP_Translations;
|
||||
if ( isset( $l10n[ $domain ] ) ) {
|
||||
return $l10n[ $domain ];
|
||||
}
|
||||
return $l10n[$domain];
|
||||
|
||||
static $noop_translations = null;
|
||||
if ( null === $noop_translations ) {
|
||||
$noop_translations = new NOOP_Translations;
|
||||
}
|
||||
|
||||
return $noop_translations;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -811,7 +817,7 @@ function get_translations_for_domain( $domain ) {
|
||||
*/
|
||||
function is_textdomain_loaded( $domain ) {
|
||||
global $l10n;
|
||||
return isset( $l10n[$domain] );
|
||||
return isset( $l10n[ $domain ] );
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -26,4 +26,24 @@ class Tests_L10n extends WP_UnitTestCase {
|
||||
$this->assertEquals( 'first-before-bar|second-before-bar', before_last_bar( 'first-before-bar|second-before-bar|after-last-bar' ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 21319
|
||||
*/
|
||||
function test_is_textdomain_loaded_for_no_translations() {
|
||||
$this->assertFalse( load_textdomain( 'wp-tests-domain', DIR_TESTDATA . '/non-existent-file' ) );
|
||||
$this->assertFalse( is_textdomain_loaded( 'wp-tests-domain' ) );
|
||||
$this->assertInstanceOf( 'NOOP_Translations', get_translations_for_domain( 'wp-tests-domain' ) );
|
||||
// Ensure that we don't confuse NOOP_Translations to be a loaded text domain.
|
||||
$this->assertFalse( is_textdomain_loaded( 'wp-tests-domain' ) );
|
||||
$this->assertFalse( unload_textdomain( 'wp-tests-domain' ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 21319
|
||||
*/
|
||||
function test_is_textdomain_is_not_loaded_after_gettext_call_with_no_translations() {
|
||||
$this->assertFalse( is_textdomain_loaded( 'wp-tests-domain' ) );
|
||||
__( 'just some string', 'wp-tests-domain' );
|
||||
$this->assertFalse( is_textdomain_loaded( 'wp-tests-domain' ) );
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user