?? sjis_0208
字號(hào):
// codecvt facet for Shift JIS multibyte code, JIS-X0208 wide-character code
#pragma once
#ifndef _CVT_SJIS_0208_
#define _CVT_SJIS_0208_
#ifndef RC_INVOKED
#include <locale>
#include <cwchar>
#pragma pack(push,_CRT_PACKING)
#pragma warning(push,3)
namespace stdext {
namespace cvt {
#pragma warning(disable: 6246)
typedef _CSTD mbstate_t _Statype;
// TEMPLATE CLASS codecvt_sjis_0208
template<class _Elem,
unsigned long _Maxcode = 0x7e7e>
class codecvt_sjis_0208
: public _STD codecvt<_Elem, char, _Statype>
{ // facet for converting between JIS-X0208 _Elem and EUC bytes
public:
typedef _STD codecvt<_Elem, char, _Statype> _Mybase;
typedef typename _Mybase::result result;
typedef char _Byte;
typedef _Elem intern_type;
typedef _Byte extern_type;
typedef _Statype state_type;
explicit codecvt_sjis_0208(size_t _Refs = 0)
: _Mybase(_Refs)
{ // construct with ref count
}
virtual ~codecvt_sjis_0208()
{ // destroy the object
}
protected:
virtual result do_in(_Statype&,
const _Byte *_First1, const _Byte *_Last1, const _Byte *& _Mid1,
_Elem *_First2, _Elem *_Last2, _Elem *& _Mid2) const
{ // convert bytes [_First1, _Last1) to [_First2, _Last)
unsigned long _Maxc = _Maxcode; // to quiet warnings
static unsigned char _Xff = 0xff;
_Mid1 = _First1;
_Mid2 = _First2;
for (; _Mid1 != _Last1 && _Mid2 != _Last2; )
{ // convert a multibyte sequence
unsigned char _By = (unsigned char)*_Mid1;
unsigned short _Ch = _By;
if (_By <= 0x80
|| 0xa0 <= _By && _By <= 0xdf
|| 0xf0 <= _By && _By <= _Xff)
;
else if (_Last1 - _Mid1 < 2)
break;
else
{ // convert 2-byte code
unsigned char _By = *++_Mid1;
if ((_By < 0x40 || 0x7e < _By) && (_By < 0x80 && 0xfc < _By))
return (_Mybase::error); // bad second byte
if (0xe0 <= _Ch)
_Ch -= 0xb0; // MS [e0, ef] => [30, 3f]
else
_Ch -= 0x70; // MS [81, 9f] => [11, 2f]
_Ch <<= 9; // MS [11, 3f] => [22, 7e] in place
if (0x9f <= _By)
_Ch = (unsigned short)(_Ch
+ (_By - 0x7e)); // LS [9f, fc] => [21, 7e]
else if (_By <= 0x7e)
_Ch = (unsigned short)(_Ch
+ (_By - 0x11f)); // LS [40, 7e] => [21, 5f] - 100
else
_Ch = (unsigned short)(_Ch
+ (_By - 0x120)); // LS [80, 9e] => [60, 7e] - 100
}
if (_Maxc < _Ch)
return (_Mybase::error); // code too large
++_Mid1;
*_Mid2++ = (_Elem)_Ch;
}
return (_First1 == _Mid1 ? _Mybase::partial : _Mybase::ok);
}
virtual result do_out(_Statype&,
const _Elem *_First1, const _Elem *_Last1, const _Elem *& _Mid1,
_Byte *_First2, _Byte *_Last2, _Byte *& _Mid2) const
{ // convert [_First1, _Last1) to bytes [_First2, _Last)
unsigned long _Maxc = _Maxcode; // to quiet warnings
_Mid1 = _First1;
_Mid2 = _First2;
for (; _Mid1 != _Last1 && _Mid2 != _Last2; )
{ // convert and put a wide char
unsigned long _Ch = (unsigned long)*_Mid1;
static unsigned char _Xff = 0xff;
if (_Maxc < _Ch)
return (_Mybase::error);
if (_Ch <= 0x80
|| 0xa0 <= _Ch && _Ch <= 0xdf
|| 0xf0 <= _Ch && _Ch <= _Xff)
*_Mid2++ = (_Byte)_Ch;
else if (_Last2 - _Mid2 < 2)
break;
else
{ // convert 2-byte code
unsigned char _By0 = (unsigned char)(_Ch >> 8);
unsigned char _By1 = (unsigned char)_Ch;
if (_By0 < 0x21 || 0x7e < _By0
|| _By1 < 0x21 || 0x7e < _By1)
return (_Mybase::error);
*_Mid2++ = (_Byte)((_By0 + 1) / 2
+ (_By0 < 0x5f ? 0x70 : 0xb0));
if ((_By0 & 1) != 0)
*_Mid2++ = (_Byte)(_By1 + (0x5f <= _By1 ? 0x20 : 0x1f));
else
*_Mid2++ = (_Byte)(_By1 + 0x7e);
}
++_Mid1;
}
return (_First1 == _Mid1 ? _Mybase::partial : _Mybase::ok);
}
virtual result do_unshift(_Statype&,
_Byte *_First2, _Byte *, _Byte *& _Mid2) const
{ // generate bytes to return to default shift state
_Mid2 = _First2;
return (_Mybase::ok);
}
virtual int do_length(const _Statype& _State, const _Byte *_First1,
const _Byte *_Last1, size_t _Count) const _THROW0()
{ // return min(_Count, converted length of bytes [_First1, _Last1))
size_t _Wchars = 0;
_Statype _Mystate = _State;
for (; _Wchars < _Count && _First1 != _Last1; )
{ // convert another wide character
const _Byte *_Mid1;
_Elem *_Mid2;
_Elem _Ch;
switch (do_in(_Mystate, _First1, _Last1, _Mid1,
&_Ch, &_Ch + 1, _Mid2))
{ // test result of single wide-char conversion
case _Mybase::noconv:
return ((int)(_Wchars + (_Last1 - _First1)));
case _Mybase::ok:
if (_Mid2 == &_Ch + 1)
++_Wchars; // replacement do_in might not convert one
_First1 = _Mid1;
break;
default:
return ((int)_Wchars); // error or partial
}
}
return ((int)_Wchars);
}
virtual bool do_always_noconv() const _THROW0()
{ // return true if conversions never change input
return (false);
}
virtual int do_max_length() const _THROW0()
{ // return maximum length required for a conversion
return (3);
}
virtual int do_encoding() const _THROW0()
{ // return length of code sequence (from codecvt)
return (0); // 0 => varying length
}
};
} // namespace cvt
} // namespace stdext
#ifdef _TEST_IT
#define NCHARS 0x10000
#define MYWC_MAX 0x7e7e
#define MYFILE "sjis_0208"
#define MYNAME stdext::cvt::codecvt_sjis_0208<Mywchar>
#include <cvt/xtest>
#endif /* _TEST_IT */
#pragma warning(pop)
#pragma pack(pop)
#endif /* RC_INVOKED */
#endif /* _CVT_SJIS_0208_ */
/*
* Copyright (c) 1992-2009 by P.J. Plauger. ALL RIGHTS RESERVED.
* Consult your license regarding permissions and restrictions.
V5.20:0009 */
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -