template< class ForwardIt > string_type lookup_collatename( ForwardIt first, ForwardIt last ) const; |
If the character sequence [first, last)
represents the name of a valid collating element in the currently imbued locale, returns the name of that collating element. Otherwise, returns an empty string.
Collating elements are the symbols found in POSIX regular expressions between [.
and .]
. For example, [.a.]
matches the character a
in the C locale. [.tilde.]
matches the character ~
in the C locale as well. [.ch.]
matches the digraph ch
in Czech locale, but generates std::regex_error
with error code std::regex_constants::error_collate
in most other locales.
first, last | - | a pair of iterators which determines the sequence of characters that represents a collating element name |
Type requirements | ||
-ForwardIt must meet the requirements of LegacyForwardIterator. |
The representation of the named collating element as a character string.
#include <iostream> #include <string> #include <regex> struct noisy_traits : std::regex_traits<char> { template< class Iter > string_type lookup_collatename( Iter first, Iter last ) const { string_type result = regex_traits::lookup_collatename(first, last); std::cout << "regex_traits<>::lookup_collatename(\"" << string_type(first, last) << "\") returns \"" << result << "\"\n"; return result; } }; int main() { std::string str = "z|}a"; // C locale collation order: x,y,z,{,|,},~ std::basic_regex<char, noisy_traits> re("[x-[.tilde.]]*a", std::regex::basic); std::cout << std::boolalpha << std::regex_match(str, re) << '\n'; }
Possible output:
regex_traits<>::lookup_collatename("tilde") returns "~" true
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/regex/regex_traits/lookup_collatename