std::iscntrl(std::locale)

From Cppreference

Jump to: navigation, search
Defined in header <locale>

template< class charT >
bool iscntrl( charT ch, const locale& loc );


Checks if the given character classified as a control character by the given locale's std::ctype facet.

Contents

[edit] Parameters

ch - character
loc - locale

[edit] Return value

Returns true if the character is classified as a control character, false otherwise.

[edit] Equivalent function

[edit] Example

Demonstrates the use of iscntrl() with different locales (OS-specific).

#include <iostream>
#include <locale>
int main()
{
    const wchar_t CCH = L'\u0094'; // Destructive Backspace in Unicode
 
    std::locale loc1("C");
    std::cout << "iscntrl(CCH, C locale) returned "
              << std::boolalpha << std::iscntrl(CCH, loc1) << '\n';
 
    std::locale loc2("en_US.UTF8");
    std::cout << "iscntrl(CCH, Unicode locale) returned "
              << std::boolalpha << std::iscntrl(CCH, loc2) << '\n';
}

Output:

iscntrl(CCH, C locale) returned false
iscntrl(CCH, Unicode locale) returned true

[edit] See also

iscntrl
checks if a character is a control character
(function)
iswcntrl
checks if a wide character is a control character
(function)