DUPLOCALE(3) | Руководство программиста Linux | DUPLOCALE(3) |
ИМЯ¶
duplocale - создаёт копию объекта локали
СИНТАКСИС¶
#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.
ЗАМЕЧАНИЯ¶
Создание копии локали может пригодиться в следующих случаях:
- Для создания копии объекта локали, в которой одна или более категорий будут изменены (с помощью newlocale(3)).
- Для получения описателя текущей локали, который может использоваться в других функциях, таких как toupper_l(3). Для этого duplocale() передаётся значение, полученное от следующего вызова:
-
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); }
СМ. ТАКЖЕ¶
freelocale(3), newlocale(3), setlocale(3), uselocale(3), locale(5), locale(7)
ЗАМЕЧАНИЯ¶
Эта страница является частью проекта Linux man-pages версии 4.16. Описание проекта, информацию об ошибках и последнюю версию этой страницы можно найти по адресу https://www.kernel.org/doc/man-pages/.
ПЕРЕВОД¶
Русский перевод этой страницы руководства был сделан Yuri Kozlov <yuray@komyakino.ru> и Иван Павлов <pavia00@gmail.com>
Этот перевод является бесплатной документацией; прочитайте Стандартную общественную лицензию GNU версии 3 или более позднюю, чтобы узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ.
Если вы обнаружите ошибки в переводе этой страницы руководства, пожалуйста, отправьте электронное письмо на man-pages-ru-talks@lists.sourceforge.net.
15 сентября 2017 г. | Linux |