Namensräume
Varianten
Aktionen

std::ctype<CharT>::widen, do_widen

Von cppreference.com
< cpp‎ | locale‎ | ctype
 
 
 
 
 
Definiert in Header <locale>
public:
CharT widen( char c ) const;
(1)
public:
const char* widen( const char* beg, const char* end, CharT* dst ) const;
(2)
protected:
virtual CharT do_widen( char c ) const;
(3)
protected:
virtual const char* do_widen( const char* beg, const char* end, CharT* dst ) const;
(4)
1,2) Öffentliche Member-Funktion, ruft die entsprechende geschützte virtuelle Member-Funktion do_widen-Überladung der am weitesten abgeleiteten Klasse auf. Überladung (1) ruft do_widen(c) auf, Überladung (2) ruft do_widen(beg, end, dst) auf.
3) Wandelt das einzelnes Byte umfassende Zeichen c in die entsprechende Wide-Character-Repräsentation unter Verwendung der einfachsten sinnvollen Transformation um. Typischerweise gilt dies nur für Zeichen, deren Multibyte-Kodierung ein einzelnes Byte ist (z. B. U+0000-U+007F in UTF-8).
4) Für jedes Zeichen im Zeichen-Array [begend) wird das entsprechende erweiterte Zeichen in die aufeinanderfolgenden Positionen im von dst zeigenden Zeichen-Array geschrieben.

Widening gibt immer ein Wide Character zurück, aber nur für Zeichen aus dem grundlegenden Quellzeichenset(bis C++23)grundlegenden Zeichensatz(seit C++23) ist garantiert, dass sie eine eindeutige, wohldefinierte und auch durch narrow() umkehrbare Erweiterungstransformation haben. In der Praxis werden alle Zeichen, deren Multibyte-Darstellung ein einzelnes Byte ist, normalerweise in ihre Wide-Character-Gegenstücke erweitert, und die übrigen möglichen Ein-Byte-Werte werden normalerweise auf denselben Platzhalterwert abgebildet, typischerweise CharT(-1).

Widening bewahrt, wenn erfolgreich, alle Zeichenklassifizierungs-Kategorien, die für is() bekannt sind.

Inhalt

[bearbeiten] Parameter

c - zu konvertierendes Zeichen
dflt - Standardwert, der zurückgegeben wird, wenn die Konvertierung fehlschlägt
beg - Zeiger auf das erste Zeichen in einem Array von Zeichen, das konvertiert werden soll
end - Zeiger auf die Position nach dem letzten Zeichen im Array von Zeichen, das konvertiert werden soll
dst - Zeiger auf das erste Element des Arrays von Zeichen, die gefüllt werden sollen

[bearbeiten] Rückgabewert

1,3) Erweitertes Zeichen.
2,4) end

[bearbeiten] Beispiel

#include <iostream>
#include <locale>
 
void try_widen(const std::ctype<wchar_t>& f, char c)
{
    wchar_t w = f.widen(c);
    std::cout << "The single-byte character " << +(unsigned char)c
              << " widens to " << +w << '\n';
}
 
int main()
{
    std::locale::global(std::locale("cs_CZ.iso88592"));
    auto& f = std::use_facet<std::ctype<wchar_t>>(std::locale());
    std::cout << std::hex << std::showbase << "In Czech ISO-8859-2 locale:\n";
    try_widen(f, 'a');
    try_widen(f, '\xdf'); // German letter ß (U+00df) in ISO-8859-2
    try_widen(f, '\xec'); // Czech letter ě (U+011b) in ISO-8859-2
 
    std::locale::global(std::locale("cs_CZ.utf8"));
    auto& f2 = std::use_facet<std::ctype<wchar_t>>(std::locale());
    std::cout << "In Czech UTF-8 locale:\n";
    try_widen(f2, 'a');
    try_widen(f2, '\xdf'); 
    try_widen(f2, '\xec'); 
}

Mögliche Ausgabe

In Czech ISO-8859-2 locale:
The single-byte character 0x61 widens to 0x61
The single-byte character 0xdf widens to 0xdf
The single-byte character 0xec widens to 0x11b
In Czech UTF-8 locale:
The single-byte character 0x61 widens to 0x61
The single-byte character 0xdf widens to 0xffffffff
The single-byte character 0xec widens to 0xffffffff

[bearbeiten] Fehlerberichte

Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 153 C++98 widen rief immer Überladung (4) auf ruft die entsprechende Überladung auf

[bearbeiten] Siehe auch

ruft do_narrow auf
(öffentliche Member-Funktion) [bearbeiten]
erweitert Zeichen
(public member function of std::basic_ios<CharT,Traits>) [bearbeiten]
erweitert ein ein Byte breites schmales Zeichen zu einem Wide-Zeichen, falls möglich
(Funktion) [bearbeiten]