LOCALE
Section: Linux Programmer's Manual (7)
Updated: 24 aprile 1993
Index
Return to Main Contents
NOME
locale - Descrizione del supporto multi-linguistico
SINTASSI
#include <locale.h>
DESCRIZIONE
Una localizzazione (locale, in inglese) è un insieme di regole
linguistiche e culturali che coprono
campi come la lingua dei messaggi, insiemi di caratteri, convenzioni
lessicografiche, ecc. Un programma deve poter determinare la sua
localizzazione e agire di conseguenza per poter essere adattato a culture
diverse.
L'header
<locale.h>
dichiara i tipi di dati, funzioni e macro utili per questo scopo.
Le funzioni che vengono dichiarate sono
setlocale()
per impostare la localizzazione corrente e
localeconv()
per ottenere informazioni sul modo di formattare i numeri.
Le differenti categorie di informazioni locali di cui un programma
potrebbe aver bisogno vengono dichiarate come macro. Usandole come
primo argomento alla funzione
setlocale()
è possibile impostare una delle seguenti localizzazioni:
- LC_COLLATE
-
viene usato per modificare il comportamento delle funzioni
strcoll()
e
strxfrm(),
che servono per confrontare stringhe nell'alfabeto locale. Ad esempio,
la «ß» tedesca viene ordinata lessicograficamente come «ss».
- LC_CTYPE
-
modifica il comportamento delle funzioni che maneggiano e classificano
caratteri, come
isupper()
e
toupper(),
e le funzioni per caratteri multi-byte come
mblen()
o
wctomb().
- LC_MONETARY
-
cambia l'informazione restituita da
localeconv(),
la quale descrive il modo in cui i numeri vengono normalmente
stampati, compresi dettagli come l'uso del punto o della virgola
decimale. Questa informazione è usata internamente dalla funzione
strfmon().
- LC_MESSAGES
-
cambia il linguaggio in cui i messaggi vengono mostrati e la forma
delle risposte positive o negative. La libreria C di GNU contiene le
funzioni
gettext(),
ngettext(),
e
rpmatch()
per facilitare l'impiego di queste informazioni. La famiglia di funzioni
GNU gettext rispetta anche la variabile
LANGUAGE.
- LC_NUMERIC
-
cambia l'informazione usata dalle famiglie di funzioni
printf()
e
scanf(),
quando viene loro richiesto di usare le impostazioni localizzate. Queste
informazioni possono anche essere lette tramite la funzione
localeconv().
- LC_TIME
-
modifica il comportamento della funzione
strftime()
onde mostrare l'ora in una forma localmente accettabile; per esempio,
in buona parte d'Europa si usano le 24 ore, a differenza delle 12 ore
degli USA.
- LC_ALL
-
Vale per tutte le macro precedenti.
Se il secondo argomento a
setlocale()
è la stringa vuota
"",
allora la localizzazione predefinita è determinata come segue:
- 1.
-
Se è presente una variabile ambientale non nulla
LC_ALL,
viene usato il valore di
LC_ALL.
- 2.
-
Se una variabile ambientale con lo stesso nome di una delle categorie
precedenti esiste ed è non nulla, il suo valore viene usato per quella
categoria.
- 3.
-
Se è presente una variabile ambientale non nulla
LANG,
viene usato il valore di
LANG .
I valori che descrivono la formattazione locale dei numeri sono dispobili
in una
struct lconv
restituita dalla funzione
localeconv(),
che è così dichiarata:
struct lconv {
/* Numeric (non-monetary) information */
char *decimal_point; /* Radix character */
char *thousands_sep; /* Separator for digit groups to left
of radix character */
char *grouping; /* Each element is the number of digits in a
group; elements with higher indices are
further left. An element with value CHAR_MAX
means that no further grouping is done. An
element with value 0 means that the previous
element is used for all groups further left. */
/* Remaining fields are for monetary information */
char *int_curr_symbol; /* First three chars are a currency symbol
from ISO 4217. Fourth char is the
separator. Fifth char is ' '. */
char *currency_symbol; /* Local currency symbol */
char *mon_decimal_point; /* Radix character */
char *mon_thousands_sep; /* Like `thousands_sep' above */
char *mon_grouping; /* Like `grouping' above */
char *positive_sign; /* Sign for positive values */
char *negative_sign; /* Sign for negative values */
char int_frac_digits; /* Int'l fractional digits */
char frac_digits; /* Local fractional digits */
char p_cs_precedes; /* 1 if currency_symbol precedes a
positive value, 0 if succeeds */
char p_sep_by_space; /* 1 if a space separates currency_symbol
from a positive value */
char n_cs_precedes; /* 1 if currency_symbol precedes a
negative value, 0 if succeeds */
char n_sep_by_space; /* 1 if a space separates currency_symbol
from a negative value */
/* Positive and negative sign positions:
0 Parentheses surround the quantity and currency_symbol.
1 The sign string precedes the quantity and currency_symbol.
2 The sign string succeeds the quantity and currency_symbol.
3 The sign string immediately precedes the currency_symbol.
4 The sign string immediately succeeds the currency_symbol. */
char p_sign_posn;
char n_sign_posn;
};
CONFORME A
POSIX.1-2001.
Le funzioni GNU gettext sono specificate in LI18NUX2000.
VEDERE ANCHE
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)
Index
- NOME
-
- SINTASSI
-
- DESCRIZIONE
-
- CONFORME A
-
- VEDERE ANCHE
-
This document was created by
man2html,
using the manual pages.
Time: 23:03:53 GMT, June 17, 2008