Current File : /home/bmofiscom/public_html/wp-content/plugins/polylang/frontend/accept-language.php |
<?php
/**
* @package Polylang
*/
/**
* Class Accept_Language.
*
* Represents an Accept-Language HTTP Header, as defined in RFC 2616 Section 14.4 {@see https://tools.ietf.org/html/rfc2616.html#section-14.4}.
*
* @since 3.0
*/
class PLL_Accept_Language {
const SUBTAG_PATTERNS = array(
'language' => '(\b[a-z]{2,3}|[a-z]{4}|[a-z]{5-8}\b)',
'language-extension' => '(?:-(\b[a-z]{3}){1,3}\b)?',
'script' => '(?:-(\b[a-z]{4})\b)?',
'region' => '(?:-(\b[a-z]{2}|[0-9]{3})\b)?',
'variant' => '(?:-(\b[0-9][a-z]{1,3}|[a-z][a-z0-9]{4,7})\b)?',
'extension' => '(?:-(\b[a-wy-z]-[a-z0-9]{2,8})\b)?',
'private-use' => '(?:-(\bx-[a-z0-9]{1,8})\b)?',
);
/**
* @var string[] {
* @type string $language Usually 2 or three letters (ISO 639).
* @type string $language-extension Up to three groups of 3 letters.
* @type string $script Four letters.
* @type string $region Either two letters of three digits.
* @type string $variant Either one digit followed by 1 to 3 letters, or a letter followed by 2 to 7 alphanumerical characters.
* @type string $extension One letter that cannot be an 'x', followed by 2 to 8 alphanumerical characters.
* @type string $private-use Starts by 'x-', followed by 1 to 8 alphanumerical characters.
* }
*/
protected $subtags;
/**
* @var float
*/
protected $quality;
/**
* PLL_Accept_Language constructor.
*
* @since 3.0
*
* @param string[] $subtags With subtag name as keys and subtag values as names.
* @param mixed $quality Floating point value from 0.0 to 1.0. Higher values indicates a user's preference.
*/
public function __construct( $subtags, $quality = 1.0 ) {
$this->subtags = $subtags;
$this->quality = is_numeric( $quality ) ? floatval( $quality ) : 1.0;
}
/**
* Creates a new instance from an array resulting of a PHP {@see preg_match()} or {@see preg_match_all()} call.
*
* @since 3.0
*
* @param string[] $matches Expects first entry to be full match, following entries to be subtags and last entry to be quality factor.
* @return PLL_Accept_Language
*/
public static function from_array( $matches ) {
$subtags = array_combine(
array_keys( array_slice( self::SUBTAG_PATTERNS, 0, count( $matches ) - 1 ) ),
array_slice( $matches, 1, count( self::SUBTAG_PATTERNS ) )
);
$quality = count( $matches ) === 9 ? $matches[8] : 1.0;
return new PLL_Accept_Language( $subtags, $quality );
}
/**
* Returns the full language tag.
*
* @since 3.0
*
* @return string
*/
public function __toString() {
$subtags = array_filter(
$this->subtags,
function ( $subtag ) {
return ! empty( trim( $subtag ) );
}
);
return implode( '-', $subtags );
}
/**
* Returns the quality factor as negotiated by the browser agent.
*
* @since 3.0
*
* @return float
*/
public function get_quality() {
return $this->quality;
}
/**
* Returns a subtag from the language tag.
*
* @since 3.0
*
* @param string $name A valid subtag name, {@see PLL_Accept_Language::SUBTAG_PATTERNS} for available subtag names.
* @return string
*/
public function get_subtag( $name ) {
return isset( $this->subtags[ $name ] ) ? $this->subtags[ $name ] : '';
}
}