ОБЗОР
#include <locale.h>
locale_t duplocale(locale_t locobj);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
duplocale():
Начиная с glibc 2.10: _XOPEN_SOURCE >= 700
До glibc 2.10: _GNU_SOURCE
ОПИСАНИЕ
Функция duplocale() создаёт копию объекта локали, на которую указывает
locobj.
Если значение locobj равно LC_GLOBAL_LOCALE, то duplocale() создаёт объект локали, содержащий копию глобальной локали, задаваемой setlocale(3).
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ
При успешном выполнении duplocale() возвращает описатель нового объекта
локали. При ошибке возвращается (locale_t) 0, а errno присваивается
код ошибки.
ОШИБКИ
ENOMEM Недостаточно памяти для создания копии объекта локали.
ВЕРСИИ
Функция duplocale() впервые появилась в версии 2.3 библиотеки GNU C.
СООТВЕТСТВИЕ СТАНДАРТАМ
POSIX.1-2008.
ЗАМЕЧАНИЯ
Создание копии локали может пригодиться в следующих случаях:
loc = uselocale((locale_t) 0);
Такая последовательность необходима, так как вызов uselocale(3) может вернуть значение LC_GLOBAL_LOCALE, которое вызовет непредсказуемое поведение, если будет передано в функции, подобные toupper_l(3). Вызов duplocale() можно использовать для проверки, что значение LC_GLOBAL_LOCALE преобразуется в подходящий объект локали. Смотрите
ПРИМЕР далее.
Каждый объект локали, созданный duplocale(), должен освобождаться с помощью freelocale(3).
ПРИМЕР
Представленная ниже программа использует uselocale(3) и duplocale()
для получения описателя текущей локали, который затем передаётся в
toupper_l(3). Программа распознаёт один аргумент командной строки, строку
символов, которая приводится к верхнему регистру и выводится в стандартный
вывод. Пример использования:
$ ./a.out abc ABC
Исходный код программы
#define _XOPEN_SOURCE 700 #include <ctype.h> #include <stdio.h> #include <stdlib.h> #include <locale.h> #define errExit(msg) do { perror(msg); exit(EXIT_FAILURE); \ } while (0) int main(int argc, char *argv[]) { locale_t loc, nloc; char *p; if (argc != 2) { fprintf(stderr, "Использование: %s строка\n", argv[0]); exit(EXIT_FAILURE); } /* Эта последовательность необходима, так как uselocale() может вернуть значение LC_GLOBAL_LOCALE, которое нельзя передавать как аргумент в toupper_l() */ loc = uselocale((locale_t) 0); if (loc == (locale_t) 0) errExit("uselocale"); nloc = duplocale(loc); if (nloc == (locale_t) 0) errExit("duplocale"); for (p = argv[1]; *p; p++) putchar(toupper_l(*p, nloc)); printf("\n"); freelocale(nloc); exit(EXIT_SUCCESS); }