blob: de7f024fd467d9a45e2ab1f741aae9748d0891ee [file] [log] [blame]
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001//===----------------------------------------------------------------------===//
2//
Howard Hinnantf5256e12010-05-11 21:36:01 +00003// The LLVM Compiler Infrastructure
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00004//
Howard Hinnantb64f8b02010-11-16 22:09:02 +00005// This file is dual licensed under the MIT and the University of Illinois Open
6// Source Licenses. See LICENSE.TXT for details.
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00007//
8//===----------------------------------------------------------------------===//
9
10// <locale>
11
12// template <> class codecvt<char, char, mbstate_t>
13
Howard Hinnant22a74dc2010-08-22 00:39:25 +000014// result out(stateT& state,
15// const internT* from, const internT* from_end, const internT*& from_next,
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000016// externT* to, externT* to_end, externT*& to_next) const;
17
18#include <locale>
19#include <string>
20#include <vector>
21#include <cassert>
22
23typedef std::codecvt<char, char, std::mbstate_t> F;
24
25int main()
26{
27 std::locale l = std::locale::classic();
28 const std::basic_string<F::intern_type> from("some text");
29 std::vector<char> to(from.size());
30 const F& f = std::use_facet<F>(l);
Dan Albert1d4a1ed2016-05-25 22:36:09 -070031 std::mbstate_t mbs = {0};
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000032 const char* from_next = 0;
33 char* to_next = 0;
34 assert(f.out(mbs, from.data(), from.data() + from.size(), from_next,
35 to.data(), to.data() + to.size(), to_next) == F::noconv);
36 assert(from_next == from.data());
37 assert(to_next == to.data());
38}