(PHP 5 >= 5.3.0, PECL intl >= 1.0.0)
Une "Locale" est un identifiant utilisé pour représenter les comportements régionaux d'uneAPI. Les locales PHP sont organisées et identifiées de la même manière que les CLDR de ICU (et que de nombreux autres éditeurs de système Unix, tels que Mac, Java, etc.). Les locales sont identifiées par les libellés de langage de la RFC 4646 (qui utilise des tirets et pas des soulignés) en plus de la notation traditionnelle avec des soulignés. Sauf contre-indication, les fonctions de cette classe sont capables d'utiliser les deux notations.
Exemple d'identifiants :
La classe Locale et les méthodes associées, sont utilisées pour interagir avec les identifiants locaux : pour vérifier qu'un identifiant est bien formé, valide, etc. Les extensions utilisées par CDR dans UAX #35 et hérité par ICU sont valides, et utilisés à chaque fois qu'elles peuvent l'être dans ICU.
Les locales ne peuvent pas être instanciées. Ce sont toutes des fonctions statiques.
La chaîne NULL
ou vide permet d'obtenir la locale racine. La racine est l'équivalent
de "en_US_POSIX" en CLDR. Les libellé de langage (et donc, les
identifiants) sont insensibles à la casse. Il existe une fonction de canonalisation
qui permet d'obtenir la spécification exacte.
$langtag
, string $locale
[, bool $canonicalize
= false
[, string $default
]] )Ces constantes définissent le comportement de Locale
Locale::DEFAULT_LOCALE
(NULL
)
Ces constantes décrivent le choix de la locale pour la méthode getLocale de différentes classes.
Locale::ACTUAL_LOCALE
(chaîne de caractères)
Locale::VALID_LOCALE
(chaîne de caractères)
Ces constantes définissent comment les Locales sont analysées ou composées. Elles doivent être utilisées comme clés dans un tableau d'arguments passé à locale_compose() et sont retournées par locale_parse() comme clés d'un array associatif.
Locale::LANG_TAG
(chaîne de caractères)
Locale::EXTLANG_TAG
(chaîne de caractères)
Locale::SCRIPT_TAG
(chaîne de caractères)
Locale::REGION_TAG
(chaîne de caractères)
Locale::VARIANT_TAG
(chaîne de caractères)
Locale::GRANDFATHERED_LANG_TAG
(chaîne de caractères)
Locale::PRIVATE_TAG
(chaîne de caractères)