Namespaces
Variants

std::wbuffer_convert<Codecvt,Elem,Tr>:: wbuffer_convert

From cppreference.net
wbuffer_convert ( ) : wbuffer_convert ( nullptr ) { }
(1)
explicit wbuffer_convert ( std:: streambuf * bytebuf,

Codecvt * pcvt = new Codecvt,

state_type state = state_type ( ) ) ;
(2)
wbuffer_convert ( const std:: wbuffer_convert & ) = delete ;
(3) (depuis C++14)
Surcharge Membres de données
bufptr cvtptr cvtstate
(1) nullptr new Codecvt state_type ( )
(2) bytebuf pcvt state
2) Si pcvt est un pointeur nul, le comportement est indéfini.
3) Le constructeur de copie est supprimé, wbuffer_convert n'est pas CopyConstructible .

Paramètres

bytebuf - pointeur vers le tampon sous-jacent
pcvt - pointeur vers une facette autonome (non gérée par une locale)
state - valeur initiale de l'état de conversion de caractères

Exemple

#include <codecvt>
#include <iostream>
#include <locale>
#include <sstream>
int main()
{
    // Encapsuler un flux de chaîne UTF-8 dans un wbuffer_convert UCS4
    std::stringbuf utf8buf("z\u00df\u6c34\U0001f34c");
                       // ou "\x7a\xc3\x9f\xe6\xb0\xb4\xf0\x9f\x8d\x8c"
                       // ou u8"zß水🍌"
    std::wbuffer_convert<std::codecvt_utf8<wchar_t>> conv_in(&utf8buf);
    std::wistream ucsbuf(&conv_in);
    std::cout << "Lecture depuis un stringbuf UTF-8 via wbuffer_convert : "
              << std::hex << std::showbase;
    for (wchar_t c; ucsbuf.get(c);)
        std::cout << static_cast<std::wint_t>(c) << ' ';
    // Encapsuler un std::cout compatible UTF-8 dans un wbuffer_convert UCS4 pour sortir des données UCS4
    std::wbuffer_convert<std::codecvt_utf8<wchar_t>> conv_out(std::cout.rdbuf());
    std::wostream out(&conv_out);
    std::cout << "\nEnvoi de données UCS4 vers std::cout via wbuffer_convert : ";
    out << L"z\u00df\u6c34\U0001f34c\n";
}

Sortie :

Lecture depuis un stringbuf UTF-8 via wbuffer_convert : 0x7a 0xdf 0x6c34 0x1f34c 
Envoi de données UCS4 vers std::cout via wbuffer_convert : zß水🍌

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 S'applique à Comportement publié Comportement corrigé
LWG 2175 C++11 pcvt pouvait être un pointeur nul le comportement est indéfini dans ce cas
LWG 2176 C++11 les constructeurs acceptant un seul argument étaient implicites rendus explicites
P0935R0 C++11 le constructeur par défaut était explicite rendu implicite