Namespaces
Variants

std::regex_traits<CharT>:: isctype

From cppreference.net
Regular expressions library
Classes
(C++11)
Algorithms
Iterators
Exceptions
Traits
Constants
(C++11)
Regex Grammar
bool isctype ( CharT c, char_class_type f ) const ;
**Примечание:** Весь код C++ внутри тегов ` ` сохранен без изменений, как и требовалось. HTML структура и атрибуты также сохранены в оригинальном виде.

Определяет, принадлежит ли символ c классу символов, идентифицируемому значением f , которое, в свою очередь, является значением, возвращаемым lookup_classname() или побитовым ИЛИ нескольких таких значений.

Версия этой функции, предоставляемая в специализациях стандартной библиотеки для std::regex_traits , выполняет следующее:

1) Сначала преобразует f в значение m типа std::ctype_base::mask .
Для каждой категории std::ctype перечисленной в таблице на странице lookup_classname() , если биты в f соответствующие категории установлены, соответствующие биты в m также будут установлены.
2) Затем предпринимается попытка классифицировать символ в установленной локали, вызывая std:: use_facet < std:: ctype < CharT >> ( getloc ( ) ) . is ( m, c ) .
  • Если это возвращает true , isctype() также вернёт true .
  • В противном случае, если c равен '_' , и f включает результат вызова lookup_classname() для класса символов [:w:] , возвращается true , в противном случае возвращается false .

Содержание

Параметры

c - символ для классификации
f - битовая маска, полученная из одного или нескольких вызовов lookup_classname()

Возвращаемое значение

true если c классифицируется с помощью f , false в противном случае.

Пример

#include <iostream>
#include <regex>
#include <string>
int main()
{
    std::regex_traits<char> t;
    std::string str_alnum = "alnum";
    auto a = t.lookup_classname(str_alnum.begin(), str_alnum.end());
    std::string str_w = "w"; // [:w:] это [:alnum:] плюс '_'
    auto w = t.lookup_classname(str_w.begin(), str_w.end());
    std::cout << std::boolalpha
              << t.isctype('A', w) << ' ' << t.isctype('A', a) << '\n'
              << t.isctype('_', w) << ' ' << t.isctype('_', a) << '\n'
              << t.isctype(' ', w) << ' ' << t.isctype(' ', a) << '\n';
}

Вывод:

true true
true false
false false

Демонстрирует пользовательскую реализацию характеристик регулярных выражений для lookup_classname() / isctype() :

#include <cwctype>
#include <iostream>
#include <locale>
#include <regex>
// This custom regex traits uses wctype/iswctype to implement lookup_classname/isctype.
struct wctype_traits : std::regex_traits<wchar_t>
{
    using char_class_type = std::wctype_t;
    template<class It>
    char_class_type lookup_classname(It first, It last, bool = false) const
    {
        return std::wctype(std::string(first, last).c_str());
    }
    bool isctype(wchar_t c, char_class_type f) const
    {
        return std::iswctype(c, f);
    }
};
int main()
{
    std::locale::global(std::locale("ja_JP.utf8"));
    std::wcout.sync_with_stdio(false);
    std::wcout.imbue(std::locale());
    std::wsmatch m;
    std::wstring in = L"風の谷のナウシカ";
    // matches all characters (they are classified as alnum)
    std::regex_search(in, m, std::wregex(L"([[:alnum:]]+)"));
    std::wcout << "alnums: " << m[1] << '\n'; // prints "風の谷のナウシカ"
    // matches only the katakana
    std::regex_search(in, m,
                      std::basic_regex<wchar_t, wctype_traits>(L"([[:jkata:]]+)"));
    std::wcout << "katakana: " << m[1] << '\n'; // prints "ナウシカ"
}

Вывод:

alnums: 風の谷のナウシカ
katakana: ナウシカ

Отчёты о дефектах

Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены задним числом к ранее опубликованным стандартам C++.

DR Applied to Behavior as published Correct behavior
LWG 2018 C++11 the value of m was unspecified matches lookup_classname() 's minimal support

Смотрите также

получает класс символов по имени
(публичная функция-член)
[virtual]
классифицирует символ или последовательность символов
(виртуальная защищенная функция-член std::ctype<CharT> )
классифицирует широкий символ согласно указанной LC_CTYPE категории
(функция)