Namespaces
Variants

std:: iscntrl (std::locale)

From cppreference.net
Défini dans l'en-tête <locale>
template < class CharT >
bool iscntrl ( CharT ch, const locale & loc ) ;

Vérifie si le caractère donné est classifié comme un caractère de contrôle par la facette std::ctype de la locale donnée.

Table des matières

Paramètres

ch - caractère
loc - paramètres régionaux

Valeur de retour

Retourne true si le caractère est classifié comme caractère de contrôle, false sinon.

Implémentation possible

template<class CharT>
bool iscntrl(CharT ch, const std::locale& loc)
{
    return std::use_facet<std::ctype<CharT>>(loc).is(std::ctype_base::cntrl, ch);
}

Exemple

Démontre l'utilisation de iscntrl() avec différentes locales (spécifiques au système d'exploitation).

#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';
}

Sortie possible :

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

Voir aussi

vérifie si un caractère est un caractère de contrôle
(fonction)
vérifie si un caractère large est un caractère de contrôle
(fonction)