load_muplugin_textdomain()WP 3.0.0

Подключает .mo файл перевода для обязательных плагинов (mu-plugins) из указанной папки.

MO файл должен называться: ДОМЕН_ПЕРЕВОДА-ЛОКАЛЬ.mo. Например my-plugin-ru_RU.mo, где my-plugin домен перевода и ru_RU локаль перевода. Какие бывают локали см. в get_locale().

Вызывать функцию рекомендуется через хук muplugins_loaded. Но можно и позднее, например на plugins_loaded.

С версии 4.6. функция сначала пытается загрузить .mo файл с папки WP_LANG_DIR/plugins/ обычно это /wp-content/language/plugins.

Работает на основе: load_textdomain()
Хуки из функции

Возвращает

true|false. Вернет false, если .mo файл не существует по указанному пути. В остальных случаях функция вернет true.

Использование

load_muplugin_textdomain( $domain, $mu_plugin_rel_path );
$domain(строка) (обязательный)
Уникальный идентификатор для получения строки перевода.
$mu_plugin_rel_path(строка)

Путь до каталога .mo файла относительно WPMU_PLUGIN_DIR.

Если путь не указан, то им будет корневая директория MU плагинов WPMU_PLUGIN_DIR. Т.е. путь до файла будет такой: WPMU_PLUGIN_DIR/domain-ru_RU.mo.

По умолчанию: ''

Примеры

0

#1 Регистрация файла перевода для MU плагина

Файл перевода должен лежать в каталоге обязательного плагина и должен называться: my-plugin-ru_RU.mo.

add_action( 'muplugins_loaded', 'myplugin_init' );
function myplugin_init(){
	load_muplugin_textdomain( 'my-plugin', dirname( plugin_basename( __FILE__ ) ) ); 
}
0

#2 Если нужно расположить файл перевода .mo в подпапку lang:

Файл перевода должен лежать в подпапке lang обязательного плагина и должен называться: my-plugin-ru_RU.mo.

add_action( 'muplugins_loaded', 'myplugin_init' );
function myplugin_init() {
	 load_muplugin_textdomain( 'my-plugin', dirname( plugin_basename( __FILE__ ) ) . '/lang/' );
}

Заметки

  • Global. WP_Textdomain_Registry. $wp_textdomain_registry WordPress Textdomain Registry.

Список изменений

С версии 3.0.0 Введена.
С версии 4.6.0 The function now tries to load the .mo file from the languages directory first.

Код load_muplugin_textdomain() WP 6.6.2

function load_muplugin_textdomain( $domain, $mu_plugin_rel_path = '' ) {
	/** @var WP_Textdomain_Registry $wp_textdomain_registry */
	global $wp_textdomain_registry;

	if ( ! is_string( $domain ) ) {
		return false;
	}

	/** This filter is documented in wp-includes/l10n.php */
	$locale = apply_filters( 'plugin_locale', determine_locale(), $domain );

	$mofile = $domain . '-' . $locale . '.mo';

	// Try to load from the languages directory first.
	if ( load_textdomain( $domain, WP_LANG_DIR . '/plugins/' . $mofile, $locale ) ) {
		return true;
	}

	$path = WPMU_PLUGIN_DIR . '/' . ltrim( $mu_plugin_rel_path, '/' );

	$wp_textdomain_registry->set_custom_path( $domain, $path );

	return load_textdomain( $domain, $path . '/' . $mofile, $locale );
}