setlocale(3)


NAME

   setlocale - set the current locale

SYNOPSIS

   #include <locale.h>

   char *setlocale(int category, const char *locale);

DESCRIPTION

   The  setlocale() function is used to set or query the program's current
   locale.

   If locale is  not  NULL,  the  program's  current  locale  is  modified
   according  to  the  arguments.   The argument category determines which
   parts of the program's current locale should be modified.

   Category            Governs
   LC_ALL              All of the locale
   LC_ADDRESS          Formatting of addresses and
                       geography-related items (*)
   LC_COLLATE          String collation
   LC_CTYPE            Character classification
   LC_IDENTIFICATION   Metadata describing the locale (*)
   LC_MEASUREMENT      Settings related to measurements
                       (metric versus US customary) (*)
   LC_MESSAGES         Localizable natural-language messages
   LC_MONETARY         Formatting of monetary values
   LC_NAME             Formatting of salutations for persons (*)
   LC_NUMERIC          Formatting of nonmonetary numeric values
   LC_PAPER            Settings related to the standard paper size (*)
   LC_TELEPHONE        Formats to be used with telephone services (*)
   LC_TIME             Formatting of date and time values

   The categories marked with an asterisk  in  the  above  table  are  GNU
   extensions.   For  further  information on these locale categories, see
   locale(7).

   The argument locale is a pointer to a character string  containing  the
   required  setting  of  category.   Such a string is either a well-known
   constant like "C" or "da_DK" (see below), or an opaque string that  was
   returned by another call of setlocale().

   If  locale  is an empty string, "", each part of the locale that should
   be modified is set according to the environment variables.  The details
   are   implementation-dependent.    For   glibc,  first  (regardless  of
   category), the environment  variable  LC_ALL  is  inspected,  next  the
   environment  variable with the same name as the category (see the table
   above), and finally the environment variable LANG.  The first  existing
   environment  variable  is  used.   If  its  value is not a valid locale
   specification, the locale is unchanged, and setlocale() returns NULL.

   The locale "C" or "POSIX" is  a  portable  locale;  it  exists  on  all
   conforming systems.

   A      locale      name      is      typically      of     the     form
   language[_territory][.codeset][@modifier], where language is an ISO 639
   language  code, territory is an ISO 3166 country code, and codeset is a
   character set or encoding identifier like ISO-8859-1 or UTF-8.   For  a
   list of all supported locales, try "locale -a", cf. locale(1).

   If locale is NULL, the current locale is only queried, not modified.

   On  startup of the main program, the portable "C" locale is selected as
   default.  A program may be made portable to all locales by calling:

       setlocale(LC_ALL, "");

   after program initialization, by  using  the  values  returned  from  a
   localeconv(3)  call  for  locale-dependent  information,  by  using the
   multibyte  and  wide  character  functions  for  text   processing   if
   MB_CUR_MAX  >  1,  and  by  using strcoll(3), wcscoll(3) or strxfrm(3),
   wcsxfrm(3) to compare strings.

RETURN VALUE

   A  successful  call  to  setlocale()  returns  an  opaque  string  that
   corresponds  to the locale set.  This string may be allocated in static
   storage.  The string returned is such that a subsequent call with  that
   string  and  its  associated  category  will  restore  that part of the
   process's locale.  The return value is NULL if the  request  cannot  be
   honored.

ATTRIBUTES

   For   an   explanation   of   the  terms  used  in  this  section,  see
   attributes(7).

   
   Interface    Attribute      Value                      
   
   setlocale()  Thread safety  MT-Unsafe const:locale env 
   

CONFORMING TO

   POSIX.1-2001, POSIX.1-2008, C89, C99.

SEE ALSO

   locale(1),  localedef(1),  isalpha(3),  localeconv(3),  nl_langinfo(3),
   rpmatch(3), strcoll(3), strftime(3), charsets(7), locale(7)

COLOPHON

   This  page  is  part of release 4.09 of the Linux man-pages project.  A
   description of the project, information about reporting bugs,  and  the
   latest     version     of     this    page,    can    be    found    at
   https://www.kernel.org/doc/man-pages/.


More Linux Commands

manpages/vfs_time_audit.8.html
vfs_time_audit(8) - samba vfs module to log slow VFS operati
This VFS module is part of the samba(7) suite. The time_audit VFS module logs system calls that take longer than the number of milliseconds defined by the varia

manpages/sigfillset.3.html
sigfillset(3) - POSIX signal set operations. (Man Page).....
These functions allow the manipulation of POSIX signal sets. sigemptyset() initializes the signal set given by set to empty, with all signals excluded from the

manpages/vfs_streams_depot.8.html
vfs_streams_depot(8) - EXPERIMENTAL module to store alternat
This EXPERIMENTAL VFS module is part of the samba(7) suite. The vfs_streams_depot enables storing of NTFS alternate data streams in the file system. As a normal

manpages/XShmGetImage.3.html
XShmGetImage(3) - X Shared Memory extension functions.......
XShmQueryExtension checks to see if the shared memory extensions are available for the specified display. XShmQueryVersion returns the version numbers of the ex

manpages/pcre_table.5.html
pcre_table(5) - format of Postfix PCRE tables (Man Page)....
pcre_table.5 - The Postfix mail system uses optional tables for address rewriting, mail routing, or access control. These tables are usually in dbm or db format

manpages/s_server.1ssl.html
s_server(1ssl) - SSL/TLS server program - Linux manual page
The s_server command implements a generic SSL/TLS server which listens for connections on a given port using SSL/TLS. OPTIONS -accept port the TCP port to liste

manpages/snmpd.internal.5.html
snmpd.internal(5) - internal configuration of the Net-SNMP a
The snmpd.conf(5) man page defines the syntax and behaviour of the main configuration directives that can be used to control the operation of the Net-SNMP agent

manpages/vcs.4.html
vcs(4) - virtual console memory (Special - Linux man page)
/dev/vcs0 is a character device with major number 7 and minor number 0, usually of mode 0644 and owner root.tty. It refers to the memory of the currently displa

manpages/systemd-notify.1.html
systemd-notify(1) - Notify init system about start-up comple
systemd-notify may be called by daemon scripts to notify the init system about status changes. It can be used to send arbitrary information, encoded in an envir

manpages/acl_create_entry.3.html
acl_create_entry(3) - create a new ACL entry (Man Page).....
The acl_create_entry() function creates a new ACL entry in the ACL pointed to by the contents of the pointer argument acl_p. On success, the function returns a

manpages/gnutls_x509_crt_get_issuer.3.html
gnutls_x509_crt_get_issuer(3) - API function (Man Page).....
Return the Certificates Issuer DN as an opaque data type. You may use gnutls_x509_dn_get_rdn_ava() to decode the DN. Note that dn should be treated as constant.

manpages/passwd.5.html
passwd(5) - password file (File formats - Linux man page)...
The /etc/passwd file is a text file that describes user login accounts for the system. It should have read permission allowed for all users (many utilities, lik





We can't live, work or learn in freedom unless the software we use is free.