Namespaces
Variants

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

From cppreference.net
std:: streambuf * rdbuf ( ) const ;
(1)
std:: streambuf * rdbuf ( std:: streambuf * bytebuf ) ;
(2)
1) Retourne le pointeur vers le flux d'octets sous-jacent.
2) Remplace le flux d'octets associé par bytebuf .

Valeur de retour

2) la valeur précédente de bufptr

Exemple

#include <codecvt>
#include <iostream>
#include <locale>
#include <sstream>
int main()
{
    // Convertir UTF-8 en UCS4
    std::stringbuf utf8buf("z\u00df\u6c34\U0001d10b");
                       // ou "\x7a\xc3\x9f\xe6\xb0\xb4\xf0\x9d\x84\x8b"
                       // ou u8"zß水𝄋"
    std::wbuffer_convert<std::codecvt_utf8<wchar_t>> conv(&utf8buf);
    std::wistream ucsbuf(&conv);
    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) << ' ';
    // Réutiliser le même wbuffer_convert pour gérer la sortie UCS4 vers UTF-8
    conv.rdbuf(std::cout.rdbuf());
    std::wostream out(&conv);
    std::cout << "\nEnvoi de données UCS4 vers std::cout via wbuffer_convert : ";
    out << L"z\u00df\u6c34\U0001d10b\n";
}

Sortie :

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

Voir aussi

construit un nouveau wbuffer_convert
(fonction membre publique)