Linux Man на русском

  User    Syst    Libr    Device    Files    Other    Admin  



   duplocale - создаёт копию объекта локали

duplocale(3) создаёт копию объекта локали


ОБЗОР

#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);
    }