Scroll to navigation

LOCALE(7) Linux - příručka programátora LOCALE(7)

JMÉNO

locale - Popis vícejazykové podpory

POUŽITÍ

#include <locale.h>

POPIS

Locale je množina jazykových a kulturních pravidel pro popis takových aspektu jako jsou jazyk pro zprávy, různé znakové sady, abecední řazení atd. Každý program musí mít možnost zjistit jeho locale a chovat se podle jím daných pravidel.

Hlavičkový soubor <locale.h> deklaruje datové typy, funkce a makra, která tuto přenositelnost usnadňuje.

Deklarované funkce: setlocale(3) pro nastavení aktuálního lacale a localeconv(3) pro zjištění informací o formátování čísel.

Různé kategorie pro lokální informace jsou definovány jako makra. Jestliže se použijí jako první argument pro funkci setlocale(3) je možno nastavit jednu z požadovaných kategorií:

Mění chování funkcí strcoll(3) a strxfrm(3), které se používají na porovnání řetězců v lokální abecedě, Například, ostré německé s se třídí jako "ss".
Mění chování klasifikačních funkcí a maker jako isupper(3) a toupper(3), a funkcí pro vícebytové znaky jako je mblen(3) nebo wctomb(3).
Mění návratovou hodnotu funkce localeconv(3), která popisuje způsob jak jsou tištěna čísla, včetně detailů o desetinné tečce či čárce. Interně je tato informace použita ve funkci strfmon(3).
mění jazyk zpráv a určuje jak vypadá pozitivní a negativní odpověď v daném jazyce. GNU C-lib obsahuje pro tento účel funkce gettext(3), ngettext(3), and rpmatch(3). Funkce z GNU gettext se rovněž řídí proměnnou prostředí LANGUAGE (která obsahuje dvojtečkou oddělovaný seznam locales), je-li tato nastavena na platné locale jiné než "C".
Mění chování funkcí printf(3) a scanf(3) kdykoli mají použít nastavení locale. Tuto informaci lze také číst pomocí funkce localeconv(3).
mění chování funkcí strftime(3), která zobrazuje současný čas podle lokálních pravidel; například v Evropě se běžně používá 24 hodinový den, zatímco v USA 12 hodinový.
Nastavuje vše.

Jestliže je druhý argument pro setlocale(3) prázdný řetězec, "", hledá se základní locale takto:

1.
Jestliže je nastavena proměnná prostředí LC_ALL, použije se LC_ALL .
2.
Jestliže existuje proměnná prostředí, která se jmenuje stejně jako některá z kategorií, použije se tato.
3.
Jestliže je nastavena proměnná prostředí LANG, použije se hodnota LANG .

Hodnoty pro číselnou konverzi jsou nastaveny ve struct lconv , kterou vrací funkce localeconv(3), má následující deklaraci:

struct lconv {

/* Číselná (nikoli peněžní) informace */
char *decimal_point; /* Znak pro desetinnou čárku */
char *thousands_sep; /* Oddělovač tisíců */
char *grouping; /* Každý prvek označuje počet číslic ve skupině;
významnější hodnoty se zobrazují více vlevo.
Pozice CHAR_MAX určuje odkud se již žádné
oddělování nečiní. Prvek s hodnotou 0 označuje,
že předchozí prvek se použije odtud doleva. */
/* Peněžní informace. */
char *int_curr_symbol; /* První tři znaky jsou symbolem měny podle
ISO 4217. Čtvrtý znak je oddělovač, pátý
je '\0'. */
char *currency_symbol; /* Lokální symbol pro měnu */
char *mon_decimal_point; /* desetinná čárka */
char *mon_thousands_sep; /* Viz thousands_sep nahoře */
char *mon_grouping; /* Viz grouping nahoře */
char *positive_sign; /* Kladné znaménko */
char *negative_sign; /* Záporné znaménko */
char int_frac_digits; /* Mezinárodní počet des. míst */
char frac_digits; /* Lokální počet des. míst */
char p_cs_precedes; /* 1 když znak měny předchází číslo,
0 když jej následuje */
char p_sep_by_space; /* 1 když mezera odděluje
currency_symbol od desetinné čárky */
char n_cs_precedes; /* 1 když currency_symbol předchází
záporné hodnoty, 0 když následuje */
char n_sep_by_space; /* 1 když mezera odděluje
currency_symbol od záporné hodnoty */
/* Kladné a záporné znaménko:
0 Závorky kolem hodnoty a symbolu měny.
1 Znaménko před hodnotou i symbolem měny.
2 Znaménko následuje za hodnotou i symbolem měny.
3 Znaménko bezprostředně před symbolem měny.
4 Znaménko bezprostředně následuje symbolem měny. */
char p_sign_posn;
char n_sign_posn; };

SPLŇUJE STANDARDY

POSIX.1-2001.

Funkce GNU gettext jsou specifikovány v LI18NUX2000.

DALŠÍ INFORMACE

locale(1), localedef(1), gettext(3), localeconv(3), ngettext(3), nl_langinfo(3), rpmatch(3), setlocale(3), strcoll(3), strfmon(3), strftime(3), strxfrm(3)

TIRÁŽ

Tato stránka je součástí projektu Linux man-pages. Popis projektu a informace o hlášení chyb najdete na http://www.kernel.org/doc/man-pages/.

2008-12-05 Linux