towlower_l(3) преобразует широкий символ к нижнему регистру

Other Alias

towlower

ОБЗОР

#include <wctype.h>


wint_t towlower(wint_t wc);
wint_t towlower_l(wint_t wc, locale_t locale);

Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

towlower_l():

Начиная с glibc 2.10:
_XOPEN_SOURCE >= 700
До glibc 2.10:
_GNU_SOURCE

ОПИСАНИЕ

Функция towlower() является широкосимвольным аналогом функции tolower(3). Если wc является широким символом в верхнем регистре и в текущей локали существует эквивалент в нижнем регистре, то возвращается эквивалент wc в нижнем регистре. Во всех остальных случаях wc возвращается неизменным.

Функция towupper_l() производит то же действие, но выполняет преобразование на основе информации о типе символа в локали, указанной в locale. Поведение towupper_l() не определёно, если значение locale равно специальному объекту локали LC_GLOBAL_LOCALE (смотрите duplocale(3)) или некорректному описателю объекта локали.

Аргумент wc должен быть представим типом wchar_t и быть корректным символом в локали или равняться значению WEOF.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

Если wc был преобразован к нижнему регистру, то towlower() возвращает его эквивалент в нижнем регистре; в противном случае возвращается wc.

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).
ИнтерфейсАтрибутЗначение
towlower() безвредность в нитяхбезвредно (MT-Safe locale)
towlower_l() безвредность в нитяхбезвредно (MT-Safe)

ВЕРСИИ

Функция towlower_l() впервые появилась в glibc 2.3.

СООТВЕТСТВИЕ СТАНДАРТАМ

towlower(): C99, POSIX.1-2001 (XSI); расширение XSI в POSIX.1-2008, но помечена как устаревшая.

towlower_l(): POSIX.1-2008.

ЗАМЕЧАНИЯ

Поведение этих функций зависит от категории LC_CTYPE локали.

Эти функции не очень подходят для работы с символами Юникода, так как в Юникоде есть три типа регистра: верхний, нижний и заглавный.