10b57cec5SDimitry Andric// -*- C++ -*- 20b57cec5SDimitry Andric//===----------------------------------------------------------------------===// 30b57cec5SDimitry Andric// 40b57cec5SDimitry Andric// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 50b57cec5SDimitry Andric// See https://llvm.org/LICENSE.txt for license information. 60b57cec5SDimitry Andric// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 70b57cec5SDimitry Andric// 80b57cec5SDimitry Andric//===----------------------------------------------------------------------===// 90b57cec5SDimitry Andric 100b57cec5SDimitry Andric#ifndef _LIBCPP___LOCALE 110b57cec5SDimitry Andric#define _LIBCPP___LOCALE 120b57cec5SDimitry Andric 13e8d8bef9SDimitry Andric#include <__availability> 14fe6060f1SDimitry Andric#include <__config> 150b57cec5SDimitry Andric#include <cctype> 16*04eeddc0SDimitry Andric#include <cstdint> 170b57cec5SDimitry Andric#include <locale.h> 18*04eeddc0SDimitry Andric#include <memory> 19*04eeddc0SDimitry Andric#include <mutex> 20*04eeddc0SDimitry Andric#include <string> 21*04eeddc0SDimitry Andric#include <utility> 22*04eeddc0SDimitry Andric 230b57cec5SDimitry Andric#if defined(_LIBCPP_MSVCRT_LIKE) 240b57cec5SDimitry Andric# include <cstring> 25d409305fSDimitry Andric# include <__support/win32/locale_win32.h> 26e8d8bef9SDimitry Andric#elif defined(_AIX) || defined(__MVS__) 27d409305fSDimitry Andric# include <__support/ibm/xlocale.h> 280b57cec5SDimitry Andric#elif defined(__ANDROID__) 29d409305fSDimitry Andric# include <__support/android/locale_bionic.h> 300b57cec5SDimitry Andric#elif defined(__sun__) 310b57cec5SDimitry Andric# include <xlocale.h> 32d409305fSDimitry Andric# include <__support/solaris/xlocale.h> 330b57cec5SDimitry Andric#elif defined(_NEWLIB_VERSION) 34d409305fSDimitry Andric# include <__support/newlib/xlocale.h> 35e8d8bef9SDimitry Andric#elif defined(__OpenBSD__) 36d409305fSDimitry Andric# include <__support/openbsd/xlocale.h> 370b57cec5SDimitry Andric#elif (defined(__APPLE__) || defined(__FreeBSD__) \ 380b57cec5SDimitry Andric || defined(__EMSCRIPTEN__) || defined(__IBMCPP__)) 390b57cec5SDimitry Andric# include <xlocale.h> 400b57cec5SDimitry Andric#elif defined(__Fuchsia__) 41d409305fSDimitry Andric# include <__support/fuchsia/xlocale.h> 420b57cec5SDimitry Andric#elif defined(__wasi__) 430b57cec5SDimitry Andric// WASI libc uses musl's locales support. 44d409305fSDimitry Andric# include <__support/musl/xlocale.h> 450b57cec5SDimitry Andric#elif defined(_LIBCPP_HAS_MUSL_LIBC) 46d409305fSDimitry Andric# include <__support/musl/xlocale.h> 470b57cec5SDimitry Andric#endif 480b57cec5SDimitry Andric 490b57cec5SDimitry Andric#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) 500b57cec5SDimitry Andric#pragma GCC system_header 510b57cec5SDimitry Andric#endif 520b57cec5SDimitry Andric 530b57cec5SDimitry Andric_LIBCPP_BEGIN_NAMESPACE_STD 540b57cec5SDimitry Andric 550b57cec5SDimitry Andric#if !defined(_LIBCPP_LOCALE__L_EXTENSIONS) 560b57cec5SDimitry Andricstruct __libcpp_locale_guard { 570b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 580b57cec5SDimitry Andric __libcpp_locale_guard(locale_t& __loc) : __old_loc_(uselocale(__loc)) {} 590b57cec5SDimitry Andric 600b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 610b57cec5SDimitry Andric ~__libcpp_locale_guard() { 620b57cec5SDimitry Andric if (__old_loc_) 630b57cec5SDimitry Andric uselocale(__old_loc_); 640b57cec5SDimitry Andric } 650b57cec5SDimitry Andric 660b57cec5SDimitry Andric locale_t __old_loc_; 670b57cec5SDimitry Andricprivate: 680b57cec5SDimitry Andric __libcpp_locale_guard(__libcpp_locale_guard const&); 690b57cec5SDimitry Andric __libcpp_locale_guard& operator=(__libcpp_locale_guard const&); 700b57cec5SDimitry Andric}; 710b57cec5SDimitry Andric#elif defined(_LIBCPP_MSVCRT_LIKE) 720b57cec5SDimitry Andricstruct __libcpp_locale_guard { 730b57cec5SDimitry Andric __libcpp_locale_guard(locale_t __l) : 740b57cec5SDimitry Andric __status(_configthreadlocale(_ENABLE_PER_THREAD_LOCALE)) { 750b57cec5SDimitry Andric // Setting the locale can be expensive even when the locale given is 760b57cec5SDimitry Andric // already the current locale, so do an explicit check to see if the 770b57cec5SDimitry Andric // current locale is already the one we want. 780b57cec5SDimitry Andric const char* __lc = __setlocale(nullptr); 790b57cec5SDimitry Andric // If every category is the same, the locale string will simply be the 800b57cec5SDimitry Andric // locale name, otherwise it will be a semicolon-separated string listing 810b57cec5SDimitry Andric // each category. In the second case, we know at least one category won't 820b57cec5SDimitry Andric // be what we want, so we only have to check the first case. 83e8d8bef9SDimitry Andric if (_VSTD::strcmp(__l.__get_locale(), __lc) != 0) { 840b57cec5SDimitry Andric __locale_all = _strdup(__lc); 850b57cec5SDimitry Andric if (__locale_all == nullptr) 860b57cec5SDimitry Andric __throw_bad_alloc(); 870b57cec5SDimitry Andric __setlocale(__l.__get_locale()); 880b57cec5SDimitry Andric } 890b57cec5SDimitry Andric } 900b57cec5SDimitry Andric ~__libcpp_locale_guard() { 910b57cec5SDimitry Andric // The CRT documentation doesn't explicitly say, but setlocale() does the 920b57cec5SDimitry Andric // right thing when given a semicolon-separated list of locale settings 930b57cec5SDimitry Andric // for the different categories in the same format as returned by 940b57cec5SDimitry Andric // setlocale(LC_ALL, nullptr). 950b57cec5SDimitry Andric if (__locale_all != nullptr) { 960b57cec5SDimitry Andric __setlocale(__locale_all); 970b57cec5SDimitry Andric free(__locale_all); 980b57cec5SDimitry Andric } 990b57cec5SDimitry Andric _configthreadlocale(__status); 1000b57cec5SDimitry Andric } 1010b57cec5SDimitry Andric static const char* __setlocale(const char* __locale) { 1020b57cec5SDimitry Andric const char* __new_locale = setlocale(LC_ALL, __locale); 1030b57cec5SDimitry Andric if (__new_locale == nullptr) 1040b57cec5SDimitry Andric __throw_bad_alloc(); 1050b57cec5SDimitry Andric return __new_locale; 1060b57cec5SDimitry Andric } 1070b57cec5SDimitry Andric int __status; 1080b57cec5SDimitry Andric char* __locale_all = nullptr; 1090b57cec5SDimitry Andric}; 1100b57cec5SDimitry Andric#endif 1110b57cec5SDimitry Andric 1120b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS locale; 1130b57cec5SDimitry Andric 1140b57cec5SDimitry Andrictemplate <class _Facet> 1150b57cec5SDimitry Andric_LIBCPP_INLINE_VISIBILITY 1160b57cec5SDimitry Andricbool 1170b57cec5SDimitry Andrichas_facet(const locale&) _NOEXCEPT; 1180b57cec5SDimitry Andric 1190b57cec5SDimitry Andrictemplate <class _Facet> 1200b57cec5SDimitry Andric_LIBCPP_INLINE_VISIBILITY 1210b57cec5SDimitry Andricconst _Facet& 1220b57cec5SDimitry Andricuse_facet(const locale&); 1230b57cec5SDimitry Andric 1240b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS locale 1250b57cec5SDimitry Andric{ 1260b57cec5SDimitry Andricpublic: 1270b57cec5SDimitry Andric // types: 1280b57cec5SDimitry Andric class _LIBCPP_TYPE_VIS facet; 1290b57cec5SDimitry Andric class _LIBCPP_TYPE_VIS id; 1300b57cec5SDimitry Andric 1310b57cec5SDimitry Andric typedef int category; 1320b57cec5SDimitry Andric _LIBCPP_AVAILABILITY_LOCALE_CATEGORY 1330b57cec5SDimitry Andric static const category // values assigned here are for exposition only 1340b57cec5SDimitry Andric none = 0, 1350b57cec5SDimitry Andric collate = LC_COLLATE_MASK, 1360b57cec5SDimitry Andric ctype = LC_CTYPE_MASK, 1370b57cec5SDimitry Andric monetary = LC_MONETARY_MASK, 1380b57cec5SDimitry Andric numeric = LC_NUMERIC_MASK, 1390b57cec5SDimitry Andric time = LC_TIME_MASK, 1400b57cec5SDimitry Andric messages = LC_MESSAGES_MASK, 1410b57cec5SDimitry Andric all = collate | ctype | monetary | numeric | time | messages; 1420b57cec5SDimitry Andric 1430b57cec5SDimitry Andric // construct/copy/destroy: 1440b57cec5SDimitry Andric locale() _NOEXCEPT; 1450b57cec5SDimitry Andric locale(const locale&) _NOEXCEPT; 1460b57cec5SDimitry Andric explicit locale(const char*); 1470b57cec5SDimitry Andric explicit locale(const string&); 1480b57cec5SDimitry Andric locale(const locale&, const char*, category); 1490b57cec5SDimitry Andric locale(const locale&, const string&, category); 1500b57cec5SDimitry Andric template <class _Facet> 1510b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY locale(const locale&, _Facet*); 1520b57cec5SDimitry Andric locale(const locale&, const locale&, category); 1530b57cec5SDimitry Andric 1540b57cec5SDimitry Andric ~locale(); 1550b57cec5SDimitry Andric 1560b57cec5SDimitry Andric const locale& operator=(const locale&) _NOEXCEPT; 1570b57cec5SDimitry Andric 1580b57cec5SDimitry Andric template <class _Facet> 1590b57cec5SDimitry Andric _LIBCPP_METHOD_TEMPLATE_IMPLICIT_INSTANTIATION_VIS 1600b57cec5SDimitry Andric locale combine(const locale&) const; 1610b57cec5SDimitry Andric 1620b57cec5SDimitry Andric // locale operations: 1630b57cec5SDimitry Andric string name() const; 1640b57cec5SDimitry Andric bool operator==(const locale&) const; 1650b57cec5SDimitry Andric bool operator!=(const locale& __y) const {return !(*this == __y);} 1660b57cec5SDimitry Andric template <class _CharT, class _Traits, class _Allocator> 1670b57cec5SDimitry Andric _LIBCPP_METHOD_TEMPLATE_IMPLICIT_INSTANTIATION_VIS 1680b57cec5SDimitry Andric bool operator()(const basic_string<_CharT, _Traits, _Allocator>&, 1690b57cec5SDimitry Andric const basic_string<_CharT, _Traits, _Allocator>&) const; 1700b57cec5SDimitry Andric 1710b57cec5SDimitry Andric // global locale objects: 1720b57cec5SDimitry Andric static locale global(const locale&); 1730b57cec5SDimitry Andric static const locale& classic(); 1740b57cec5SDimitry Andric 1750b57cec5SDimitry Andricprivate: 1760b57cec5SDimitry Andric class __imp; 1770b57cec5SDimitry Andric __imp* __locale_; 1780b57cec5SDimitry Andric 1790b57cec5SDimitry Andric void __install_ctor(const locale&, facet*, long); 1800b57cec5SDimitry Andric static locale& __global(); 1810b57cec5SDimitry Andric bool has_facet(id&) const; 1820b57cec5SDimitry Andric const facet* use_facet(id&) const; 1830b57cec5SDimitry Andric 1840b57cec5SDimitry Andric template <class _Facet> friend bool has_facet(const locale&) _NOEXCEPT; 1850b57cec5SDimitry Andric template <class _Facet> friend const _Facet& use_facet(const locale&); 1860b57cec5SDimitry Andric}; 1870b57cec5SDimitry Andric 1880b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS locale::facet 1890b57cec5SDimitry Andric : public __shared_count 1900b57cec5SDimitry Andric{ 1910b57cec5SDimitry Andricprotected: 1920b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1930b57cec5SDimitry Andric explicit facet(size_t __refs = 0) 1940b57cec5SDimitry Andric : __shared_count(static_cast<long>(__refs)-1) {} 1950b57cec5SDimitry Andric 1960b57cec5SDimitry Andric virtual ~facet(); 1970b57cec5SDimitry Andric 1980b57cec5SDimitry Andric// facet(const facet&) = delete; // effectively done in __shared_count 1990b57cec5SDimitry Andric// void operator=(const facet&) = delete; 2000b57cec5SDimitry Andricprivate: 2010b57cec5SDimitry Andric virtual void __on_zero_shared() _NOEXCEPT; 2020b57cec5SDimitry Andric}; 2030b57cec5SDimitry Andric 2040b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS locale::id 2050b57cec5SDimitry Andric{ 2060b57cec5SDimitry Andric once_flag __flag_; 2070b57cec5SDimitry Andric int32_t __id_; 2080b57cec5SDimitry Andric 2090b57cec5SDimitry Andric static int32_t __next_id; 2100b57cec5SDimitry Andricpublic: 2110b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR id() :__id_(0) {} 2120eae32dcSDimitry Andric void operator=(const id&) = delete; 2130eae32dcSDimitry Andric id(const id&) = delete; 2140eae32dcSDimitry Andric 2150b57cec5SDimitry Andricprivate: 2160b57cec5SDimitry Andric void __init(); 2170b57cec5SDimitry Andricpublic: // only needed for tests 2180b57cec5SDimitry Andric long __get(); 2190b57cec5SDimitry Andric 2200b57cec5SDimitry Andric friend class locale; 2210b57cec5SDimitry Andric friend class locale::__imp; 2220b57cec5SDimitry Andric}; 2230b57cec5SDimitry Andric 2240b57cec5SDimitry Andrictemplate <class _Facet> 2250b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 2260b57cec5SDimitry Andriclocale::locale(const locale& __other, _Facet* __f) 2270b57cec5SDimitry Andric{ 2280b57cec5SDimitry Andric __install_ctor(__other, __f, __f ? __f->id.__get() : 0); 2290b57cec5SDimitry Andric} 2300b57cec5SDimitry Andric 2310b57cec5SDimitry Andrictemplate <class _Facet> 2320b57cec5SDimitry Andriclocale 2330b57cec5SDimitry Andriclocale::combine(const locale& __other) const 2340b57cec5SDimitry Andric{ 2350b57cec5SDimitry Andric if (!_VSTD::has_facet<_Facet>(__other)) 2360b57cec5SDimitry Andric __throw_runtime_error("locale::combine: locale missing facet"); 2370b57cec5SDimitry Andric 2380b57cec5SDimitry Andric return locale(*this, &const_cast<_Facet&>(_VSTD::use_facet<_Facet>(__other))); 2390b57cec5SDimitry Andric} 2400b57cec5SDimitry Andric 2410b57cec5SDimitry Andrictemplate <class _Facet> 2420b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 2430b57cec5SDimitry Andricbool 2440b57cec5SDimitry Andrichas_facet(const locale& __l) _NOEXCEPT 2450b57cec5SDimitry Andric{ 2460b57cec5SDimitry Andric return __l.has_facet(_Facet::id); 2470b57cec5SDimitry Andric} 2480b57cec5SDimitry Andric 2490b57cec5SDimitry Andrictemplate <class _Facet> 2500b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 2510b57cec5SDimitry Andricconst _Facet& 2520b57cec5SDimitry Andricuse_facet(const locale& __l) 2530b57cec5SDimitry Andric{ 2540b57cec5SDimitry Andric return static_cast<const _Facet&>(*__l.use_facet(_Facet::id)); 2550b57cec5SDimitry Andric} 2560b57cec5SDimitry Andric 2570b57cec5SDimitry Andric// template <class _CharT> class collate; 2580b57cec5SDimitry Andric 2590b57cec5SDimitry Andrictemplate <class _CharT> 2600b57cec5SDimitry Andricclass _LIBCPP_TEMPLATE_VIS collate 2610b57cec5SDimitry Andric : public locale::facet 2620b57cec5SDimitry Andric{ 2630b57cec5SDimitry Andricpublic: 2640b57cec5SDimitry Andric typedef _CharT char_type; 2650b57cec5SDimitry Andric typedef basic_string<char_type> string_type; 2660b57cec5SDimitry Andric 2670b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 2680b57cec5SDimitry Andric explicit collate(size_t __refs = 0) 2690b57cec5SDimitry Andric : locale::facet(__refs) {} 2700b57cec5SDimitry Andric 2710b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 2720b57cec5SDimitry Andric int compare(const char_type* __lo1, const char_type* __hi1, 2730b57cec5SDimitry Andric const char_type* __lo2, const char_type* __hi2) const 2740b57cec5SDimitry Andric { 2750b57cec5SDimitry Andric return do_compare(__lo1, __hi1, __lo2, __hi2); 2760b57cec5SDimitry Andric } 2770b57cec5SDimitry Andric 2780b57cec5SDimitry Andric // FIXME(EricWF): The _LIBCPP_ALWAYS_INLINE is needed on Windows to work 2790b57cec5SDimitry Andric // around a dllimport bug that expects an external instantiation. 2800b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 2810b57cec5SDimitry Andric _LIBCPP_ALWAYS_INLINE 2820b57cec5SDimitry Andric string_type transform(const char_type* __lo, const char_type* __hi) const 2830b57cec5SDimitry Andric { 2840b57cec5SDimitry Andric return do_transform(__lo, __hi); 2850b57cec5SDimitry Andric } 2860b57cec5SDimitry Andric 2870b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 2880b57cec5SDimitry Andric long hash(const char_type* __lo, const char_type* __hi) const 2890b57cec5SDimitry Andric { 2900b57cec5SDimitry Andric return do_hash(__lo, __hi); 2910b57cec5SDimitry Andric } 2920b57cec5SDimitry Andric 2930b57cec5SDimitry Andric static locale::id id; 2940b57cec5SDimitry Andric 2950b57cec5SDimitry Andricprotected: 2960b57cec5SDimitry Andric ~collate(); 2970b57cec5SDimitry Andric virtual int do_compare(const char_type* __lo1, const char_type* __hi1, 2980b57cec5SDimitry Andric const char_type* __lo2, const char_type* __hi2) const; 2990b57cec5SDimitry Andric virtual string_type do_transform(const char_type* __lo, const char_type* __hi) const 3000b57cec5SDimitry Andric {return string_type(__lo, __hi);} 3010b57cec5SDimitry Andric virtual long do_hash(const char_type* __lo, const char_type* __hi) const; 3020b57cec5SDimitry Andric}; 3030b57cec5SDimitry Andric 3040b57cec5SDimitry Andrictemplate <class _CharT> locale::id collate<_CharT>::id; 3050b57cec5SDimitry Andric 3060b57cec5SDimitry Andrictemplate <class _CharT> 3070b57cec5SDimitry Andriccollate<_CharT>::~collate() 3080b57cec5SDimitry Andric{ 3090b57cec5SDimitry Andric} 3100b57cec5SDimitry Andric 3110b57cec5SDimitry Andrictemplate <class _CharT> 3120b57cec5SDimitry Andricint 3130b57cec5SDimitry Andriccollate<_CharT>::do_compare(const char_type* __lo1, const char_type* __hi1, 3140b57cec5SDimitry Andric const char_type* __lo2, const char_type* __hi2) const 3150b57cec5SDimitry Andric{ 3160b57cec5SDimitry Andric for (; __lo2 != __hi2; ++__lo1, ++__lo2) 3170b57cec5SDimitry Andric { 3180b57cec5SDimitry Andric if (__lo1 == __hi1 || *__lo1 < *__lo2) 3190b57cec5SDimitry Andric return -1; 3200b57cec5SDimitry Andric if (*__lo2 < *__lo1) 3210b57cec5SDimitry Andric return 1; 3220b57cec5SDimitry Andric } 3230b57cec5SDimitry Andric return __lo1 != __hi1; 3240b57cec5SDimitry Andric} 3250b57cec5SDimitry Andric 3260b57cec5SDimitry Andrictemplate <class _CharT> 3270b57cec5SDimitry Andriclong 3280b57cec5SDimitry Andriccollate<_CharT>::do_hash(const char_type* __lo, const char_type* __hi) const 3290b57cec5SDimitry Andric{ 3300b57cec5SDimitry Andric size_t __h = 0; 3310b57cec5SDimitry Andric const size_t __sr = __CHAR_BIT__ * sizeof(size_t) - 8; 3320b57cec5SDimitry Andric const size_t __mask = size_t(0xF) << (__sr + 4); 3330b57cec5SDimitry Andric for(const char_type* __p = __lo; __p != __hi; ++__p) 3340b57cec5SDimitry Andric { 3350b57cec5SDimitry Andric __h = (__h << 4) + static_cast<size_t>(*__p); 3360b57cec5SDimitry Andric size_t __g = __h & __mask; 3370b57cec5SDimitry Andric __h ^= __g | (__g >> __sr); 3380b57cec5SDimitry Andric } 3390b57cec5SDimitry Andric return static_cast<long>(__h); 3400b57cec5SDimitry Andric} 3410b57cec5SDimitry Andric 342e8d8bef9SDimitry Andric_LIBCPP_EXTERN_TEMPLATE_EVEN_IN_DEBUG_MODE(class _LIBCPP_EXTERN_TEMPLATE_TYPE_VIS collate<char>) 343349cc55cSDimitry Andric#ifndef _LIBCPP_HAS_NO_WIDE_CHARACTERS 344e8d8bef9SDimitry Andric_LIBCPP_EXTERN_TEMPLATE_EVEN_IN_DEBUG_MODE(class _LIBCPP_EXTERN_TEMPLATE_TYPE_VIS collate<wchar_t>) 345349cc55cSDimitry Andric#endif 3460b57cec5SDimitry Andric 3470b57cec5SDimitry Andric// template <class CharT> class collate_byname; 3480b57cec5SDimitry Andric 3490b57cec5SDimitry Andrictemplate <class _CharT> class _LIBCPP_TEMPLATE_VIS collate_byname; 3500b57cec5SDimitry Andric 3510b57cec5SDimitry Andrictemplate <> 3520b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS collate_byname<char> 3530b57cec5SDimitry Andric : public collate<char> 3540b57cec5SDimitry Andric{ 3550b57cec5SDimitry Andric locale_t __l; 3560b57cec5SDimitry Andricpublic: 3570b57cec5SDimitry Andric typedef char char_type; 3580b57cec5SDimitry Andric typedef basic_string<char_type> string_type; 3590b57cec5SDimitry Andric 3600b57cec5SDimitry Andric explicit collate_byname(const char* __n, size_t __refs = 0); 3610b57cec5SDimitry Andric explicit collate_byname(const string& __n, size_t __refs = 0); 3620b57cec5SDimitry Andric 3630b57cec5SDimitry Andricprotected: 3640b57cec5SDimitry Andric ~collate_byname(); 3650b57cec5SDimitry Andric virtual int do_compare(const char_type* __lo1, const char_type* __hi1, 3660b57cec5SDimitry Andric const char_type* __lo2, const char_type* __hi2) const; 3670b57cec5SDimitry Andric virtual string_type do_transform(const char_type* __lo, const char_type* __hi) const; 3680b57cec5SDimitry Andric}; 3690b57cec5SDimitry Andric 370349cc55cSDimitry Andric#ifndef _LIBCPP_HAS_NO_WIDE_CHARACTERS 3710b57cec5SDimitry Andrictemplate <> 3720b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS collate_byname<wchar_t> 3730b57cec5SDimitry Andric : public collate<wchar_t> 3740b57cec5SDimitry Andric{ 3750b57cec5SDimitry Andric locale_t __l; 3760b57cec5SDimitry Andricpublic: 3770b57cec5SDimitry Andric typedef wchar_t char_type; 3780b57cec5SDimitry Andric typedef basic_string<char_type> string_type; 3790b57cec5SDimitry Andric 3800b57cec5SDimitry Andric explicit collate_byname(const char* __n, size_t __refs = 0); 3810b57cec5SDimitry Andric explicit collate_byname(const string& __n, size_t __refs = 0); 3820b57cec5SDimitry Andric 3830b57cec5SDimitry Andricprotected: 3840b57cec5SDimitry Andric ~collate_byname(); 3850b57cec5SDimitry Andric 3860b57cec5SDimitry Andric virtual int do_compare(const char_type* __lo1, const char_type* __hi1, 3870b57cec5SDimitry Andric const char_type* __lo2, const char_type* __hi2) const; 3880b57cec5SDimitry Andric virtual string_type do_transform(const char_type* __lo, const char_type* __hi) const; 3890b57cec5SDimitry Andric}; 390349cc55cSDimitry Andric#endif 3910b57cec5SDimitry Andric 3920b57cec5SDimitry Andrictemplate <class _CharT, class _Traits, class _Allocator> 3930b57cec5SDimitry Andricbool 3940b57cec5SDimitry Andriclocale::operator()(const basic_string<_CharT, _Traits, _Allocator>& __x, 3950b57cec5SDimitry Andric const basic_string<_CharT, _Traits, _Allocator>& __y) const 3960b57cec5SDimitry Andric{ 3970b57cec5SDimitry Andric return _VSTD::use_facet<_VSTD::collate<_CharT> >(*this).compare( 3980b57cec5SDimitry Andric __x.data(), __x.data() + __x.size(), 3990b57cec5SDimitry Andric __y.data(), __y.data() + __y.size()) < 0; 4000b57cec5SDimitry Andric} 4010b57cec5SDimitry Andric 4020b57cec5SDimitry Andric// template <class charT> class ctype 4030b57cec5SDimitry Andric 4040b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS ctype_base 4050b57cec5SDimitry Andric{ 4060b57cec5SDimitry Andricpublic: 407e8d8bef9SDimitry Andric#if defined(_LIBCPP_PROVIDES_DEFAULT_RUNE_TABLE) 408e8d8bef9SDimitry Andric typedef unsigned long mask; 409e8d8bef9SDimitry Andric static const mask space = 1<<0; 410e8d8bef9SDimitry Andric static const mask print = 1<<1; 411e8d8bef9SDimitry Andric static const mask cntrl = 1<<2; 412e8d8bef9SDimitry Andric static const mask upper = 1<<3; 413e8d8bef9SDimitry Andric static const mask lower = 1<<4; 414e8d8bef9SDimitry Andric static const mask alpha = 1<<5; 415e8d8bef9SDimitry Andric static const mask digit = 1<<6; 416e8d8bef9SDimitry Andric static const mask punct = 1<<7; 417e8d8bef9SDimitry Andric static const mask xdigit = 1<<8; 418e8d8bef9SDimitry Andric static const mask blank = 1<<9; 419e8d8bef9SDimitry Andric#if defined(__BIONIC__) 420e8d8bef9SDimitry Andric // Historically this was a part of regex_traits rather than ctype_base. The 421e8d8bef9SDimitry Andric // historical value of the constant is preserved for ABI compatibility. 422e8d8bef9SDimitry Andric static const mask __regex_word = 0x8000; 423e8d8bef9SDimitry Andric#else 424e8d8bef9SDimitry Andric static const mask __regex_word = 1<<10; 425e8d8bef9SDimitry Andric#endif // defined(__BIONIC__) 426e8d8bef9SDimitry Andric#elif defined(__GLIBC__) 4270b57cec5SDimitry Andric typedef unsigned short mask; 4280b57cec5SDimitry Andric static const mask space = _ISspace; 4290b57cec5SDimitry Andric static const mask print = _ISprint; 4300b57cec5SDimitry Andric static const mask cntrl = _IScntrl; 4310b57cec5SDimitry Andric static const mask upper = _ISupper; 4320b57cec5SDimitry Andric static const mask lower = _ISlower; 4330b57cec5SDimitry Andric static const mask alpha = _ISalpha; 4340b57cec5SDimitry Andric static const mask digit = _ISdigit; 4350b57cec5SDimitry Andric static const mask punct = _ISpunct; 4360b57cec5SDimitry Andric static const mask xdigit = _ISxdigit; 4370b57cec5SDimitry Andric static const mask blank = _ISblank; 4380b57cec5SDimitry Andric#if defined(__mips__) 4390b57cec5SDimitry Andric static const mask __regex_word = static_cast<mask>(_ISbit(15)); 4400b57cec5SDimitry Andric#else 4410b57cec5SDimitry Andric static const mask __regex_word = 0x80; 4420b57cec5SDimitry Andric#endif 4430b57cec5SDimitry Andric#elif defined(_LIBCPP_MSVCRT_LIKE) 4440b57cec5SDimitry Andric typedef unsigned short mask; 4450b57cec5SDimitry Andric static const mask space = _SPACE; 4460b57cec5SDimitry Andric static const mask print = _BLANK|_PUNCT|_ALPHA|_DIGIT; 4470b57cec5SDimitry Andric static const mask cntrl = _CONTROL; 4480b57cec5SDimitry Andric static const mask upper = _UPPER; 4490b57cec5SDimitry Andric static const mask lower = _LOWER; 4500b57cec5SDimitry Andric static const mask alpha = _ALPHA; 4510b57cec5SDimitry Andric static const mask digit = _DIGIT; 4520b57cec5SDimitry Andric static const mask punct = _PUNCT; 4530b57cec5SDimitry Andric static const mask xdigit = _HEX; 4540b57cec5SDimitry Andric static const mask blank = _BLANK; 4550b57cec5SDimitry Andric static const mask __regex_word = 0x80; 4560b57cec5SDimitry Andric# define _LIBCPP_CTYPE_MASK_IS_COMPOSITE_PRINT 4570b57cec5SDimitry Andric#elif defined(__APPLE__) || defined(__FreeBSD__) || defined(__EMSCRIPTEN__) || defined(__NetBSD__) 4580b57cec5SDimitry Andric# ifdef __APPLE__ 4590b57cec5SDimitry Andric typedef __uint32_t mask; 4600b57cec5SDimitry Andric# elif defined(__FreeBSD__) 4610b57cec5SDimitry Andric typedef unsigned long mask; 4620b57cec5SDimitry Andric# elif defined(__EMSCRIPTEN__) || defined(__NetBSD__) 4630b57cec5SDimitry Andric typedef unsigned short mask; 4640b57cec5SDimitry Andric# endif 4650b57cec5SDimitry Andric static const mask space = _CTYPE_S; 4660b57cec5SDimitry Andric static const mask print = _CTYPE_R; 4670b57cec5SDimitry Andric static const mask cntrl = _CTYPE_C; 4680b57cec5SDimitry Andric static const mask upper = _CTYPE_U; 4690b57cec5SDimitry Andric static const mask lower = _CTYPE_L; 4700b57cec5SDimitry Andric static const mask alpha = _CTYPE_A; 4710b57cec5SDimitry Andric static const mask digit = _CTYPE_D; 4720b57cec5SDimitry Andric static const mask punct = _CTYPE_P; 4730b57cec5SDimitry Andric static const mask xdigit = _CTYPE_X; 4740b57cec5SDimitry Andric 4750b57cec5SDimitry Andric# if defined(__NetBSD__) 4760b57cec5SDimitry Andric static const mask blank = _CTYPE_BL; 4770b57cec5SDimitry Andric // NetBSD defines classes up to 0x2000 4780b57cec5SDimitry Andric // see sys/ctype_bits.h, _CTYPE_Q 4790b57cec5SDimitry Andric static const mask __regex_word = 0x8000; 4800b57cec5SDimitry Andric# else 4810b57cec5SDimitry Andric static const mask blank = _CTYPE_B; 4820b57cec5SDimitry Andric static const mask __regex_word = 0x80; 4830b57cec5SDimitry Andric# endif 4840b57cec5SDimitry Andric#elif defined(__sun__) || defined(_AIX) 4850b57cec5SDimitry Andric typedef unsigned int mask; 4860b57cec5SDimitry Andric static const mask space = _ISSPACE; 4870b57cec5SDimitry Andric static const mask print = _ISPRINT; 4880b57cec5SDimitry Andric static const mask cntrl = _ISCNTRL; 4890b57cec5SDimitry Andric static const mask upper = _ISUPPER; 4900b57cec5SDimitry Andric static const mask lower = _ISLOWER; 4910b57cec5SDimitry Andric static const mask alpha = _ISALPHA; 4920b57cec5SDimitry Andric static const mask digit = _ISDIGIT; 4930b57cec5SDimitry Andric static const mask punct = _ISPUNCT; 4940b57cec5SDimitry Andric static const mask xdigit = _ISXDIGIT; 4950b57cec5SDimitry Andric static const mask blank = _ISBLANK; 4960b57cec5SDimitry Andric static const mask __regex_word = 0x80; 4970b57cec5SDimitry Andric#elif defined(_NEWLIB_VERSION) 4980b57cec5SDimitry Andric // Same type as Newlib's _ctype_ array in newlib/libc/include/ctype.h. 4990b57cec5SDimitry Andric typedef char mask; 5000b57cec5SDimitry Andric static const mask space = _S; 5010b57cec5SDimitry Andric static const mask print = _P | _U | _L | _N | _B; 5020b57cec5SDimitry Andric static const mask cntrl = _C; 5030b57cec5SDimitry Andric static const mask upper = _U; 5040b57cec5SDimitry Andric static const mask lower = _L; 5050b57cec5SDimitry Andric static const mask alpha = _U | _L; 5060b57cec5SDimitry Andric static const mask digit = _N; 5070b57cec5SDimitry Andric static const mask punct = _P; 5080b57cec5SDimitry Andric static const mask xdigit = _X | _N; 5090b57cec5SDimitry Andric static const mask blank = _B; 5100b57cec5SDimitry Andric static const mask __regex_word = 0x80; 5110b57cec5SDimitry Andric# define _LIBCPP_CTYPE_MASK_IS_COMPOSITE_PRINT 5120b57cec5SDimitry Andric# define _LIBCPP_CTYPE_MASK_IS_COMPOSITE_ALPHA 5130b57cec5SDimitry Andric# define _LIBCPP_CTYPE_MASK_IS_COMPOSITE_XDIGIT 514*04eeddc0SDimitry Andric#elif defined(__MVS__) 515*04eeddc0SDimitry Andric# if defined(__NATIVE_ASCII_F) 516*04eeddc0SDimitry Andric typedef unsigned int mask; 517*04eeddc0SDimitry Andric static const mask space = _ISSPACE_A; 518*04eeddc0SDimitry Andric static const mask print = _ISPRINT_A; 519*04eeddc0SDimitry Andric static const mask cntrl = _ISCNTRL_A; 520*04eeddc0SDimitry Andric static const mask upper = _ISUPPER_A; 521*04eeddc0SDimitry Andric static const mask lower = _ISLOWER_A; 522*04eeddc0SDimitry Andric static const mask alpha = _ISALPHA_A; 523*04eeddc0SDimitry Andric static const mask digit = _ISDIGIT_A; 524*04eeddc0SDimitry Andric static const mask punct = _ISPUNCT_A; 525*04eeddc0SDimitry Andric static const mask xdigit = _ISXDIGIT_A; 526*04eeddc0SDimitry Andric static const mask blank = _ISBLANK_A; 527*04eeddc0SDimitry Andric# else 528*04eeddc0SDimitry Andric typedef unsigned short mask; 529*04eeddc0SDimitry Andric static const mask space = __ISSPACE; 530*04eeddc0SDimitry Andric static const mask print = __ISPRINT; 531*04eeddc0SDimitry Andric static const mask cntrl = __ISCNTRL; 532*04eeddc0SDimitry Andric static const mask upper = __ISUPPER; 533*04eeddc0SDimitry Andric static const mask lower = __ISLOWER; 534*04eeddc0SDimitry Andric static const mask alpha = __ISALPHA; 535*04eeddc0SDimitry Andric static const mask digit = __ISDIGIT; 536*04eeddc0SDimitry Andric static const mask punct = __ISPUNCT; 537*04eeddc0SDimitry Andric static const mask xdigit = __ISXDIGIT; 538*04eeddc0SDimitry Andric static const mask blank = __ISBLANK; 539*04eeddc0SDimitry Andric# endif 540*04eeddc0SDimitry Andric static const mask __regex_word = 0x8000; 5410b57cec5SDimitry Andric#else 542e8d8bef9SDimitry Andric# error unknown rune table for this platform -- do you mean to define _LIBCPP_PROVIDES_DEFAULT_RUNE_TABLE? 5430b57cec5SDimitry Andric#endif 5440b57cec5SDimitry Andric static const mask alnum = alpha | digit; 5450b57cec5SDimitry Andric static const mask graph = alnum | punct; 5460b57cec5SDimitry Andric 5470b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY ctype_base() {} 5480b57cec5SDimitry Andric}; 5490b57cec5SDimitry Andric 5500b57cec5SDimitry Andrictemplate <class _CharT> class _LIBCPP_TEMPLATE_VIS ctype; 5510b57cec5SDimitry Andric 552349cc55cSDimitry Andric#ifndef _LIBCPP_HAS_NO_WIDE_CHARACTERS 5530b57cec5SDimitry Andrictemplate <> 5540b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS ctype<wchar_t> 5550b57cec5SDimitry Andric : public locale::facet, 5560b57cec5SDimitry Andric public ctype_base 5570b57cec5SDimitry Andric{ 5580b57cec5SDimitry Andricpublic: 5590b57cec5SDimitry Andric typedef wchar_t char_type; 5600b57cec5SDimitry Andric 5610b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 5620b57cec5SDimitry Andric explicit ctype(size_t __refs = 0) 5630b57cec5SDimitry Andric : locale::facet(__refs) {} 5640b57cec5SDimitry Andric 5650b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 5660b57cec5SDimitry Andric bool is(mask __m, char_type __c) const 5670b57cec5SDimitry Andric { 5680b57cec5SDimitry Andric return do_is(__m, __c); 5690b57cec5SDimitry Andric } 5700b57cec5SDimitry Andric 5710b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 5720b57cec5SDimitry Andric const char_type* is(const char_type* __low, const char_type* __high, mask* __vec) const 5730b57cec5SDimitry Andric { 5740b57cec5SDimitry Andric return do_is(__low, __high, __vec); 5750b57cec5SDimitry Andric } 5760b57cec5SDimitry Andric 5770b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 5780b57cec5SDimitry Andric const char_type* scan_is(mask __m, const char_type* __low, const char_type* __high) const 5790b57cec5SDimitry Andric { 5800b57cec5SDimitry Andric return do_scan_is(__m, __low, __high); 5810b57cec5SDimitry Andric } 5820b57cec5SDimitry Andric 5830b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 5840b57cec5SDimitry Andric const char_type* scan_not(mask __m, const char_type* __low, const char_type* __high) const 5850b57cec5SDimitry Andric { 5860b57cec5SDimitry Andric return do_scan_not(__m, __low, __high); 5870b57cec5SDimitry Andric } 5880b57cec5SDimitry Andric 5890b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 5900b57cec5SDimitry Andric char_type toupper(char_type __c) const 5910b57cec5SDimitry Andric { 5920b57cec5SDimitry Andric return do_toupper(__c); 5930b57cec5SDimitry Andric } 5940b57cec5SDimitry Andric 5950b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 5960b57cec5SDimitry Andric const char_type* toupper(char_type* __low, const char_type* __high) const 5970b57cec5SDimitry Andric { 5980b57cec5SDimitry Andric return do_toupper(__low, __high); 5990b57cec5SDimitry Andric } 6000b57cec5SDimitry Andric 6010b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 6020b57cec5SDimitry Andric char_type tolower(char_type __c) const 6030b57cec5SDimitry Andric { 6040b57cec5SDimitry Andric return do_tolower(__c); 6050b57cec5SDimitry Andric } 6060b57cec5SDimitry Andric 6070b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 6080b57cec5SDimitry Andric const char_type* tolower(char_type* __low, const char_type* __high) const 6090b57cec5SDimitry Andric { 6100b57cec5SDimitry Andric return do_tolower(__low, __high); 6110b57cec5SDimitry Andric } 6120b57cec5SDimitry Andric 6130b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 6140b57cec5SDimitry Andric char_type widen(char __c) const 6150b57cec5SDimitry Andric { 6160b57cec5SDimitry Andric return do_widen(__c); 6170b57cec5SDimitry Andric } 6180b57cec5SDimitry Andric 6190b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 6200b57cec5SDimitry Andric const char* widen(const char* __low, const char* __high, char_type* __to) const 6210b57cec5SDimitry Andric { 6220b57cec5SDimitry Andric return do_widen(__low, __high, __to); 6230b57cec5SDimitry Andric } 6240b57cec5SDimitry Andric 6250b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 6260b57cec5SDimitry Andric char narrow(char_type __c, char __dfault) const 6270b57cec5SDimitry Andric { 6280b57cec5SDimitry Andric return do_narrow(__c, __dfault); 6290b57cec5SDimitry Andric } 6300b57cec5SDimitry Andric 6310b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 6320b57cec5SDimitry Andric const char_type* narrow(const char_type* __low, const char_type* __high, char __dfault, char* __to) const 6330b57cec5SDimitry Andric { 6340b57cec5SDimitry Andric return do_narrow(__low, __high, __dfault, __to); 6350b57cec5SDimitry Andric } 6360b57cec5SDimitry Andric 6370b57cec5SDimitry Andric static locale::id id; 6380b57cec5SDimitry Andric 6390b57cec5SDimitry Andricprotected: 6400b57cec5SDimitry Andric ~ctype(); 6410b57cec5SDimitry Andric virtual bool do_is(mask __m, char_type __c) const; 6420b57cec5SDimitry Andric virtual const char_type* do_is(const char_type* __low, const char_type* __high, mask* __vec) const; 6430b57cec5SDimitry Andric virtual const char_type* do_scan_is(mask __m, const char_type* __low, const char_type* __high) const; 6440b57cec5SDimitry Andric virtual const char_type* do_scan_not(mask __m, const char_type* __low, const char_type* __high) const; 6450b57cec5SDimitry Andric virtual char_type do_toupper(char_type) const; 6460b57cec5SDimitry Andric virtual const char_type* do_toupper(char_type* __low, const char_type* __high) const; 6470b57cec5SDimitry Andric virtual char_type do_tolower(char_type) const; 6480b57cec5SDimitry Andric virtual const char_type* do_tolower(char_type* __low, const char_type* __high) const; 6490b57cec5SDimitry Andric virtual char_type do_widen(char) const; 6500b57cec5SDimitry Andric virtual const char* do_widen(const char* __low, const char* __high, char_type* __dest) const; 6510b57cec5SDimitry Andric virtual char do_narrow(char_type, char __dfault) const; 6520b57cec5SDimitry Andric virtual const char_type* do_narrow(const char_type* __low, const char_type* __high, char __dfault, char* __dest) const; 6530b57cec5SDimitry Andric}; 654349cc55cSDimitry Andric#endif // _LIBCPP_HAS_NO_WIDE_CHARACTERS 6550b57cec5SDimitry Andric 6560b57cec5SDimitry Andrictemplate <> 6570b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS ctype<char> 6580b57cec5SDimitry Andric : public locale::facet, public ctype_base 6590b57cec5SDimitry Andric{ 6600b57cec5SDimitry Andric const mask* __tab_; 6610b57cec5SDimitry Andric bool __del_; 6620b57cec5SDimitry Andricpublic: 6630b57cec5SDimitry Andric typedef char char_type; 6640b57cec5SDimitry Andric 665e8d8bef9SDimitry Andric explicit ctype(const mask* __tab = nullptr, bool __del = false, size_t __refs = 0); 6660b57cec5SDimitry Andric 6670b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 6680b57cec5SDimitry Andric bool is(mask __m, char_type __c) const 6690b57cec5SDimitry Andric { 6700b57cec5SDimitry Andric return isascii(__c) ? (__tab_[static_cast<int>(__c)] & __m) !=0 : false; 6710b57cec5SDimitry Andric } 6720b57cec5SDimitry Andric 6730b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 6740b57cec5SDimitry Andric const char_type* is(const char_type* __low, const char_type* __high, mask* __vec) const 6750b57cec5SDimitry Andric { 6760b57cec5SDimitry Andric for (; __low != __high; ++__low, ++__vec) 6770b57cec5SDimitry Andric *__vec = isascii(*__low) ? __tab_[static_cast<int>(*__low)] : 0; 6780b57cec5SDimitry Andric return __low; 6790b57cec5SDimitry Andric } 6800b57cec5SDimitry Andric 6810b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 6820b57cec5SDimitry Andric const char_type* scan_is (mask __m, const char_type* __low, const char_type* __high) const 6830b57cec5SDimitry Andric { 6840b57cec5SDimitry Andric for (; __low != __high; ++__low) 6850b57cec5SDimitry Andric if (isascii(*__low) && (__tab_[static_cast<int>(*__low)] & __m)) 6860b57cec5SDimitry Andric break; 6870b57cec5SDimitry Andric return __low; 6880b57cec5SDimitry Andric } 6890b57cec5SDimitry Andric 6900b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 6910b57cec5SDimitry Andric const char_type* scan_not(mask __m, const char_type* __low, const char_type* __high) const 6920b57cec5SDimitry Andric { 6930b57cec5SDimitry Andric for (; __low != __high; ++__low) 6940b57cec5SDimitry Andric if (!(isascii(*__low) && (__tab_[static_cast<int>(*__low)] & __m))) 6950b57cec5SDimitry Andric break; 6960b57cec5SDimitry Andric return __low; 6970b57cec5SDimitry Andric } 6980b57cec5SDimitry Andric 6990b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 7000b57cec5SDimitry Andric char_type toupper(char_type __c) const 7010b57cec5SDimitry Andric { 7020b57cec5SDimitry Andric return do_toupper(__c); 7030b57cec5SDimitry Andric } 7040b57cec5SDimitry Andric 7050b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 7060b57cec5SDimitry Andric const char_type* toupper(char_type* __low, const char_type* __high) const 7070b57cec5SDimitry Andric { 7080b57cec5SDimitry Andric return do_toupper(__low, __high); 7090b57cec5SDimitry Andric } 7100b57cec5SDimitry Andric 7110b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 7120b57cec5SDimitry Andric char_type tolower(char_type __c) const 7130b57cec5SDimitry Andric { 7140b57cec5SDimitry Andric return do_tolower(__c); 7150b57cec5SDimitry Andric } 7160b57cec5SDimitry Andric 7170b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 7180b57cec5SDimitry Andric const char_type* tolower(char_type* __low, const char_type* __high) const 7190b57cec5SDimitry Andric { 7200b57cec5SDimitry Andric return do_tolower(__low, __high); 7210b57cec5SDimitry Andric } 7220b57cec5SDimitry Andric 7230b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 7240b57cec5SDimitry Andric char_type widen(char __c) const 7250b57cec5SDimitry Andric { 7260b57cec5SDimitry Andric return do_widen(__c); 7270b57cec5SDimitry Andric } 7280b57cec5SDimitry Andric 7290b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 7300b57cec5SDimitry Andric const char* widen(const char* __low, const char* __high, char_type* __to) const 7310b57cec5SDimitry Andric { 7320b57cec5SDimitry Andric return do_widen(__low, __high, __to); 7330b57cec5SDimitry Andric } 7340b57cec5SDimitry Andric 7350b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 7360b57cec5SDimitry Andric char narrow(char_type __c, char __dfault) const 7370b57cec5SDimitry Andric { 7380b57cec5SDimitry Andric return do_narrow(__c, __dfault); 7390b57cec5SDimitry Andric } 7400b57cec5SDimitry Andric 7410b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 7420b57cec5SDimitry Andric const char* narrow(const char_type* __low, const char_type* __high, char __dfault, char* __to) const 7430b57cec5SDimitry Andric { 7440b57cec5SDimitry Andric return do_narrow(__low, __high, __dfault, __to); 7450b57cec5SDimitry Andric } 7460b57cec5SDimitry Andric 7470b57cec5SDimitry Andric static locale::id id; 7480b57cec5SDimitry Andric 7490b57cec5SDimitry Andric#ifdef _CACHED_RUNES 7500b57cec5SDimitry Andric static const size_t table_size = _CACHED_RUNES; 7510b57cec5SDimitry Andric#else 7520b57cec5SDimitry Andric static const size_t table_size = 256; // FIXME: Don't hardcode this. 7530b57cec5SDimitry Andric#endif 7540b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY const mask* table() const _NOEXCEPT {return __tab_;} 7550b57cec5SDimitry Andric static const mask* classic_table() _NOEXCEPT; 7560b57cec5SDimitry Andric#if defined(__GLIBC__) || defined(__EMSCRIPTEN__) 7570b57cec5SDimitry Andric static const int* __classic_upper_table() _NOEXCEPT; 7580b57cec5SDimitry Andric static const int* __classic_lower_table() _NOEXCEPT; 7590b57cec5SDimitry Andric#endif 7600b57cec5SDimitry Andric#if defined(__NetBSD__) 7610b57cec5SDimitry Andric static const short* __classic_upper_table() _NOEXCEPT; 7620b57cec5SDimitry Andric static const short* __classic_lower_table() _NOEXCEPT; 7630b57cec5SDimitry Andric#endif 764*04eeddc0SDimitry Andric#if defined(__MVS__) 765*04eeddc0SDimitry Andric static const unsigned short* __classic_upper_table() _NOEXCEPT; 766*04eeddc0SDimitry Andric static const unsigned short* __classic_lower_table() _NOEXCEPT; 767*04eeddc0SDimitry Andric#endif 7680b57cec5SDimitry Andric 7690b57cec5SDimitry Andricprotected: 7700b57cec5SDimitry Andric ~ctype(); 7710b57cec5SDimitry Andric virtual char_type do_toupper(char_type __c) const; 7720b57cec5SDimitry Andric virtual const char_type* do_toupper(char_type* __low, const char_type* __high) const; 7730b57cec5SDimitry Andric virtual char_type do_tolower(char_type __c) const; 7740b57cec5SDimitry Andric virtual const char_type* do_tolower(char_type* __low, const char_type* __high) const; 7750b57cec5SDimitry Andric virtual char_type do_widen(char __c) const; 7760b57cec5SDimitry Andric virtual const char* do_widen(const char* __low, const char* __high, char_type* __to) const; 7770b57cec5SDimitry Andric virtual char do_narrow(char_type __c, char __dfault) const; 7780b57cec5SDimitry Andric virtual const char* do_narrow(const char_type* __low, const char_type* __high, char __dfault, char* __to) const; 7790b57cec5SDimitry Andric}; 7800b57cec5SDimitry Andric 7810b57cec5SDimitry Andric// template <class CharT> class ctype_byname; 7820b57cec5SDimitry Andric 7830b57cec5SDimitry Andrictemplate <class _CharT> class _LIBCPP_TEMPLATE_VIS ctype_byname; 7840b57cec5SDimitry Andric 7850b57cec5SDimitry Andrictemplate <> 7860b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS ctype_byname<char> 7870b57cec5SDimitry Andric : public ctype<char> 7880b57cec5SDimitry Andric{ 7890b57cec5SDimitry Andric locale_t __l; 7900b57cec5SDimitry Andric 7910b57cec5SDimitry Andricpublic: 7920b57cec5SDimitry Andric explicit ctype_byname(const char*, size_t = 0); 7930b57cec5SDimitry Andric explicit ctype_byname(const string&, size_t = 0); 7940b57cec5SDimitry Andric 7950b57cec5SDimitry Andricprotected: 7960b57cec5SDimitry Andric ~ctype_byname(); 7970b57cec5SDimitry Andric virtual char_type do_toupper(char_type) const; 7980b57cec5SDimitry Andric virtual const char_type* do_toupper(char_type* __low, const char_type* __high) const; 7990b57cec5SDimitry Andric virtual char_type do_tolower(char_type) const; 8000b57cec5SDimitry Andric virtual const char_type* do_tolower(char_type* __low, const char_type* __high) const; 8010b57cec5SDimitry Andric}; 8020b57cec5SDimitry Andric 803349cc55cSDimitry Andric#ifndef _LIBCPP_HAS_NO_WIDE_CHARACTERS 8040b57cec5SDimitry Andrictemplate <> 8050b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS ctype_byname<wchar_t> 8060b57cec5SDimitry Andric : public ctype<wchar_t> 8070b57cec5SDimitry Andric{ 8080b57cec5SDimitry Andric locale_t __l; 8090b57cec5SDimitry Andric 8100b57cec5SDimitry Andricpublic: 8110b57cec5SDimitry Andric explicit ctype_byname(const char*, size_t = 0); 8120b57cec5SDimitry Andric explicit ctype_byname(const string&, size_t = 0); 8130b57cec5SDimitry Andric 8140b57cec5SDimitry Andricprotected: 8150b57cec5SDimitry Andric ~ctype_byname(); 8160b57cec5SDimitry Andric virtual bool do_is(mask __m, char_type __c) const; 8170b57cec5SDimitry Andric virtual const char_type* do_is(const char_type* __low, const char_type* __high, mask* __vec) const; 8180b57cec5SDimitry Andric virtual const char_type* do_scan_is(mask __m, const char_type* __low, const char_type* __high) const; 8190b57cec5SDimitry Andric virtual const char_type* do_scan_not(mask __m, const char_type* __low, const char_type* __high) const; 8200b57cec5SDimitry Andric virtual char_type do_toupper(char_type) const; 8210b57cec5SDimitry Andric virtual const char_type* do_toupper(char_type* __low, const char_type* __high) const; 8220b57cec5SDimitry Andric virtual char_type do_tolower(char_type) const; 8230b57cec5SDimitry Andric virtual const char_type* do_tolower(char_type* __low, const char_type* __high) const; 8240b57cec5SDimitry Andric virtual char_type do_widen(char) const; 8250b57cec5SDimitry Andric virtual const char* do_widen(const char* __low, const char* __high, char_type* __dest) const; 8260b57cec5SDimitry Andric virtual char do_narrow(char_type, char __dfault) const; 8270b57cec5SDimitry Andric virtual const char_type* do_narrow(const char_type* __low, const char_type* __high, char __dfault, char* __dest) const; 8280b57cec5SDimitry Andric}; 829349cc55cSDimitry Andric#endif // _LIBCPP_HAS_NO_WIDE_CHARACTERS 8300b57cec5SDimitry Andric 8310b57cec5SDimitry Andrictemplate <class _CharT> 8320b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 8330b57cec5SDimitry Andricbool 8340b57cec5SDimitry Andricisspace(_CharT __c, const locale& __loc) 8350b57cec5SDimitry Andric{ 8360b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::space, __c); 8370b57cec5SDimitry Andric} 8380b57cec5SDimitry Andric 8390b57cec5SDimitry Andrictemplate <class _CharT> 8400b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 8410b57cec5SDimitry Andricbool 8420b57cec5SDimitry Andricisprint(_CharT __c, const locale& __loc) 8430b57cec5SDimitry Andric{ 8440b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::print, __c); 8450b57cec5SDimitry Andric} 8460b57cec5SDimitry Andric 8470b57cec5SDimitry Andrictemplate <class _CharT> 8480b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 8490b57cec5SDimitry Andricbool 8500b57cec5SDimitry Andriciscntrl(_CharT __c, const locale& __loc) 8510b57cec5SDimitry Andric{ 8520b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::cntrl, __c); 8530b57cec5SDimitry Andric} 8540b57cec5SDimitry Andric 8550b57cec5SDimitry Andrictemplate <class _CharT> 8560b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 8570b57cec5SDimitry Andricbool 8580b57cec5SDimitry Andricisupper(_CharT __c, const locale& __loc) 8590b57cec5SDimitry Andric{ 8600b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::upper, __c); 8610b57cec5SDimitry Andric} 8620b57cec5SDimitry Andric 8630b57cec5SDimitry Andrictemplate <class _CharT> 8640b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 8650b57cec5SDimitry Andricbool 8660b57cec5SDimitry Andricislower(_CharT __c, const locale& __loc) 8670b57cec5SDimitry Andric{ 8680b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::lower, __c); 8690b57cec5SDimitry Andric} 8700b57cec5SDimitry Andric 8710b57cec5SDimitry Andrictemplate <class _CharT> 8720b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 8730b57cec5SDimitry Andricbool 8740b57cec5SDimitry Andricisalpha(_CharT __c, const locale& __loc) 8750b57cec5SDimitry Andric{ 8760b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::alpha, __c); 8770b57cec5SDimitry Andric} 8780b57cec5SDimitry Andric 8790b57cec5SDimitry Andrictemplate <class _CharT> 8800b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 8810b57cec5SDimitry Andricbool 8820b57cec5SDimitry Andricisdigit(_CharT __c, const locale& __loc) 8830b57cec5SDimitry Andric{ 8840b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::digit, __c); 8850b57cec5SDimitry Andric} 8860b57cec5SDimitry Andric 8870b57cec5SDimitry Andrictemplate <class _CharT> 8880b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 8890b57cec5SDimitry Andricbool 8900b57cec5SDimitry Andricispunct(_CharT __c, const locale& __loc) 8910b57cec5SDimitry Andric{ 8920b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::punct, __c); 8930b57cec5SDimitry Andric} 8940b57cec5SDimitry Andric 8950b57cec5SDimitry Andrictemplate <class _CharT> 8960b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 8970b57cec5SDimitry Andricbool 8980b57cec5SDimitry Andricisxdigit(_CharT __c, const locale& __loc) 8990b57cec5SDimitry Andric{ 9000b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::xdigit, __c); 9010b57cec5SDimitry Andric} 9020b57cec5SDimitry Andric 9030b57cec5SDimitry Andrictemplate <class _CharT> 9040b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 9050b57cec5SDimitry Andricbool 9060b57cec5SDimitry Andricisalnum(_CharT __c, const locale& __loc) 9070b57cec5SDimitry Andric{ 9080b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::alnum, __c); 9090b57cec5SDimitry Andric} 9100b57cec5SDimitry Andric 9110b57cec5SDimitry Andrictemplate <class _CharT> 9120b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 9130b57cec5SDimitry Andricbool 9140b57cec5SDimitry Andricisgraph(_CharT __c, const locale& __loc) 9150b57cec5SDimitry Andric{ 9160b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).is(ctype_base::graph, __c); 9170b57cec5SDimitry Andric} 9180b57cec5SDimitry Andric 9190b57cec5SDimitry Andrictemplate <class _CharT> 9200b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 9210b57cec5SDimitry Andric_CharT 9220b57cec5SDimitry Andrictoupper(_CharT __c, const locale& __loc) 9230b57cec5SDimitry Andric{ 9240b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).toupper(__c); 9250b57cec5SDimitry Andric} 9260b57cec5SDimitry Andric 9270b57cec5SDimitry Andrictemplate <class _CharT> 9280b57cec5SDimitry Andricinline _LIBCPP_INLINE_VISIBILITY 9290b57cec5SDimitry Andric_CharT 9300b57cec5SDimitry Andrictolower(_CharT __c, const locale& __loc) 9310b57cec5SDimitry Andric{ 9320b57cec5SDimitry Andric return use_facet<ctype<_CharT> >(__loc).tolower(__c); 9330b57cec5SDimitry Andric} 9340b57cec5SDimitry Andric 9350b57cec5SDimitry Andric// codecvt_base 9360b57cec5SDimitry Andric 9370b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS codecvt_base 9380b57cec5SDimitry Andric{ 9390b57cec5SDimitry Andricpublic: 9400b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY codecvt_base() {} 9410b57cec5SDimitry Andric enum result {ok, partial, error, noconv}; 9420b57cec5SDimitry Andric}; 9430b57cec5SDimitry Andric 9440b57cec5SDimitry Andric// template <class internT, class externT, class stateT> class codecvt; 9450b57cec5SDimitry Andric 9460b57cec5SDimitry Andrictemplate <class _InternT, class _ExternT, class _StateT> class _LIBCPP_TEMPLATE_VIS codecvt; 9470b57cec5SDimitry Andric 9480b57cec5SDimitry Andric// template <> class codecvt<char, char, mbstate_t> 9490b57cec5SDimitry Andric 9500b57cec5SDimitry Andrictemplate <> 9510b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS codecvt<char, char, mbstate_t> 9520b57cec5SDimitry Andric : public locale::facet, 9530b57cec5SDimitry Andric public codecvt_base 9540b57cec5SDimitry Andric{ 9550b57cec5SDimitry Andricpublic: 9560b57cec5SDimitry Andric typedef char intern_type; 9570b57cec5SDimitry Andric typedef char extern_type; 9580b57cec5SDimitry Andric typedef mbstate_t state_type; 9590b57cec5SDimitry Andric 9600b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 9610b57cec5SDimitry Andric explicit codecvt(size_t __refs = 0) 9620b57cec5SDimitry Andric : locale::facet(__refs) {} 9630b57cec5SDimitry Andric 9640b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 9650b57cec5SDimitry Andric result out(state_type& __st, 9660b57cec5SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 9670b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 9680b57cec5SDimitry Andric { 9690b57cec5SDimitry Andric return do_out(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 9700b57cec5SDimitry Andric } 9710b57cec5SDimitry Andric 9720b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 9730b57cec5SDimitry Andric result unshift(state_type& __st, 9740b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 9750b57cec5SDimitry Andric { 9760b57cec5SDimitry Andric return do_unshift(__st, __to, __to_end, __to_nxt); 9770b57cec5SDimitry Andric } 9780b57cec5SDimitry Andric 9790b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 9800b57cec5SDimitry Andric result in(state_type& __st, 9810b57cec5SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 9820b57cec5SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const 9830b57cec5SDimitry Andric { 9840b57cec5SDimitry Andric return do_in(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 9850b57cec5SDimitry Andric } 9860b57cec5SDimitry Andric 9870b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 9880b57cec5SDimitry Andric int encoding() const _NOEXCEPT 9890b57cec5SDimitry Andric { 9900b57cec5SDimitry Andric return do_encoding(); 9910b57cec5SDimitry Andric } 9920b57cec5SDimitry Andric 9930b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 9940b57cec5SDimitry Andric bool always_noconv() const _NOEXCEPT 9950b57cec5SDimitry Andric { 9960b57cec5SDimitry Andric return do_always_noconv(); 9970b57cec5SDimitry Andric } 9980b57cec5SDimitry Andric 9990b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 10000b57cec5SDimitry Andric int length(state_type& __st, const extern_type* __frm, const extern_type* __end, size_t __mx) const 10010b57cec5SDimitry Andric { 10020b57cec5SDimitry Andric return do_length(__st, __frm, __end, __mx); 10030b57cec5SDimitry Andric } 10040b57cec5SDimitry Andric 10050b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 10060b57cec5SDimitry Andric int max_length() const _NOEXCEPT 10070b57cec5SDimitry Andric { 10080b57cec5SDimitry Andric return do_max_length(); 10090b57cec5SDimitry Andric } 10100b57cec5SDimitry Andric 10110b57cec5SDimitry Andric static locale::id id; 10120b57cec5SDimitry Andric 10130b57cec5SDimitry Andricprotected: 10140b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 10150b57cec5SDimitry Andric explicit codecvt(const char*, size_t __refs = 0) 10160b57cec5SDimitry Andric : locale::facet(__refs) {} 10170b57cec5SDimitry Andric 10180b57cec5SDimitry Andric ~codecvt(); 10190b57cec5SDimitry Andric 10200b57cec5SDimitry Andric virtual result do_out(state_type& __st, 10210b57cec5SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 10220b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 10230b57cec5SDimitry Andric virtual result do_in(state_type& __st, 10240b57cec5SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 10250b57cec5SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; 10260b57cec5SDimitry Andric virtual result do_unshift(state_type& __st, 10270b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 10280b57cec5SDimitry Andric virtual int do_encoding() const _NOEXCEPT; 10290b57cec5SDimitry Andric virtual bool do_always_noconv() const _NOEXCEPT; 10300b57cec5SDimitry Andric virtual int do_length(state_type& __st, const extern_type* __frm, const extern_type* __end, size_t __mx) const; 10310b57cec5SDimitry Andric virtual int do_max_length() const _NOEXCEPT; 10320b57cec5SDimitry Andric}; 10330b57cec5SDimitry Andric 10340b57cec5SDimitry Andric// template <> class codecvt<wchar_t, char, mbstate_t> 10350b57cec5SDimitry Andric 1036349cc55cSDimitry Andric#ifndef _LIBCPP_HAS_NO_WIDE_CHARACTERS 10370b57cec5SDimitry Andrictemplate <> 10380b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS codecvt<wchar_t, char, mbstate_t> 10390b57cec5SDimitry Andric : public locale::facet, 10400b57cec5SDimitry Andric public codecvt_base 10410b57cec5SDimitry Andric{ 10420b57cec5SDimitry Andric locale_t __l; 10430b57cec5SDimitry Andricpublic: 10440b57cec5SDimitry Andric typedef wchar_t intern_type; 10450b57cec5SDimitry Andric typedef char extern_type; 10460b57cec5SDimitry Andric typedef mbstate_t state_type; 10470b57cec5SDimitry Andric 10480b57cec5SDimitry Andric explicit codecvt(size_t __refs = 0); 10490b57cec5SDimitry Andric 10500b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 10510b57cec5SDimitry Andric result out(state_type& __st, 10520b57cec5SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 10530b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 10540b57cec5SDimitry Andric { 10550b57cec5SDimitry Andric return do_out(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 10560b57cec5SDimitry Andric } 10570b57cec5SDimitry Andric 10580b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 10590b57cec5SDimitry Andric result unshift(state_type& __st, 10600b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 10610b57cec5SDimitry Andric { 10620b57cec5SDimitry Andric return do_unshift(__st, __to, __to_end, __to_nxt); 10630b57cec5SDimitry Andric } 10640b57cec5SDimitry Andric 10650b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 10660b57cec5SDimitry Andric result in(state_type& __st, 10670b57cec5SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 10680b57cec5SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const 10690b57cec5SDimitry Andric { 10700b57cec5SDimitry Andric return do_in(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 10710b57cec5SDimitry Andric } 10720b57cec5SDimitry Andric 10730b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 10740b57cec5SDimitry Andric int encoding() const _NOEXCEPT 10750b57cec5SDimitry Andric { 10760b57cec5SDimitry Andric return do_encoding(); 10770b57cec5SDimitry Andric } 10780b57cec5SDimitry Andric 10790b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 10800b57cec5SDimitry Andric bool always_noconv() const _NOEXCEPT 10810b57cec5SDimitry Andric { 10820b57cec5SDimitry Andric return do_always_noconv(); 10830b57cec5SDimitry Andric } 10840b57cec5SDimitry Andric 10850b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 10860b57cec5SDimitry Andric int length(state_type& __st, const extern_type* __frm, const extern_type* __end, size_t __mx) const 10870b57cec5SDimitry Andric { 10880b57cec5SDimitry Andric return do_length(__st, __frm, __end, __mx); 10890b57cec5SDimitry Andric } 10900b57cec5SDimitry Andric 10910b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 10920b57cec5SDimitry Andric int max_length() const _NOEXCEPT 10930b57cec5SDimitry Andric { 10940b57cec5SDimitry Andric return do_max_length(); 10950b57cec5SDimitry Andric } 10960b57cec5SDimitry Andric 10970b57cec5SDimitry Andric static locale::id id; 10980b57cec5SDimitry Andric 10990b57cec5SDimitry Andricprotected: 11000b57cec5SDimitry Andric explicit codecvt(const char*, size_t __refs = 0); 11010b57cec5SDimitry Andric 11020b57cec5SDimitry Andric ~codecvt(); 11030b57cec5SDimitry Andric 11040b57cec5SDimitry Andric virtual result do_out(state_type& __st, 11050b57cec5SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 11060b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 11070b57cec5SDimitry Andric virtual result do_in(state_type& __st, 11080b57cec5SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 11090b57cec5SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; 11100b57cec5SDimitry Andric virtual result do_unshift(state_type& __st, 11110b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 11120b57cec5SDimitry Andric virtual int do_encoding() const _NOEXCEPT; 11130b57cec5SDimitry Andric virtual bool do_always_noconv() const _NOEXCEPT; 11140b57cec5SDimitry Andric virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; 11150b57cec5SDimitry Andric virtual int do_max_length() const _NOEXCEPT; 11160b57cec5SDimitry Andric}; 1117349cc55cSDimitry Andric#endif // _LIBCPP_HAS_NO_WIDE_CHARACTERS 11180b57cec5SDimitry Andric 1119e8d8bef9SDimitry Andric// template <> class codecvt<char16_t, char, mbstate_t> // deprecated in C++20 11200b57cec5SDimitry Andric 11210b57cec5SDimitry Andrictemplate <> 1122e8d8bef9SDimitry Andricclass _LIBCPP_DEPRECATED_IN_CXX20 _LIBCPP_TYPE_VIS codecvt<char16_t, char, mbstate_t> 11230b57cec5SDimitry Andric : public locale::facet, 11240b57cec5SDimitry Andric public codecvt_base 11250b57cec5SDimitry Andric{ 11260b57cec5SDimitry Andricpublic: 11270b57cec5SDimitry Andric typedef char16_t intern_type; 11280b57cec5SDimitry Andric typedef char extern_type; 11290b57cec5SDimitry Andric typedef mbstate_t state_type; 11300b57cec5SDimitry Andric 11310b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 11320b57cec5SDimitry Andric explicit codecvt(size_t __refs = 0) 11330b57cec5SDimitry Andric : locale::facet(__refs) {} 11340b57cec5SDimitry Andric 11350b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 11360b57cec5SDimitry Andric result out(state_type& __st, 11370b57cec5SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 11380b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 11390b57cec5SDimitry Andric { 11400b57cec5SDimitry Andric return do_out(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 11410b57cec5SDimitry Andric } 11420b57cec5SDimitry Andric 11430b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 11440b57cec5SDimitry Andric result unshift(state_type& __st, 11450b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 11460b57cec5SDimitry Andric { 11470b57cec5SDimitry Andric return do_unshift(__st, __to, __to_end, __to_nxt); 11480b57cec5SDimitry Andric } 11490b57cec5SDimitry Andric 11500b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 11510b57cec5SDimitry Andric result in(state_type& __st, 11520b57cec5SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 11530b57cec5SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const 11540b57cec5SDimitry Andric { 11550b57cec5SDimitry Andric return do_in(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 11560b57cec5SDimitry Andric } 11570b57cec5SDimitry Andric 11580b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 11590b57cec5SDimitry Andric int encoding() const _NOEXCEPT 11600b57cec5SDimitry Andric { 11610b57cec5SDimitry Andric return do_encoding(); 11620b57cec5SDimitry Andric } 11630b57cec5SDimitry Andric 11640b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 11650b57cec5SDimitry Andric bool always_noconv() const _NOEXCEPT 11660b57cec5SDimitry Andric { 11670b57cec5SDimitry Andric return do_always_noconv(); 11680b57cec5SDimitry Andric } 11690b57cec5SDimitry Andric 11700b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 11710b57cec5SDimitry Andric int length(state_type& __st, const extern_type* __frm, const extern_type* __end, size_t __mx) const 11720b57cec5SDimitry Andric { 11730b57cec5SDimitry Andric return do_length(__st, __frm, __end, __mx); 11740b57cec5SDimitry Andric } 11750b57cec5SDimitry Andric 11760b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 11770b57cec5SDimitry Andric int max_length() const _NOEXCEPT 11780b57cec5SDimitry Andric { 11790b57cec5SDimitry Andric return do_max_length(); 11800b57cec5SDimitry Andric } 11810b57cec5SDimitry Andric 11820b57cec5SDimitry Andric static locale::id id; 11830b57cec5SDimitry Andric 11840b57cec5SDimitry Andricprotected: 11850b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 11860b57cec5SDimitry Andric explicit codecvt(const char*, size_t __refs = 0) 11870b57cec5SDimitry Andric : locale::facet(__refs) {} 11880b57cec5SDimitry Andric 11890b57cec5SDimitry Andric ~codecvt(); 11900b57cec5SDimitry Andric 11910b57cec5SDimitry Andric virtual result do_out(state_type& __st, 11920b57cec5SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 11930b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 11940b57cec5SDimitry Andric virtual result do_in(state_type& __st, 11950b57cec5SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 11960b57cec5SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; 11970b57cec5SDimitry Andric virtual result do_unshift(state_type& __st, 11980b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 11990b57cec5SDimitry Andric virtual int do_encoding() const _NOEXCEPT; 12000b57cec5SDimitry Andric virtual bool do_always_noconv() const _NOEXCEPT; 12010b57cec5SDimitry Andric virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; 12020b57cec5SDimitry Andric virtual int do_max_length() const _NOEXCEPT; 12030b57cec5SDimitry Andric}; 12040b57cec5SDimitry Andric 1205fe6060f1SDimitry Andric#ifndef _LIBCPP_HAS_NO_CHAR8_T 1206e8d8bef9SDimitry Andric 1207e8d8bef9SDimitry Andric// template <> class codecvt<char16_t, char8_t, mbstate_t> // C++20 12080b57cec5SDimitry Andric 12090b57cec5SDimitry Andrictemplate <> 1210e8d8bef9SDimitry Andricclass _LIBCPP_TYPE_VIS codecvt<char16_t, char8_t, mbstate_t> 1211e8d8bef9SDimitry Andric : public locale::facet, 1212e8d8bef9SDimitry Andric public codecvt_base 1213e8d8bef9SDimitry Andric{ 1214e8d8bef9SDimitry Andricpublic: 1215e8d8bef9SDimitry Andric typedef char16_t intern_type; 1216e8d8bef9SDimitry Andric typedef char8_t extern_type; 1217e8d8bef9SDimitry Andric typedef mbstate_t state_type; 1218e8d8bef9SDimitry Andric 1219e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1220e8d8bef9SDimitry Andric explicit codecvt(size_t __refs = 0) 1221e8d8bef9SDimitry Andric : locale::facet(__refs) {} 1222e8d8bef9SDimitry Andric 1223e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1224e8d8bef9SDimitry Andric result out(state_type& __st, 1225e8d8bef9SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 1226e8d8bef9SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 1227e8d8bef9SDimitry Andric { 1228e8d8bef9SDimitry Andric return do_out(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 1229e8d8bef9SDimitry Andric } 1230e8d8bef9SDimitry Andric 1231e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1232e8d8bef9SDimitry Andric result unshift(state_type& __st, 1233e8d8bef9SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 1234e8d8bef9SDimitry Andric { 1235e8d8bef9SDimitry Andric return do_unshift(__st, __to, __to_end, __to_nxt); 1236e8d8bef9SDimitry Andric } 1237e8d8bef9SDimitry Andric 1238e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1239e8d8bef9SDimitry Andric result in(state_type& __st, 1240e8d8bef9SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 1241e8d8bef9SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const 1242e8d8bef9SDimitry Andric { 1243e8d8bef9SDimitry Andric return do_in(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 1244e8d8bef9SDimitry Andric } 1245e8d8bef9SDimitry Andric 1246e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1247e8d8bef9SDimitry Andric int encoding() const _NOEXCEPT 1248e8d8bef9SDimitry Andric { 1249e8d8bef9SDimitry Andric return do_encoding(); 1250e8d8bef9SDimitry Andric } 1251e8d8bef9SDimitry Andric 1252e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1253e8d8bef9SDimitry Andric bool always_noconv() const _NOEXCEPT 1254e8d8bef9SDimitry Andric { 1255e8d8bef9SDimitry Andric return do_always_noconv(); 1256e8d8bef9SDimitry Andric } 1257e8d8bef9SDimitry Andric 1258e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1259e8d8bef9SDimitry Andric int length(state_type& __st, const extern_type* __frm, const extern_type* __end, size_t __mx) const 1260e8d8bef9SDimitry Andric { 1261e8d8bef9SDimitry Andric return do_length(__st, __frm, __end, __mx); 1262e8d8bef9SDimitry Andric } 1263e8d8bef9SDimitry Andric 1264e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1265e8d8bef9SDimitry Andric int max_length() const _NOEXCEPT 1266e8d8bef9SDimitry Andric { 1267e8d8bef9SDimitry Andric return do_max_length(); 1268e8d8bef9SDimitry Andric } 1269e8d8bef9SDimitry Andric 1270e8d8bef9SDimitry Andric static locale::id id; 1271e8d8bef9SDimitry Andric 1272e8d8bef9SDimitry Andricprotected: 1273e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1274e8d8bef9SDimitry Andric explicit codecvt(const char*, size_t __refs = 0) 1275e8d8bef9SDimitry Andric : locale::facet(__refs) {} 1276e8d8bef9SDimitry Andric 1277e8d8bef9SDimitry Andric ~codecvt(); 1278e8d8bef9SDimitry Andric 1279e8d8bef9SDimitry Andric virtual result do_out(state_type& __st, 1280e8d8bef9SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 1281e8d8bef9SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 1282e8d8bef9SDimitry Andric virtual result do_in(state_type& __st, 1283e8d8bef9SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 1284e8d8bef9SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; 1285e8d8bef9SDimitry Andric virtual result do_unshift(state_type& __st, 1286e8d8bef9SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 1287e8d8bef9SDimitry Andric virtual int do_encoding() const _NOEXCEPT; 1288e8d8bef9SDimitry Andric virtual bool do_always_noconv() const _NOEXCEPT; 1289e8d8bef9SDimitry Andric virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; 1290e8d8bef9SDimitry Andric virtual int do_max_length() const _NOEXCEPT; 1291e8d8bef9SDimitry Andric}; 1292e8d8bef9SDimitry Andric 1293e8d8bef9SDimitry Andric#endif 1294e8d8bef9SDimitry Andric 1295e8d8bef9SDimitry Andric// template <> class codecvt<char32_t, char, mbstate_t> // deprecated in C++20 1296e8d8bef9SDimitry Andric 1297e8d8bef9SDimitry Andrictemplate <> 1298e8d8bef9SDimitry Andricclass _LIBCPP_DEPRECATED_IN_CXX20 _LIBCPP_TYPE_VIS codecvt<char32_t, char, mbstate_t> 12990b57cec5SDimitry Andric : public locale::facet, 13000b57cec5SDimitry Andric public codecvt_base 13010b57cec5SDimitry Andric{ 13020b57cec5SDimitry Andricpublic: 13030b57cec5SDimitry Andric typedef char32_t intern_type; 13040b57cec5SDimitry Andric typedef char extern_type; 13050b57cec5SDimitry Andric typedef mbstate_t state_type; 13060b57cec5SDimitry Andric 13070b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 13080b57cec5SDimitry Andric explicit codecvt(size_t __refs = 0) 13090b57cec5SDimitry Andric : locale::facet(__refs) {} 13100b57cec5SDimitry Andric 13110b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 13120b57cec5SDimitry Andric result out(state_type& __st, 13130b57cec5SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 13140b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 13150b57cec5SDimitry Andric { 13160b57cec5SDimitry Andric return do_out(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 13170b57cec5SDimitry Andric } 13180b57cec5SDimitry Andric 13190b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 13200b57cec5SDimitry Andric result unshift(state_type& __st, 13210b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 13220b57cec5SDimitry Andric { 13230b57cec5SDimitry Andric return do_unshift(__st, __to, __to_end, __to_nxt); 13240b57cec5SDimitry Andric } 13250b57cec5SDimitry Andric 13260b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 13270b57cec5SDimitry Andric result in(state_type& __st, 13280b57cec5SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 13290b57cec5SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const 13300b57cec5SDimitry Andric { 13310b57cec5SDimitry Andric return do_in(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 13320b57cec5SDimitry Andric } 13330b57cec5SDimitry Andric 13340b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 13350b57cec5SDimitry Andric int encoding() const _NOEXCEPT 13360b57cec5SDimitry Andric { 13370b57cec5SDimitry Andric return do_encoding(); 13380b57cec5SDimitry Andric } 13390b57cec5SDimitry Andric 13400b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 13410b57cec5SDimitry Andric bool always_noconv() const _NOEXCEPT 13420b57cec5SDimitry Andric { 13430b57cec5SDimitry Andric return do_always_noconv(); 13440b57cec5SDimitry Andric } 13450b57cec5SDimitry Andric 13460b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 13470b57cec5SDimitry Andric int length(state_type& __st, const extern_type* __frm, const extern_type* __end, size_t __mx) const 13480b57cec5SDimitry Andric { 13490b57cec5SDimitry Andric return do_length(__st, __frm, __end, __mx); 13500b57cec5SDimitry Andric } 13510b57cec5SDimitry Andric 13520b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 13530b57cec5SDimitry Andric int max_length() const _NOEXCEPT 13540b57cec5SDimitry Andric { 13550b57cec5SDimitry Andric return do_max_length(); 13560b57cec5SDimitry Andric } 13570b57cec5SDimitry Andric 13580b57cec5SDimitry Andric static locale::id id; 13590b57cec5SDimitry Andric 13600b57cec5SDimitry Andricprotected: 13610b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 13620b57cec5SDimitry Andric explicit codecvt(const char*, size_t __refs = 0) 13630b57cec5SDimitry Andric : locale::facet(__refs) {} 13640b57cec5SDimitry Andric 13650b57cec5SDimitry Andric ~codecvt(); 13660b57cec5SDimitry Andric 13670b57cec5SDimitry Andric virtual result do_out(state_type& __st, 13680b57cec5SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 13690b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 13700b57cec5SDimitry Andric virtual result do_in(state_type& __st, 13710b57cec5SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 13720b57cec5SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; 13730b57cec5SDimitry Andric virtual result do_unshift(state_type& __st, 13740b57cec5SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 13750b57cec5SDimitry Andric virtual int do_encoding() const _NOEXCEPT; 13760b57cec5SDimitry Andric virtual bool do_always_noconv() const _NOEXCEPT; 13770b57cec5SDimitry Andric virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; 13780b57cec5SDimitry Andric virtual int do_max_length() const _NOEXCEPT; 13790b57cec5SDimitry Andric}; 13800b57cec5SDimitry Andric 1381fe6060f1SDimitry Andric#ifndef _LIBCPP_HAS_NO_CHAR8_T 1382e8d8bef9SDimitry Andric 1383e8d8bef9SDimitry Andric// template <> class codecvt<char32_t, char8_t, mbstate_t> // C++20 1384e8d8bef9SDimitry Andric 1385e8d8bef9SDimitry Andrictemplate <> 1386e8d8bef9SDimitry Andricclass _LIBCPP_TYPE_VIS codecvt<char32_t, char8_t, mbstate_t> 1387e8d8bef9SDimitry Andric : public locale::facet, 1388e8d8bef9SDimitry Andric public codecvt_base 1389e8d8bef9SDimitry Andric{ 1390e8d8bef9SDimitry Andricpublic: 1391e8d8bef9SDimitry Andric typedef char32_t intern_type; 1392e8d8bef9SDimitry Andric typedef char8_t extern_type; 1393e8d8bef9SDimitry Andric typedef mbstate_t state_type; 1394e8d8bef9SDimitry Andric 1395e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1396e8d8bef9SDimitry Andric explicit codecvt(size_t __refs = 0) 1397e8d8bef9SDimitry Andric : locale::facet(__refs) {} 1398e8d8bef9SDimitry Andric 1399e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1400e8d8bef9SDimitry Andric result out(state_type& __st, 1401e8d8bef9SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 1402e8d8bef9SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 1403e8d8bef9SDimitry Andric { 1404e8d8bef9SDimitry Andric return do_out(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 1405e8d8bef9SDimitry Andric } 1406e8d8bef9SDimitry Andric 1407e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1408e8d8bef9SDimitry Andric result unshift(state_type& __st, 1409e8d8bef9SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const 1410e8d8bef9SDimitry Andric { 1411e8d8bef9SDimitry Andric return do_unshift(__st, __to, __to_end, __to_nxt); 1412e8d8bef9SDimitry Andric } 1413e8d8bef9SDimitry Andric 1414e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1415e8d8bef9SDimitry Andric result in(state_type& __st, 1416e8d8bef9SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 1417e8d8bef9SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const 1418e8d8bef9SDimitry Andric { 1419e8d8bef9SDimitry Andric return do_in(__st, __frm, __frm_end, __frm_nxt, __to, __to_end, __to_nxt); 1420e8d8bef9SDimitry Andric } 1421e8d8bef9SDimitry Andric 1422e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1423e8d8bef9SDimitry Andric int encoding() const _NOEXCEPT 1424e8d8bef9SDimitry Andric { 1425e8d8bef9SDimitry Andric return do_encoding(); 1426e8d8bef9SDimitry Andric } 1427e8d8bef9SDimitry Andric 1428e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1429e8d8bef9SDimitry Andric bool always_noconv() const _NOEXCEPT 1430e8d8bef9SDimitry Andric { 1431e8d8bef9SDimitry Andric return do_always_noconv(); 1432e8d8bef9SDimitry Andric } 1433e8d8bef9SDimitry Andric 1434e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1435e8d8bef9SDimitry Andric int length(state_type& __st, const extern_type* __frm, const extern_type* __end, size_t __mx) const 1436e8d8bef9SDimitry Andric { 1437e8d8bef9SDimitry Andric return do_length(__st, __frm, __end, __mx); 1438e8d8bef9SDimitry Andric } 1439e8d8bef9SDimitry Andric 1440e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1441e8d8bef9SDimitry Andric int max_length() const _NOEXCEPT 1442e8d8bef9SDimitry Andric { 1443e8d8bef9SDimitry Andric return do_max_length(); 1444e8d8bef9SDimitry Andric } 1445e8d8bef9SDimitry Andric 1446e8d8bef9SDimitry Andric static locale::id id; 1447e8d8bef9SDimitry Andric 1448e8d8bef9SDimitry Andricprotected: 1449e8d8bef9SDimitry Andric _LIBCPP_INLINE_VISIBILITY 1450e8d8bef9SDimitry Andric explicit codecvt(const char*, size_t __refs = 0) 1451e8d8bef9SDimitry Andric : locale::facet(__refs) {} 1452e8d8bef9SDimitry Andric 1453e8d8bef9SDimitry Andric ~codecvt(); 1454e8d8bef9SDimitry Andric 1455e8d8bef9SDimitry Andric virtual result do_out(state_type& __st, 1456e8d8bef9SDimitry Andric const intern_type* __frm, const intern_type* __frm_end, const intern_type*& __frm_nxt, 1457e8d8bef9SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 1458e8d8bef9SDimitry Andric virtual result do_in(state_type& __st, 1459e8d8bef9SDimitry Andric const extern_type* __frm, const extern_type* __frm_end, const extern_type*& __frm_nxt, 1460e8d8bef9SDimitry Andric intern_type* __to, intern_type* __to_end, intern_type*& __to_nxt) const; 1461e8d8bef9SDimitry Andric virtual result do_unshift(state_type& __st, 1462e8d8bef9SDimitry Andric extern_type* __to, extern_type* __to_end, extern_type*& __to_nxt) const; 1463e8d8bef9SDimitry Andric virtual int do_encoding() const _NOEXCEPT; 1464e8d8bef9SDimitry Andric virtual bool do_always_noconv() const _NOEXCEPT; 1465e8d8bef9SDimitry Andric virtual int do_length(state_type&, const extern_type* __frm, const extern_type* __end, size_t __mx) const; 1466e8d8bef9SDimitry Andric virtual int do_max_length() const _NOEXCEPT; 1467e8d8bef9SDimitry Andric}; 1468e8d8bef9SDimitry Andric 1469e8d8bef9SDimitry Andric#endif 1470e8d8bef9SDimitry Andric 14710b57cec5SDimitry Andric// template <class _InternT, class _ExternT, class _StateT> class codecvt_byname 14720b57cec5SDimitry Andric 14730b57cec5SDimitry Andrictemplate <class _InternT, class _ExternT, class _StateT> 14740b57cec5SDimitry Andricclass _LIBCPP_TEMPLATE_VIS codecvt_byname 14750b57cec5SDimitry Andric : public codecvt<_InternT, _ExternT, _StateT> 14760b57cec5SDimitry Andric{ 14770b57cec5SDimitry Andricpublic: 14780b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 14790b57cec5SDimitry Andric explicit codecvt_byname(const char* __nm, size_t __refs = 0) 14800b57cec5SDimitry Andric : codecvt<_InternT, _ExternT, _StateT>(__nm, __refs) {} 14810b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 14820b57cec5SDimitry Andric explicit codecvt_byname(const string& __nm, size_t __refs = 0) 14830b57cec5SDimitry Andric : codecvt<_InternT, _ExternT, _StateT>(__nm.c_str(), __refs) {} 14840b57cec5SDimitry Andricprotected: 14850b57cec5SDimitry Andric ~codecvt_byname(); 14860b57cec5SDimitry Andric}; 14870b57cec5SDimitry Andric 1488e8d8bef9SDimitry Andric_LIBCPP_SUPPRESS_DEPRECATED_PUSH 14890b57cec5SDimitry Andrictemplate <class _InternT, class _ExternT, class _StateT> 14900b57cec5SDimitry Andriccodecvt_byname<_InternT, _ExternT, _StateT>::~codecvt_byname() 14910b57cec5SDimitry Andric{ 14920b57cec5SDimitry Andric} 1493e8d8bef9SDimitry Andric_LIBCPP_SUPPRESS_DEPRECATED_POP 14940b57cec5SDimitry Andric 1495e8d8bef9SDimitry Andric_LIBCPP_EXTERN_TEMPLATE_EVEN_IN_DEBUG_MODE(class _LIBCPP_EXTERN_TEMPLATE_TYPE_VIS codecvt_byname<char, char, mbstate_t>) 1496349cc55cSDimitry Andric#ifndef _LIBCPP_HAS_NO_WIDE_CHARACTERS 1497e8d8bef9SDimitry Andric_LIBCPP_EXTERN_TEMPLATE_EVEN_IN_DEBUG_MODE(class _LIBCPP_EXTERN_TEMPLATE_TYPE_VIS codecvt_byname<wchar_t, char, mbstate_t>) 1498349cc55cSDimitry Andric#endif 1499e8d8bef9SDimitry Andric_LIBCPP_EXTERN_TEMPLATE_EVEN_IN_DEBUG_MODE(class _LIBCPP_DEPRECATED_IN_CXX20 _LIBCPP_EXTERN_TEMPLATE_TYPE_VIS codecvt_byname<char16_t, char, mbstate_t>) // deprecated in C++20 1500e8d8bef9SDimitry Andric_LIBCPP_EXTERN_TEMPLATE_EVEN_IN_DEBUG_MODE(class _LIBCPP_DEPRECATED_IN_CXX20 _LIBCPP_EXTERN_TEMPLATE_TYPE_VIS codecvt_byname<char32_t, char, mbstate_t>) // deprecated in C++20 1501fe6060f1SDimitry Andric#ifndef _LIBCPP_HAS_NO_CHAR8_T 1502e8d8bef9SDimitry Andric_LIBCPP_EXTERN_TEMPLATE_EVEN_IN_DEBUG_MODE(class _LIBCPP_EXTERN_TEMPLATE_TYPE_VIS codecvt_byname<char16_t, char8_t, mbstate_t>) // C++20 1503e8d8bef9SDimitry Andric_LIBCPP_EXTERN_TEMPLATE_EVEN_IN_DEBUG_MODE(class _LIBCPP_EXTERN_TEMPLATE_TYPE_VIS codecvt_byname<char32_t, char8_t, mbstate_t>) // C++20 1504e8d8bef9SDimitry Andric#endif 15050b57cec5SDimitry Andric 15060b57cec5SDimitry Andrictemplate <size_t _Np> 15070b57cec5SDimitry Andricstruct __narrow_to_utf8 15080b57cec5SDimitry Andric{ 15090b57cec5SDimitry Andric template <class _OutputIterator, class _CharT> 15100b57cec5SDimitry Andric _OutputIterator 15110b57cec5SDimitry Andric operator()(_OutputIterator __s, const _CharT* __wb, const _CharT* __we) const; 15120b57cec5SDimitry Andric}; 15130b57cec5SDimitry Andric 15140b57cec5SDimitry Andrictemplate <> 15150b57cec5SDimitry Andricstruct __narrow_to_utf8<8> 15160b57cec5SDimitry Andric{ 15170b57cec5SDimitry Andric template <class _OutputIterator, class _CharT> 15180b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 15190b57cec5SDimitry Andric _OutputIterator 15200b57cec5SDimitry Andric operator()(_OutputIterator __s, const _CharT* __wb, const _CharT* __we) const 15210b57cec5SDimitry Andric { 15220b57cec5SDimitry Andric for (; __wb < __we; ++__wb, ++__s) 15230b57cec5SDimitry Andric *__s = *__wb; 15240b57cec5SDimitry Andric return __s; 15250b57cec5SDimitry Andric } 15260b57cec5SDimitry Andric}; 15270b57cec5SDimitry Andric 1528e8d8bef9SDimitry Andric_LIBCPP_SUPPRESS_DEPRECATED_PUSH 15290b57cec5SDimitry Andrictemplate <> 1530fe6060f1SDimitry Andricstruct _LIBCPP_TYPE_VIS __narrow_to_utf8<16> 15310b57cec5SDimitry Andric : public codecvt<char16_t, char, mbstate_t> 15320b57cec5SDimitry Andric{ 15330b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 15340b57cec5SDimitry Andric __narrow_to_utf8() : codecvt<char16_t, char, mbstate_t>(1) {} 1535e8d8bef9SDimitry Andric_LIBCPP_SUPPRESS_DEPRECATED_POP 15360b57cec5SDimitry Andric 1537fe6060f1SDimitry Andric ~__narrow_to_utf8(); 15380b57cec5SDimitry Andric 15390b57cec5SDimitry Andric template <class _OutputIterator, class _CharT> 15400b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 15410b57cec5SDimitry Andric _OutputIterator 15420b57cec5SDimitry Andric operator()(_OutputIterator __s, const _CharT* __wb, const _CharT* __we) const 15430b57cec5SDimitry Andric { 15440b57cec5SDimitry Andric result __r = ok; 15450b57cec5SDimitry Andric mbstate_t __mb; 15460b57cec5SDimitry Andric while (__wb < __we && __r != error) 15470b57cec5SDimitry Andric { 15480b57cec5SDimitry Andric const int __sz = 32; 15490b57cec5SDimitry Andric char __buf[__sz]; 15500b57cec5SDimitry Andric char* __bn; 15510b57cec5SDimitry Andric const char16_t* __wn = (const char16_t*)__wb; 15520b57cec5SDimitry Andric __r = do_out(__mb, (const char16_t*)__wb, (const char16_t*)__we, __wn, 15530b57cec5SDimitry Andric __buf, __buf+__sz, __bn); 15540b57cec5SDimitry Andric if (__r == codecvt_base::error || __wn == (const char16_t*)__wb) 15550b57cec5SDimitry Andric __throw_runtime_error("locale not supported"); 15560b57cec5SDimitry Andric for (const char* __p = __buf; __p < __bn; ++__p, ++__s) 15570b57cec5SDimitry Andric *__s = *__p; 15580b57cec5SDimitry Andric __wb = (const _CharT*)__wn; 15590b57cec5SDimitry Andric } 15600b57cec5SDimitry Andric return __s; 15610b57cec5SDimitry Andric } 15620b57cec5SDimitry Andric}; 15630b57cec5SDimitry Andric 1564e8d8bef9SDimitry Andric_LIBCPP_SUPPRESS_DEPRECATED_PUSH 15650b57cec5SDimitry Andrictemplate <> 1566fe6060f1SDimitry Andricstruct _LIBCPP_TYPE_VIS __narrow_to_utf8<32> 15670b57cec5SDimitry Andric : public codecvt<char32_t, char, mbstate_t> 15680b57cec5SDimitry Andric{ 15690b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 15700b57cec5SDimitry Andric __narrow_to_utf8() : codecvt<char32_t, char, mbstate_t>(1) {} 1571e8d8bef9SDimitry Andric_LIBCPP_SUPPRESS_DEPRECATED_POP 15720b57cec5SDimitry Andric 1573fe6060f1SDimitry Andric ~__narrow_to_utf8(); 15740b57cec5SDimitry Andric 15750b57cec5SDimitry Andric template <class _OutputIterator, class _CharT> 15760b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 15770b57cec5SDimitry Andric _OutputIterator 15780b57cec5SDimitry Andric operator()(_OutputIterator __s, const _CharT* __wb, const _CharT* __we) const 15790b57cec5SDimitry Andric { 15800b57cec5SDimitry Andric result __r = ok; 15810b57cec5SDimitry Andric mbstate_t __mb; 15820b57cec5SDimitry Andric while (__wb < __we && __r != error) 15830b57cec5SDimitry Andric { 15840b57cec5SDimitry Andric const int __sz = 32; 15850b57cec5SDimitry Andric char __buf[__sz]; 15860b57cec5SDimitry Andric char* __bn; 15870b57cec5SDimitry Andric const char32_t* __wn = (const char32_t*)__wb; 15880b57cec5SDimitry Andric __r = do_out(__mb, (const char32_t*)__wb, (const char32_t*)__we, __wn, 15890b57cec5SDimitry Andric __buf, __buf+__sz, __bn); 15900b57cec5SDimitry Andric if (__r == codecvt_base::error || __wn == (const char32_t*)__wb) 15910b57cec5SDimitry Andric __throw_runtime_error("locale not supported"); 15920b57cec5SDimitry Andric for (const char* __p = __buf; __p < __bn; ++__p, ++__s) 15930b57cec5SDimitry Andric *__s = *__p; 15940b57cec5SDimitry Andric __wb = (const _CharT*)__wn; 15950b57cec5SDimitry Andric } 15960b57cec5SDimitry Andric return __s; 15970b57cec5SDimitry Andric } 15980b57cec5SDimitry Andric}; 15990b57cec5SDimitry Andric 16000b57cec5SDimitry Andrictemplate <size_t _Np> 16010b57cec5SDimitry Andricstruct __widen_from_utf8 16020b57cec5SDimitry Andric{ 16030b57cec5SDimitry Andric template <class _OutputIterator> 16040b57cec5SDimitry Andric _OutputIterator 16050b57cec5SDimitry Andric operator()(_OutputIterator __s, const char* __nb, const char* __ne) const; 16060b57cec5SDimitry Andric}; 16070b57cec5SDimitry Andric 16080b57cec5SDimitry Andrictemplate <> 16090b57cec5SDimitry Andricstruct __widen_from_utf8<8> 16100b57cec5SDimitry Andric{ 16110b57cec5SDimitry Andric template <class _OutputIterator> 16120b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 16130b57cec5SDimitry Andric _OutputIterator 16140b57cec5SDimitry Andric operator()(_OutputIterator __s, const char* __nb, const char* __ne) const 16150b57cec5SDimitry Andric { 16160b57cec5SDimitry Andric for (; __nb < __ne; ++__nb, ++__s) 16170b57cec5SDimitry Andric *__s = *__nb; 16180b57cec5SDimitry Andric return __s; 16190b57cec5SDimitry Andric } 16200b57cec5SDimitry Andric}; 16210b57cec5SDimitry Andric 1622e8d8bef9SDimitry Andric_LIBCPP_SUPPRESS_DEPRECATED_PUSH 16230b57cec5SDimitry Andrictemplate <> 1624fe6060f1SDimitry Andricstruct _LIBCPP_TYPE_VIS __widen_from_utf8<16> 16250b57cec5SDimitry Andric : public codecvt<char16_t, char, mbstate_t> 16260b57cec5SDimitry Andric{ 16270b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 16280b57cec5SDimitry Andric __widen_from_utf8() : codecvt<char16_t, char, mbstate_t>(1) {} 1629e8d8bef9SDimitry Andric_LIBCPP_SUPPRESS_DEPRECATED_POP 16300b57cec5SDimitry Andric 1631fe6060f1SDimitry Andric ~__widen_from_utf8(); 16320b57cec5SDimitry Andric 16330b57cec5SDimitry Andric template <class _OutputIterator> 16340b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 16350b57cec5SDimitry Andric _OutputIterator 16360b57cec5SDimitry Andric operator()(_OutputIterator __s, const char* __nb, const char* __ne) const 16370b57cec5SDimitry Andric { 16380b57cec5SDimitry Andric result __r = ok; 16390b57cec5SDimitry Andric mbstate_t __mb; 16400b57cec5SDimitry Andric while (__nb < __ne && __r != error) 16410b57cec5SDimitry Andric { 16420b57cec5SDimitry Andric const int __sz = 32; 16430b57cec5SDimitry Andric char16_t __buf[__sz]; 16440b57cec5SDimitry Andric char16_t* __bn; 16450b57cec5SDimitry Andric const char* __nn = __nb; 16460b57cec5SDimitry Andric __r = do_in(__mb, __nb, __ne - __nb > __sz ? __nb+__sz : __ne, __nn, 16470b57cec5SDimitry Andric __buf, __buf+__sz, __bn); 16480b57cec5SDimitry Andric if (__r == codecvt_base::error || __nn == __nb) 16490b57cec5SDimitry Andric __throw_runtime_error("locale not supported"); 16500b57cec5SDimitry Andric for (const char16_t* __p = __buf; __p < __bn; ++__p, ++__s) 1651e8d8bef9SDimitry Andric *__s = *__p; 16520b57cec5SDimitry Andric __nb = __nn; 16530b57cec5SDimitry Andric } 16540b57cec5SDimitry Andric return __s; 16550b57cec5SDimitry Andric } 16560b57cec5SDimitry Andric}; 16570b57cec5SDimitry Andric 1658e8d8bef9SDimitry Andric_LIBCPP_SUPPRESS_DEPRECATED_PUSH 16590b57cec5SDimitry Andrictemplate <> 1660fe6060f1SDimitry Andricstruct _LIBCPP_TYPE_VIS __widen_from_utf8<32> 16610b57cec5SDimitry Andric : public codecvt<char32_t, char, mbstate_t> 16620b57cec5SDimitry Andric{ 16630b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 16640b57cec5SDimitry Andric __widen_from_utf8() : codecvt<char32_t, char, mbstate_t>(1) {} 1665e8d8bef9SDimitry Andric_LIBCPP_SUPPRESS_DEPRECATED_POP 16660b57cec5SDimitry Andric 1667fe6060f1SDimitry Andric ~__widen_from_utf8(); 16680b57cec5SDimitry Andric 16690b57cec5SDimitry Andric template <class _OutputIterator> 16700b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY 16710b57cec5SDimitry Andric _OutputIterator 16720b57cec5SDimitry Andric operator()(_OutputIterator __s, const char* __nb, const char* __ne) const 16730b57cec5SDimitry Andric { 16740b57cec5SDimitry Andric result __r = ok; 16750b57cec5SDimitry Andric mbstate_t __mb; 16760b57cec5SDimitry Andric while (__nb < __ne && __r != error) 16770b57cec5SDimitry Andric { 16780b57cec5SDimitry Andric const int __sz = 32; 16790b57cec5SDimitry Andric char32_t __buf[__sz]; 16800b57cec5SDimitry Andric char32_t* __bn; 16810b57cec5SDimitry Andric const char* __nn = __nb; 16820b57cec5SDimitry Andric __r = do_in(__mb, __nb, __ne - __nb > __sz ? __nb+__sz : __ne, __nn, 16830b57cec5SDimitry Andric __buf, __buf+__sz, __bn); 16840b57cec5SDimitry Andric if (__r == codecvt_base::error || __nn == __nb) 16850b57cec5SDimitry Andric __throw_runtime_error("locale not supported"); 16860b57cec5SDimitry Andric for (const char32_t* __p = __buf; __p < __bn; ++__p, ++__s) 1687e8d8bef9SDimitry Andric *__s = *__p; 16880b57cec5SDimitry Andric __nb = __nn; 16890b57cec5SDimitry Andric } 16900b57cec5SDimitry Andric return __s; 16910b57cec5SDimitry Andric } 16920b57cec5SDimitry Andric}; 16930b57cec5SDimitry Andric 16940b57cec5SDimitry Andric// template <class charT> class numpunct 16950b57cec5SDimitry Andric 16960b57cec5SDimitry Andrictemplate <class _CharT> class _LIBCPP_TEMPLATE_VIS numpunct; 16970b57cec5SDimitry Andric 16980b57cec5SDimitry Andrictemplate <> 16990b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS numpunct<char> 17000b57cec5SDimitry Andric : public locale::facet 17010b57cec5SDimitry Andric{ 17020b57cec5SDimitry Andricpublic: 17030b57cec5SDimitry Andric typedef char char_type; 17040b57cec5SDimitry Andric typedef basic_string<char_type> string_type; 17050b57cec5SDimitry Andric 17060b57cec5SDimitry Andric explicit numpunct(size_t __refs = 0); 17070b57cec5SDimitry Andric 17080b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY char_type decimal_point() const {return do_decimal_point();} 17090b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY char_type thousands_sep() const {return do_thousands_sep();} 17100b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY string grouping() const {return do_grouping();} 17110b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY string_type truename() const {return do_truename();} 17120b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY string_type falsename() const {return do_falsename();} 17130b57cec5SDimitry Andric 17140b57cec5SDimitry Andric static locale::id id; 17150b57cec5SDimitry Andric 17160b57cec5SDimitry Andricprotected: 17170b57cec5SDimitry Andric ~numpunct(); 17180b57cec5SDimitry Andric virtual char_type do_decimal_point() const; 17190b57cec5SDimitry Andric virtual char_type do_thousands_sep() const; 17200b57cec5SDimitry Andric virtual string do_grouping() const; 17210b57cec5SDimitry Andric virtual string_type do_truename() const; 17220b57cec5SDimitry Andric virtual string_type do_falsename() const; 17230b57cec5SDimitry Andric 17240b57cec5SDimitry Andric char_type __decimal_point_; 17250b57cec5SDimitry Andric char_type __thousands_sep_; 17260b57cec5SDimitry Andric string __grouping_; 17270b57cec5SDimitry Andric}; 17280b57cec5SDimitry Andric 1729349cc55cSDimitry Andric#ifndef _LIBCPP_HAS_NO_WIDE_CHARACTERS 17300b57cec5SDimitry Andrictemplate <> 17310b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS numpunct<wchar_t> 17320b57cec5SDimitry Andric : public locale::facet 17330b57cec5SDimitry Andric{ 17340b57cec5SDimitry Andricpublic: 17350b57cec5SDimitry Andric typedef wchar_t char_type; 17360b57cec5SDimitry Andric typedef basic_string<char_type> string_type; 17370b57cec5SDimitry Andric 17380b57cec5SDimitry Andric explicit numpunct(size_t __refs = 0); 17390b57cec5SDimitry Andric 17400b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY char_type decimal_point() const {return do_decimal_point();} 17410b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY char_type thousands_sep() const {return do_thousands_sep();} 17420b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY string grouping() const {return do_grouping();} 17430b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY string_type truename() const {return do_truename();} 17440b57cec5SDimitry Andric _LIBCPP_INLINE_VISIBILITY string_type falsename() const {return do_falsename();} 17450b57cec5SDimitry Andric 17460b57cec5SDimitry Andric static locale::id id; 17470b57cec5SDimitry Andric 17480b57cec5SDimitry Andricprotected: 17490b57cec5SDimitry Andric ~numpunct(); 17500b57cec5SDimitry Andric virtual char_type do_decimal_point() const; 17510b57cec5SDimitry Andric virtual char_type do_thousands_sep() const; 17520b57cec5SDimitry Andric virtual string do_grouping() const; 17530b57cec5SDimitry Andric virtual string_type do_truename() const; 17540b57cec5SDimitry Andric virtual string_type do_falsename() const; 17550b57cec5SDimitry Andric 17560b57cec5SDimitry Andric char_type __decimal_point_; 17570b57cec5SDimitry Andric char_type __thousands_sep_; 17580b57cec5SDimitry Andric string __grouping_; 17590b57cec5SDimitry Andric}; 1760349cc55cSDimitry Andric#endif // _LIBCPP_HAS_NO_WIDE_CHARACTERS 17610b57cec5SDimitry Andric 17620b57cec5SDimitry Andric// template <class charT> class numpunct_byname 17630b57cec5SDimitry Andric 17640b57cec5SDimitry Andrictemplate <class _CharT> class _LIBCPP_TEMPLATE_VIS numpunct_byname; 17650b57cec5SDimitry Andric 17660b57cec5SDimitry Andrictemplate <> 17670b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS numpunct_byname<char> 17680b57cec5SDimitry Andric: public numpunct<char> 17690b57cec5SDimitry Andric{ 17700b57cec5SDimitry Andricpublic: 17710b57cec5SDimitry Andric typedef char char_type; 17720b57cec5SDimitry Andric typedef basic_string<char_type> string_type; 17730b57cec5SDimitry Andric 17740b57cec5SDimitry Andric explicit numpunct_byname(const char* __nm, size_t __refs = 0); 17750b57cec5SDimitry Andric explicit numpunct_byname(const string& __nm, size_t __refs = 0); 17760b57cec5SDimitry Andric 17770b57cec5SDimitry Andricprotected: 17780b57cec5SDimitry Andric ~numpunct_byname(); 17790b57cec5SDimitry Andric 17800b57cec5SDimitry Andricprivate: 17810b57cec5SDimitry Andric void __init(const char*); 17820b57cec5SDimitry Andric}; 17830b57cec5SDimitry Andric 1784349cc55cSDimitry Andric#ifndef _LIBCPP_HAS_NO_WIDE_CHARACTERS 17850b57cec5SDimitry Andrictemplate <> 17860b57cec5SDimitry Andricclass _LIBCPP_TYPE_VIS numpunct_byname<wchar_t> 17870b57cec5SDimitry Andric: public numpunct<wchar_t> 17880b57cec5SDimitry Andric{ 17890b57cec5SDimitry Andricpublic: 17900b57cec5SDimitry Andric typedef wchar_t char_type; 17910b57cec5SDimitry Andric typedef basic_string<char_type> string_type; 17920b57cec5SDimitry Andric 17930b57cec5SDimitry Andric explicit numpunct_byname(const char* __nm, size_t __refs = 0); 17940b57cec5SDimitry Andric explicit numpunct_byname(const string& __nm, size_t __refs = 0); 17950b57cec5SDimitry Andric 17960b57cec5SDimitry Andricprotected: 17970b57cec5SDimitry Andric ~numpunct_byname(); 17980b57cec5SDimitry Andric 17990b57cec5SDimitry Andricprivate: 18000b57cec5SDimitry Andric void __init(const char*); 18010b57cec5SDimitry Andric}; 1802349cc55cSDimitry Andric#endif // _LIBCPP_HAS_NO_WIDE_CHARACTERS 18030b57cec5SDimitry Andric 18040b57cec5SDimitry Andric_LIBCPP_END_NAMESPACE_STD 18050b57cec5SDimitry Andric 18060b57cec5SDimitry Andric#endif // _LIBCPP___LOCALE 1807