TOWUPPER(3) | Руководство программиста Linux | TOWUPPER(3) |
towupper, towupper_l - преобразует широкий символ к верхнему регистру
#include <wctype.h>
wint_t towupper(wint_t wc);
wint_t towupper_l(wint_t wc, locale_t locale);
Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):
towupper_l():
Функция towupper() является широкосимвольным аналогом функции toupper(3). Если wc является широким символом в нижнем регистре и в текущей локали существует эквивалент в верхнем регистре, то возвращается эквивалент wc в верхнем регистре. Во всех остальных случаях wc возвращается неизменным.
Функция towupper_l() производит то же действие, но выполняет преобразование на основе информации о типе символа в локали, указанной в locale. Поведение towupper_l() не определёно, если значение locale равно специальному объекту локали LC_GLOBAL_LOCALE (смотрите duplocale(3)) или некорректному описателю объекта локали.
Аргумент wc должен быть представим типом wchar_t и быть корректным символом в локали или равняться значению WEOF.
Если wc был преобразован к верхнему регистру, то towupper() возвращает его эквивалент в верхнем регистре; в противном случае возвращается wc.
Функция towupper_l() впервые появилась в glibc 2.3.
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
towupper() | Безвредность в нитях | MT-Safe locale |
towupper_l() | Безвредность в нитях | MT-Safe |
towupper(): C99, POSIX.1-2001 (XSI); расширение XSI в POSIX.1-2008, но помечена как устаревшая.
towupper_l(): POSIX.1-2008.
Поведение этих функций зависит от категории LC_CTYPE локали.
Эти функции не очень подходят для работы с символами Юникода, так как в Юникоде есть три типа регистра: верхний, нижний и заглавный.
2017-09-15 | GNU |