📄 xlocnum
字号:
// xlocnum internal header (from <locale>)
#if _MSC_VER > 1000
#pragma once
#endif
#ifndef _XLOCNUM_
#define _XLOCNUM_
#include <cerrno>
#include <climits>
#include <cstdio>
#include <cstdlib>
#include <xiosbase>
#ifdef _MSC_VER
#pragma pack(push,8)
#endif /* _MSC_VER */
_STD_BEGIN
// TEMPLATE CLASS numpunct
template<class _E>
class numpunct : public locale::facet {
public:
typedef basic_string<_E, char_traits<_E>, allocator<_E> >
string_type;
typedef _E char_type;
static locale::id id;
_E decimal_point() const
{return (do_decimal_point()); }
_E thousands_sep() const
{return (do_thousands_sep()); }
string grouping() const
{return (do_grouping()); }
string_type falsename() const
{return (do_falsename()); }
string_type truename() const
{return (do_truename()); }
explicit numpunct(size_t _R = 0)
: locale::facet(_R) {_Init(_Locinfo()); }
numpunct(const _Locinfo& _Lobj, size_t _R = 0)
: locale::facet(_R) {_Init(_Lobj); }
static size_t __cdecl _Getcat()
{return (_LC_NUMERIC); }
_PROTECTED:
virtual ~numpunct()
{delete[] _Gr;
delete[] _Nf;
delete[] _Nt; }
protected:
void _Init(const _Locinfo& _Lobj)
{const lconv *_P = _Lobj._Getlconv();
_Dp = _WIDEN(_E, _P->decimal_point[0]);
_Ks = _WIDEN(_E, _P->thousands_sep[0]);
_Gr = _MAKLOCSTR(char, _P->grouping);
_Nf = _MAKLOCSTR(_E, _Lobj._Getfalse());
_Nt = _MAKLOCSTR(_E, _Lobj._Gettrue()); }
virtual _E do_decimal_point() const
{return (_Dp); }
virtual _E do_thousands_sep() const
{return (_Ks); }
virtual string do_grouping() const
{return (string(_Gr)); }
virtual string_type do_falsename() const
{return (string_type(_Nf)); }
virtual string_type do_truename() const
{return (string_type(_Nt)); }
private:
char *_Gr;
_E _Dp, _Ks, *_Nf, *_Nt;
};
typedef numpunct<char> _Npc;
typedef numpunct<wchar_t> _Npwc;
// TEMPLATE CLASS numpunct_byname
template<class _E>
class numpunct_byname : public numpunct<_E> {
public:
explicit numpunct_byname(const char *_S, size_t _R = 0)
: numpunct<_E>(_Locinfo(_S), _R) {}
_PROTECTED:
virtual ~numpunct_byname()
{}
};
template<class _E>
locale::id numpunct<_E>::id;
#define _VIRTUAL virtual
template<class _E> inline
bool (isdigit)(_E _C, const locale& _L)
{return (_USE(_L, ctype<_E>).is(ctype_base::digit, _C)); }
// TEMPLATE CLASS num_get
template<class _E,
class _II = istreambuf_iterator<_E, char_traits<_E> > >
class num_get : public locale::facet {
public:
typedef numpunct<_E> _Mypunct;
typedef basic_string<_E, char_traits<_E>, allocator<_E> >
_Mystr;
static size_t __cdecl _Getcat()
{return (_LC_NUMERIC); }
static locale::id id;
_PROTECTED:
virtual ~num_get()
{}
protected:
void _Init(const _Locinfo& _Lobj)
{}
public:
explicit num_get(size_t _R = 0)
: locale::facet(_R) {_Init(_Locinfo()); }
num_get(const _Locinfo& _Lobj, size_t _R = 0)
: locale::facet(_R) {_Init(_Lobj); }
typedef _E char_type;
typedef _II iter_type;
_II get(_II _F, _II _L, ios_base& _X, ios_base::iostate& _St,
_Bool& _V) const
{return (do_get(_F, _L, _X, _St, _V)); }
_II get(_II _F, _II _L, ios_base& _X, ios_base::iostate& _St,
unsigned short& _V) const
{return (do_get(_F, _L, _X, _St, _V)); }
_II get(_II _F, _II _L, ios_base& _X, ios_base::iostate& _St,
unsigned int& _V) const
{return (do_get(_F, _L, _X, _St, _V)); }
_II get(_II _F, _II _L, ios_base& _X, ios_base::iostate& _St,
long& _V) const
{return (do_get(_F, _L, _X, _St, _V)); }
_II get(_II _F, _II _L, ios_base& _X, ios_base::iostate& _St,
unsigned long& _V) const
{return (do_get(_F, _L, _X, _St, _V)); }
_II get(_II _F, _II _L, ios_base& _X, ios_base::iostate& _St,
float& _V) const
{return (do_get(_F, _L, _X, _St, _V)); }
_II get(_II _F, _II _L, ios_base& _X, ios_base::iostate& _St,
double& _V) const
{return (do_get(_F, _L, _X, _St, _V)); }
_II get(_II _F, _II _L, ios_base& _X, ios_base::iostate& _St,
long double& _V) const
{return (do_get(_F, _L, _X, _St, _V)); }
_II get(_II _F, _II _L, ios_base& _X, ios_base::iostate& _St,
void *& _V) const
{return (do_get(_F, _L, _X, _St, _V)); }
protected:
_VIRTUAL _II do_get(_II _F, _II _L, ios_base& _X,
ios_base::iostate& _St, _Bool& _V) const
{int _Ans = -1;
if (_X.flags() & ios_base::boolalpha)
{const _Mypunct& _Fac = _USE(_X.getloc(), _Mypunct);
_Mystr _Str(1, (_E)0);
_Str += _Fac.falsename();
_Str += (_E)0;
_Str += _Fac.truename();
_Ans = _Getloctxt(_F, _L, (size_t)2, _Str.c_str()); }
else
{char _Ac[_MAX_INT_DIG], *_Ep;
errno = 0;
const unsigned long _Ulo = strtoul(_Ac, &_Ep,
_Getifld(_Ac, _F, _L, _X.flags(), _X.getloc()));
if (_Ep != _Ac && errno == 0 && _Ulo <= 1)
_Ans = _Ulo; }
if (_F == _L)
_St |= ios_base::eofbit;
if (_Ans < 0)
_St |= ios_base::failbit;
else
_V = _Ans != 0;
return (_F); }
_VIRTUAL _II do_get(_II _F, _II _L, ios_base& _X,
ios_base::iostate& _St, unsigned short& _V) const
{char _Ac[_MAX_INT_DIG], *_Ep;
errno = 0;
int _Base =
_Getifld(_Ac, _F, _L, _X.flags(), _X.getloc());
char *_S = _Ac[0] == '-' ? _Ac + 1 : _Ac;
const unsigned long _Ans = strtoul(_S, &_Ep, _Base);
if (_F == _L)
_St |= ios_base::eofbit;
if (_Ep == _S || errno != 0 || USHRT_MAX < _Ans)
_St |= ios_base::failbit;
else
_V = (unsigned short)(_Ac[0] == '-' ? -_Ans : _Ans);
return (_F); }
_VIRTUAL _II do_get(_II _F, _II _L, ios_base& _X,
ios_base::iostate& _St, unsigned int& _V) const
{char _Ac[_MAX_INT_DIG], *_Ep;
errno = 0;
int _Base =
_Getifld(_Ac, _F, _L, _X.flags(), _X.getloc());
char *_S = _Ac[0] == '-' ? _Ac + 1 : _Ac;
const unsigned long _Ans = strtoul(_S, &_Ep, _Base);
if (_F == _L)
_St |= ios_base::eofbit;
if (_Ep == _S || errno != 0 || UINT_MAX < _Ans)
_St |= ios_base::failbit;
else
_V = _Ac[0] == '-' ? -_Ans : _Ans;
return (_F); }
_VIRTUAL _II do_get(_II _F, _II _L, ios_base& _X,
ios_base::iostate& _St, long& _V) const
{char _Ac[_MAX_INT_DIG], *_Ep;
errno = 0;
const long _Ans = strtol(_Ac, &_Ep,
_Getifld(_Ac, _F, _L, _X.flags(), _X.getloc()));
if (_F == _L)
_St |= ios_base::eofbit;
if (_Ep == _Ac || errno != 0)
_St |= ios_base::failbit;
else
_V = _Ans;
return (_F); }
_VIRTUAL _II do_get(_II _F, _II _L, ios_base& _X,
ios_base::iostate& _St, unsigned long& _V) const
{char _Ac[_MAX_INT_DIG], *_Ep;
errno = 0;
const unsigned long _Ans = strtoul(_Ac, &_Ep,
_Getifld(_Ac, _F, _L, _X.flags(), _X.getloc()));
if (_F == _L)
_St |= ios_base::eofbit;
if (_Ep == _Ac || errno != 0)
_St |= ios_base::failbit;
else
_V = _Ans;
return (_F); }
_VIRTUAL _II do_get(_II _F, _II _L, ios_base& _X,
ios_base::iostate& _St, float& _V) const
{char _Ac[_MAX_EXP_DIG + _MAX_SIG_DIG + 32], *_Ep;
errno = 0;
const float _Ans = _Stof(_Ac, &_Ep,
_Getffld(_Ac, _F, _L, _X.getloc()));
if (_F == _L)
_St |= ios_base::eofbit;
if (_Ep == _Ac || errno != 0)
_St |= ios_base::failbit;
else
_V = _Ans;
return (_F); }
_VIRTUAL _II do_get(_II _F, _II _L, ios_base& _X,
ios_base::iostate& _St, double& _V) const
{char _Ac[_MAX_EXP_DIG + _MAX_SIG_DIG + 32], *_Ep;
errno = 0;
const double _Ans = _Stod(_Ac, &_Ep,
_Getffld(_Ac, _F, _L, _X.getloc()));
if (_F == _L)
_St |= ios_base::eofbit;
if (_Ep == _Ac || errno != 0)
_St |= ios_base::failbit;
else
_V = _Ans;
return (_F); }
_VIRTUAL _II do_get(_II _F, _II _L, ios_base& _X,
ios_base::iostate& _St, long double& _V) const
{char _Ac[_MAX_EXP_DIG + _MAX_SIG_DIG + 32], *_Ep;
errno = 0;
const long double _Ans = _Stold(_Ac, &_Ep,
_Getffld(_Ac, _F, _L, _X.getloc()));
if (_F == _L)
_St |= ios_base::eofbit;
if (_Ep == _Ac || errno != 0)
_St |= ios_base::failbit;
else
_V = _Ans;
return (_F); }
_VIRTUAL _II do_get(_II _F, _II _L, ios_base& _X,
ios_base::iostate& _St, void *& _V) const
{union _Pvlo {
void *_Pv;
unsigned long _Lo[1 +
(sizeof (void *) - 1) / sizeof (unsigned long)];
} _U;
const int _NL = sizeof (_U._Lo) / sizeof (unsigned long);
for (int _I = 0; ; ++_F)
{char _Ac[_MAX_INT_DIG], *_Ep;
errno = 0;
_U._Lo[_I] = strtoul(_Ac, &_Ep,
_Getifld(_Ac, _F, _L,
ios_base::hex, _X.getloc()));
if (_F == _L)
_St |= ios_base::eofbit;
if (_Ep == _Ac || errno != 0)
{_St |= ios_base::failbit;
break; }
if (_NL <= ++_I)
break;
if (_F == _L || *_F != _WIDEN(_E, ':'))
{_St |= ios_base::failbit;
break; }}
if (!(_St & ios_base::failbit))
_V = _U._Pv;
return (_F); }
private:
static int __cdecl _Getifld(char *_Ac, _II& _F, _II& _L,
ios_base::fmtflags _Bfl, const locale& _Loc)
{const _E _E0 = _WIDEN(_E, '0');
const _Mypunct& _Fac = _USE(_Loc, _Mypunct);
const string _Gr = _Fac.grouping();
const _E _Ks = _Fac.thousands_sep();
char *_P = _Ac;
if (_F == _L)
;
else if (*_F == _WIDEN(_E, '+'))
*_P++ = '+', ++_F;
else if (*_F == _WIDEN(_E, '-'))
*_P++ = '-', ++_F;
_Bfl &= ios_base::basefield;
int _Base = _Bfl == ios_base::oct ? 8
: _Bfl == ios_base::hex ? 16
: _Bfl == ios_base::_Fmtzero ? 0 : 10;
bool _Sd = false, _Snz = false;
if (_F != _L && *_F == _E0)
{_Sd = true, ++_F;
if (_F != _L && (*_F == _WIDEN(_E, 'x')
|| *_F == _WIDEN(_E, 'X'))
&& (_Base == 0 || _Base == 16))
_Base = 16, _Sd = false, ++_F;
else if (_Base == 0)
_Base = 8; }
int _Dlen = _Base == 0 || _Base == 10 ? 10
: _Base == 8 ? 8 : 16 + 6;
string _Grin(1, _Sd ? '\1' : '\0');
size_t _I = 0;
for (char *const _Pe = &_Ac[_MAX_INT_DIG - 1];
_F != _L; ++_F)
if (memchr("0123456789abcdefABCDEF",
*_P = (char)_NARROW(_E, *_F), _Dlen) != 0)
{if ((_Snz || *_P != '0') && _P < _Pe)
++_P, _Snz = true;
_Sd = true;
if (_Grin[_I] != CHAR_MAX)
++_Grin[_I]; }
else if (_Grin[_I] == '\0' || _Ks == (_E)0
|| *_F != _Ks)
break;
else
_Grin.append(1, '\0'), ++_I;
if (_I == 0)
;
else if ('\0' < _Grin[_I])
++_I;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -