Namespaces
Variants

std::ctype<CharT>:: narrow, do_narrow

From cppreference.net
Défini dans l'en-tête <locale>
public :
char narrow ( CharT c, char dflt ) const ;
(1)
public :

const CharT * narrow ( const CharT * beg, const CharT * end,

char dflt, char * dst ) const ;
(2)
protected :
virtual char do_narrow ( CharT c, char dflt ) const ;
(3)
protected :

virtual const CharT * do_narrow ( const CharT * beg, const CharT * end,

char dflt, char * dst ) const ;
(4)
1,2) Fonction membre publique, appelle la fonction membre virtuelle protégée correspondante do_narrow surchargée de la classe la plus dérivée. La surcharge (1) appelle do_narrow ( c, dflt ) , la surcharge (2) appelle do_narrow ( beg, end, dflt, dst ) .
3) Convertit le caractère (éventuellement large) c en représentation multioctet si le caractère peut être représenté avec un seul octet (par exemple, les caractères ASCII dans l'encodage UTF-8 sont des octets simples). Renvoie dflt si une telle conversion n'existe pas.
4) Pour chaque caractère dans le tableau de caractères [ beg , end ) , écrit des caractères rétrécis (ou dflt lorsque le rétrécissement échoue) vers les emplacements successifs dans le tableau de caractères pointé par dst .

Le rétrécissement est toujours réussi et est toujours réversible (en appelant widen() ) pour tous les caractères du basic source character set (until C++23) basic character set (since C++23) .

Le rétrécissement, s'il réussit, préserve toutes les catégories de classification de caractères connues par is() .

  • c'est-à-dire is ( m, c ) || ! ctc. is ( m, do_narrow ( c, dflt ) ) est toujours true pour toute catégorie ctype nommée avec un facet ctype<char> ctc et une valeur ctype_base::mask m (sauf si do_narrow retourne dflt ).

Le rétrécissement de tout caractère numérique garantit que si le résultat est soustrait du littéral de caractère '0' , la différence est égale à la valeur numérique du caractère original.

  • c'est-à-dire pour tout caractère numérique c , l'expression ( do_narrow ( c, dflt ) - '0' ) évalue la valeur numérique du caractère.

Table des matières

Paramètres

c - caractère à convertir
dflt - valeur par défaut à produire si la conversion échoue
beg - pointeur vers le premier caractère dans un tableau de caractères à convertir
end - pointeur situé après le dernier caractère du tableau de caractères à convertir
dst - pointeur vers le premier élément du tableau de caractères à remplir

Valeur de retour

1,3) Caractère réduit ou dflt si la réduction échoue.
2,4) end

Exemple

#include <iostream>
#include <locale>
void try_narrow(const std::ctype<wchar_t>& f, wchar_t c)
{
    char n = f.narrow(c, 0);
    if (n)
        std::wcout << '\'' << c << "' narrowed to " << +(unsigned char)n << '\n';
    else
        std::wcout << '\'' << c << "' could not be narrowed\n";
}
int main()
{
    std::locale::global(std::locale("en_US.utf8"));
    std::wcout.imbue(std::locale());
    std::wcout << std::hex << std::showbase << "In US English UTF-8 locale:\n";
    auto& f = std::use_facet<std::ctype<wchar_t>>(std::locale());
    try_narrow(f, L'A');
    try_narrow(f, L'A');
    try_narrow(f, L'ě');
    std::locale::global(std::locale("cs_CZ.iso88592"));
    auto& f2 = std::use_facet<std::ctype<wchar_t>>(std::locale());
    std::wcout << "In Czech ISO-8859-2 locale:\n";
    try_narrow(f2, L'A');
    try_narrow(f2, L'A');
    try_narrow(f2, L'ě');
}

Sortie possible :

In US English UTF-8 locale:
'A' narrowed to 0x41
'A' could not be narrowed
'ě' could not be narrowed
In Czech ISO-8859-2 locale:
'A' narrowed to 0x41
'A' could not be narrowed
'ě' narrowed to 0xec

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR Appliqué à Comportement publié Comportement corrigé
LWG 126 C++98 1. le code représentant la réversibilité était
do_widen ( do_narrow ( c ) , 0 ) == c
2. le code représentant la préservation de catégorie était
is ( m, c ) || ! ctc. is ( m, do_narrow ( c ) , dflt )
les deux corrigés
LWG 153 C++98 narrow appelait toujours la surcharge (4) appelle la surcharge correspondante

Voir aussi

invoque do_widen
(fonction membre publique)
rétrécit les caractères
(fonction membre publique de std::basic_ios<CharT,Traits> )
rétrécit un caractère large en un caractère étroit sur un seul octet, si possible
(fonction)