b0y-101 Mini Shell


Current Path : E:/www3/chiangrai/wp-content/plugins/polylang/include/
File Upload :
Current File : E:/www3/chiangrai/wp-content/plugins/polylang/include/mo.php

<?php
/**
 * @package Polylang
 */

/**
 * Manages strings translations storage.
 * A static cache is used internally to enhance performances,
 * for it to work as expected, use `import_from_db` for the cache to be used
 * and `export_to_db` for the cache to be cleared.
 *
 * @since 1.2
 * @since 2.1 Stores the strings in a post meta instead of post content to avoid unserialize issues (See #63)
 * @since 3.4 Stores the strings into language taxonomy term meta instead of a post meta.
 */
class PLL_MO extends MO {
	/**
	 * Static cache for the translations.
	 *
	 * @var PLL_Cache<array>
	 */
	private static $cache;

	/**
	 * Constructor, initializes the cache if not already done.
	 *
	 * @since 3.7
	 */
	public function __construct() {
		if ( empty( self::$cache ) ) {
			self::$cache = new PLL_Cache();
		}
	}

	/**
	 * Writes the strings into a term meta.
	 *
	 * @since 1.2
	 *
	 * @param PLL_Language $lang The language in which we want to export strings.
	 * @return void
	 */
	public function export_to_db( $lang ) {
		/*
		 * It would be convenient to store the whole object, but it would take a huge space in DB.
		 * So let's keep only the strings in an array.
		 * The strings are slashed to avoid breaking slashed strings in update_term_meta.
		 * @see https://codex.wordpress.org/Function_Reference/update_post_meta#Character_Escaping.
		 */
		$strings = array();
		foreach ( $this->entries as $entry ) {
			if ( '' !== $entry->singular ) {
				$strings[] = wp_slash( array( $entry->singular, $this->translate( $entry->singular ) ) );
			}
		}

		update_term_meta( $lang->term_id, '_pll_strings_translations', $strings );

		self::$cache->clean( $lang->slug );
	}

	/**
	 * Reads a PLL_MO object from the term meta.
	 *
	 * @since 1.2
	 * @since 3.4 Reads a PLL_MO from the term meta.
	 *
	 * @param PLL_Language $lang The language in which we want to get strings.
	 * @return void
	 */
	public function import_from_db( $lang ) {
		$this->set_header( 'Language', $lang->slug );

		if ( ! empty( self::$cache->get( $lang->slug ) ) ) {
			$this->entries = self::$cache->get( $lang->slug );
			return;
		}

		$strings = get_term_meta( $lang->term_id, '_pll_strings_translations', true );
		if ( empty( $strings ) || ! is_array( $strings ) ) {
			self::$cache->set( $lang->slug, array() );
			return;
		}

		foreach ( $strings as $msg ) {
			if ( '' === $msg[0] || '' === $msg[1] ) {
				continue;
			}

			$entry = $this->make_entry( $msg[0], $msg[1] );

			if ( '' !== $entry->singular ) {
				$this->add_entry( $entry );
			}
		}

		self::$cache->set( $lang->slug, $this->entries );
	}

	/**
	 * Deletes a string
	 *
	 * @since 2.9
	 *
	 * @param string $string The source string to remove from the translations.
	 * @return void
	 */
	public function delete_entry( $string ) {
		unset( $this->entries[ $string ] );
	}

	/**
	 * Translates a string or returns false if the translation is not found.
	 * Contrary to `self::translate()`, this method doesn't fallback to the source string but returns empty string instead.
	 *
	 * @since 3.7
	 *
	 * @param string $source The source string to translate.
	 * @return string The translated string or empty string if not found.
	 */
	public function translate_if_any( string $source ) {
		$entry = new Translation_Entry( array( 'singular' => $source ) );
		$entry = $this->translate_entry( $entry );

		if ( ! $entry instanceof Translation_Entry || empty( $entry->translations ) ) {
			return '';
		}

		return $entry->translations[0];
	}
}

Copyright © 2019 by b0y-101