std::wstring_convert<Codecvt,Elem,Wide_alloc,Byte_alloc>::wstring_convert
From cppreference.com
wstring_convert() : wstring_convert( new Codecvt ) {} |
(1) | |
explicit wstring_convert( Codecvt* pcvt ); |
(2) | |
wstring_convert( Codecvt* pcvt, state_type state ); |
(3) | |
explicit wstring_convert( const byte_string& byte_err, const wide_string& wide_err = wide_string() ); |
(4) | |
wstring_convert( const std::wstring_convert& ) = delete; |
(5) | (since C++14) |
| Overload | Data members | ||||
|---|---|---|---|---|---|
byte_err_string
|
wide_err_string
|
cvtptr
|
cvtstate
|
cvtcount
| |
| (1) | default-initialized | new Codecvt
|
default-initialized | uninitialized | |
| (2) | pcvt
| ||||
| (3) | state
| ||||
| (4) | byte_err
|
wide_err
|
new Codecvt
|
state_type()
| |
2,3) If
pcvt is a null pointer, the behavior is undefined.Parameters
| pcvt | - | pointer to the conversion facet |
| state | - | initial value of the conversion shift state |
| byte_err | - | narrow string to display on errors |
| wide_err | - | wide string to display on errors |
Example
Run this code
#include <codecvt>
#include <locale>
#include <utility>
// utility wrapper to adapt locale-bound facets for wstring/wbuffer convert
template<class Facet>
struct deletable_facet : Facet
{
using Facet::Facet; // inherit constructors
~deletable_facet() {}
};
int main()
{
// UTF-16le / UCS4 conversion
std::wstring_convert
<std::codecvt_utf16<char32_t, 0x10ffff, std::little_endian>> u16to32;
// UTF-8 / wide string conversion with custom messages
std::wstring_convert<std::codecvt_utf8<wchar_t>> u8towide("Error!", L"Error!");
// GB18030 / wide string conversion facet
using F = deletable_facet<std::codecvt_byname<wchar_t, char, std::mbstate_t>>;
std::wstring_convert<F> gbtowide(new F("zh_CN.gb18030"));
}
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 2175 | C++11 | pcvt could be a null pointer
|
the behavior is undefined in this case |
| LWG 2176 | C++11 | constructors accepting single argument were implicit | made explicit |
| P0935R0 | C++11 | the default constructor was explicit | made implicit |