📄 char_conversions.hpp
字号:
return parent_class_type::data();
}
/// @}
// Not to be implemented
private:
wide2multibyte(wide2multibyte const&);
wide2multibyte& operator =(wide2multibyte const&);
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
};
#ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION
template <ss_typename_param_k C>
class encoding2encoding
{
public:
encoding2encoding(C const* s)
: m_s(s)
{}
encoding2encoding(C *s)
: m_s(s)
{}
template <ss_typename_param_k S>
encoding2encoding(S const& s)
: m_s(s.c_str())
{}
public:
C const* c_str() const
{
return m_s;
}
operator C const* () const
{
return m_s;
}
private:
C const* m_s;
};
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
/* ////////////////////////////////////////////////////////////////////// */
/** \brief Type that converts a multibyte string to a wide string.
*
* \ingroup group__library__conversion
*/
typedef multibyte2wide<256> a2w;
/** \brief Type that converts a wide string to a multibyte string.
*
* \ingroup group__library__conversion
*/
typedef wide2multibyte<256> w2a;
//#if defined(UNICODE)
//typedef encoding2encoding<ss_char_w_t> t2w;
//typedef encoding2encoding<ss_char_w_t> w2t;
//typedef w2a t2a;
//typedef a2w a2t;
//#else /* ? UNICODE */
//typedef encoding2encoding<ss_char_a_t> t2a;
//typedef encoding2encoding<ss_char_a_t> a2t;
//typedef a2w t2w;
//typedef w2a w2t;
//#endif /* UNICODE */
/* /////////////////////////////////////////////////////////////////////////
* Shims
*/
/** \brief \ref group__concept__shim__string_access__c_str_ptr_null for stlsoft::multibyte2wide
*
* \ingroup group__concept__shim__string_access
*/
template< ss_size_t CCH
>
inline ss_char_w_t const* c_str_ptr_null(stlsoft_ns_qual(multibyte2wide)<CCH> const& b)
{
return stlsoft_ns_qual(c_str_ptr_null)(b.c_str());
}
#ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION
template< ss_size_t CCH
>
inline ss_char_w_t const* c_str_ptr_null_w(stlsoft_ns_qual(multibyte2wide)<CCH> const& b)
{
return stlsoft_ns_qual(c_str_ptr_null)(b.c_str());
}
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
/** \brief \ref group__concept__shim__string_access__c_str_ptr for stlsoft::multibyte2wide
*
* \ingroup group__concept__shim__string_access
*/
template< ss_size_t CCH
>
inline ss_char_w_t const* c_str_ptr(stlsoft_ns_qual(multibyte2wide)<CCH> const& b)
{
return b.c_str();
}
#ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION
template< ss_size_t CCH
>
inline ss_char_w_t const* c_str_ptr_w(stlsoft_ns_qual(multibyte2wide)<CCH> const& b)
{
return b.c_str();
}
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
/** \brief \ref group__concept__shim__string_access__c_str_data for stlsoft::multibyte2wide
*
* \ingroup group__concept__shim__string_access
*/
template< ss_size_t CCH
>
inline ss_char_w_t const* c_str_data(stlsoft_ns_qual(multibyte2wide)<CCH> const& b)
{
return b.c_str();
}
#ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION
template< ss_size_t CCH
>
inline ss_char_w_t const* c_str_data_w(stlsoft_ns_qual(multibyte2wide)<CCH> const& b)
{
return b.c_str();
}
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
/** \brief \ref group__concept__shim__string_access__c_str_len for stlsoft::multibyte2wide
*
* \ingroup group__concept__shim__string_access
*/
template< ss_size_t CCH
>
inline ss_size_t c_str_len(stlsoft_ns_qual(multibyte2wide)<CCH> const& b)
{
return stlsoft_ns_qual(c_str_len)(b.c_str());
}
#ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION
template< ss_size_t CCH
>
inline ss_size_t c_str_len_w(stlsoft_ns_qual(multibyte2wide)<CCH> const& b)
{
return stlsoft_ns_qual(c_str_len_w)(b.c_str());
}
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
/** \brief \ref group__concept__shim__string_access__c_str_ptr_null for stlsoft::wide2multibyte
*
* \ingroup group__concept__shim__string_access
*/
template< ss_size_t CCH
>
inline ss_char_a_t const* c_str_ptr_null(stlsoft_ns_qual(wide2multibyte)<CCH> const& b)
{
return stlsoft_ns_qual(c_str_ptr_null)(b.c_str());
}
#ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION
template< ss_size_t CCH
>
inline ss_char_a_t const* c_str_ptr_null_a(stlsoft_ns_qual(wide2multibyte)<CCH> const& b)
{
return stlsoft_ns_qual(c_str_ptr_null)(b.c_str());
}
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
/** \brief \ref group__concept__shim__string_access__c_str_ptr for stlsoft::wide2multibyte
*
* \ingroup group__concept__shim__string_access
*/
template< ss_size_t CCH
>
inline ss_char_a_t const* c_str_ptr(stlsoft_ns_qual(wide2multibyte)<CCH> const& b)
{
return b.c_str();
}
#ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION
template< ss_size_t CCH
>
inline ss_char_a_t const* c_str_ptr_a(stlsoft_ns_qual(wide2multibyte)<CCH> const& b)
{
return b.c_str();
}
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
/** \brief \ref group__concept__shim__string_access__c_str_data for stlsoft::wide2multibyte
*
* \ingroup group__concept__shim__string_access
*/
template< ss_size_t CCH
>
inline ss_char_a_t const* c_str_data(stlsoft_ns_qual(wide2multibyte)<CCH> const& b)
{
return b.c_str();
}
#ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION
template< ss_size_t CCH
>
inline ss_char_a_t const* c_str_data_a(stlsoft_ns_qual(wide2multibyte)<CCH> const& b)
{
return b.c_str();
}
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
/** \brief \ref group__concept__shim__string_access__c_str_len for stlsoft::wide2multibyte
*
* \ingroup group__concept__shim__string_access
*/
template< ss_size_t CCH
>
inline ss_size_t c_str_len(stlsoft_ns_qual(wide2multibyte)<CCH> const& b)
{
return stlsoft_ns_qual(c_str_len)(b.c_str());
}
#ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION
template< ss_size_t CCH
>
inline ss_size_t c_str_len_a(stlsoft_ns_qual(wide2multibyte)<CCH> const& b)
{
return stlsoft_ns_qual(c_str_len_a)(b.c_str());
}
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
/** \brief \ref group__concept__shim__stream_insertion "stream insertion shim" for stlsoft::multibyte2wide
*
* \ingroup group__concept__shim__stream_insertion
*/
template< ss_typename_param_k S
, ss_size_t CCH
>
inline S& operator <<(S& s, stlsoft_ns_qual(multibyte2wide)<CCH> const& b)
{
s << b.c_str();
return s;
}
/** \brief \ref group__concept__shim__stream_insertion "stream insertion shim" for stlsoft::wide2multibyte
*
* \ingroup group__concept__shim__stream_insertion
*/
template< ss_typename_param_k S
, ss_size_t CCH
>
inline S& operator <<(S& s, stlsoft_ns_qual(wide2multibyte)<CCH> const& b)
{
s << b.c_str();
return s;
}
////////////////////////////////////////////////////////////////////////////
// Unit-testing
#ifdef STLSOFT_UNITTEST
# include "./unittest/char_conversions_unittest_.h"
#endif /* STLSOFT_UNITTEST */
/* ////////////////////////////////////////////////////////////////////// */
#ifndef _STLSOFT_NO_NAMESPACE
} // namespace stlsoft
#endif /* _STLSOFT_NO_NAMESPACE */
/* /////////////////////////////////////////////////////////////////////////
* Global namespace shims
*/
/* This defines stream inserter shim function templates for the converters
* for use with the Visual C++ <7.1 standard library.
*/
#if defined(STLSOFT_CF_STD_LIBRARY_IS_DINKUMWARE_VC) && \
STLSOFT_CF_STD_LIBRARY_DINKUMWARE_VC_VERSION < STLSOFT_CF_DINKUMWARE_VC_VERSION_7_1
# include <iosfwd>
template <stlsoft_ns_qual(ss_size_t) CCH>
inline stlsoft_ns_qual_std(basic_ostream)<char>& operator <<(stlsoft_ns_qual_std(basic_ostream)<char> &stm, stlsoft_ns_qual(wide2multibyte)<CCH> const& b)
{
return stm << b.c_str();
}
template <stlsoft_ns_qual(ss_size_t) CCH>
inline stlsoft_ns_qual_std(basic_ostream)<wchar_t>& operator <<(stlsoft_ns_qual_std(basic_ostream)<wchar_t> &stm, stlsoft_ns_qual(multibyte2wide)<CCH> const& b)
{
return stm << b.c_str();
}
#endif /* library */
/* ////////////////////////////////////////////////////////////////////// */
#endif /* STLSOFT_INCL_STLSOFT_CONVERSION_HPP_CHAR_CONVERSIONS */
/* ////////////////////////////////////////////////////////////////////// */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -