basic_cstring.hpp
来自「Boost provides free peer-reviewed portab」· HPP 代码 · 共 732 行 · 第 1/2 页
HPP
732 行
trim_left( exclusions ); trim_right( exclusions ); return *this;}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>&basic_cstring<CharT>::operator=( basic_cstring<CharT> const& s ){ m_begin = s.m_begin; m_end = s.m_end; return *this;}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>&basic_cstring<CharT>::operator=( std_string const& s ){ return *this = self_type( s );}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>&basic_cstring<CharT>::operator=( pointer s ){ return *this = self_type( s );}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>&basic_cstring<CharT>::assign( basic_cstring<CharT> const& s, size_type pos, size_type len ){ return *this = self_type( s.m_begin + pos, len );}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>&basic_cstring<CharT>::assign( std_string const& s ){ return *this = self_type( s );}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>&basic_cstring<CharT>::assign( std_string const& s, size_type pos, size_type len ){ return *this = self_type( s.c_str() + pos, len );}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>&basic_cstring<CharT>::assign( pointer s ){ return *this = self_type( s );}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>&basic_cstring<CharT>::assign( pointer s, size_type len ){ return *this = self_type( s, len );}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>&basic_cstring<CharT>::assign( pointer f, pointer l ){ return *this = self_type( f, l );}//____________________________________________________________________________//template<typename CharT>inline voidbasic_cstring<CharT>::swap( basic_cstring<CharT>& s ){ // do not want to include alogrithm pointer tmp1 = m_begin; pointer tmp2 = m_end; m_begin = s.m_begin; m_end = s.m_end; s.m_begin = tmp1; s.m_end = tmp2;}//____________________________________________________________________________//template<typename CharT>inline typename basic_cstring<CharT>::iteratorbasic_cstring<CharT>::begin(){ return m_begin;}//____________________________________________________________________________//template<typename CharT>inline typename basic_cstring<CharT>::const_iteratorbasic_cstring<CharT>::begin() const{ return m_begin;}//____________________________________________________________________________//template<typename CharT>inline typename basic_cstring<CharT>::iteratorbasic_cstring<CharT>::end(){ return m_end;}//____________________________________________________________________________//template<typename CharT>inline typename basic_cstring<CharT>::const_iteratorbasic_cstring<CharT>::end() const{ return m_end;}//____________________________________________________________________________//template<typename CharT>inline typename basic_cstring<CharT>::size_typebasic_cstring<CharT>::find( basic_cstring<CharT> str ) const{ if( str.is_empty() || str.size() > size() ) return (size_type)npos; const_iterator it = begin(); const_iterator last = end() - str.size() + 1; while( it != last ) { if( traits_type::compare( it, str.begin(), str.size() ) == 0 ) break; ++it; } return it == last ? (size_type)npos : it - begin();}//____________________________________________________________________________//template<typename CharT>inline typename basic_cstring<CharT>::size_typebasic_cstring<CharT>::rfind( basic_cstring<CharT> str ) const{ if( str.is_empty() || str.size() > size() ) return (size_type)npos; const_iterator it = end() - str.size(); const_iterator last = begin()-1; while( it != last ) { if( traits_type::compare( it, str.begin(), str.size() ) == 0 ) break; --it; } return it == last ? npos : it - begin();}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>basic_cstring<CharT>::substr( size_type beg_index, size_type end_index ) const{ return beg_index > size() ? self_type() : end_index > size() ? self_type( m_begin + beg_index, m_end ) : self_type( m_begin + beg_index, m_begin + end_index );}//____________________________________________________________________________//template<typename CharT>inline basic_cstring<CharT>basic_cstring<CharT>::default_trim_ex(){ static CharT ws[3] = { CharT(' '), CharT('\t'), CharT('\n') }; // !! wide case return self_type( ws, 3 );}//____________________________________________________________________________//// ************************************************************************** //// ************** comparison operators ************** //// ************************************************************************** //template<typename CharT1,typename CharT2>inline booloperator==( basic_cstring<CharT1> const& s1, basic_cstring<CharT2> const& s2 ){ typedef typename basic_cstring<CharT1>::traits_type traits_type; return s1.size() == s2.size() && traits_type::compare( s1.begin(), s2.begin(), s1.size() ) == 0;}//____________________________________________________________________________//template<typename CharT1,typename CharT2>inline booloperator==( basic_cstring<CharT1> const& s1, CharT2* s2 ){#if !defined(__DMC__) return s1 == basic_cstring<CharT2>( s2 );#else return s1 == basic_cstring<CharT2 const>( s2 );#endif}//____________________________________________________________________________//template<typename CharT>inline booloperator==( basic_cstring<CharT> const& s1, typename basic_cstring<CharT>::std_string const& s2 ){ return s1 == basic_cstring<CharT>( s2 );}//____________________________________________________________________________//template<typename CharT1,typename CharT2>inline booloperator==( CharT1* s2, basic_cstring<CharT2> const& s1 ){ return s1 == s2;}//____________________________________________________________________________//template<typename CharT>inline booloperator==( typename basic_cstring<CharT>::std_string const& s2, basic_cstring<CharT> const& s1 ){ return s1 == s2;}//____________________________________________________________________________//template<typename CharT>inline booloperator!=( basic_cstring<CharT> const& s1, CharT* s2 ){ return !(s1 == s2);}//____________________________________________________________________________//template<typename CharT>inline booloperator!=( CharT* s2, basic_cstring<CharT> const& s1 ){ return !(s1 == s2);}//____________________________________________________________________________//template<typename CharT>inline booloperator!=( basic_cstring<CharT> const& s1, basic_cstring<CharT> const& s2 ){ return !(s1 == s2);}//____________________________________________________________________________//template<typename CharT>inline booloperator!=( basic_cstring<CharT> const& s1, typename basic_cstring<CharT>::std_string const& s2 ){ return !(s1 == s2);}//____________________________________________________________________________//template<typename CharT>inline booloperator!=( typename basic_cstring<CharT>::std_string const& s2, basic_cstring<CharT> const& s1 ){ return !(s1 == s2);}//____________________________________________________________________________//// ************************************************************************** //// ************** first_char ************** //// ************************************************************************** //template<typename CharT>inline typename basic_cstring<CharT>::value_typefirst_char( basic_cstring<CharT> source ){ typedef typename basic_cstring<CharT>::value_type string_value_type; return source.is_empty() ? (string_value_type)0 : *source.begin();}//____________________________________________________________________________//// ************************************************************************** //// ************** last_char ************** //// ************************************************************************** //template<typename CharT>inline typename basic_cstring<CharT>::value_typelast_char( basic_cstring<CharT> source ){ typedef typename basic_cstring<CharT>::value_type string_value_type; return source.is_empty() ? (string_value_type)0 : *(source.end()-1);}//____________________________________________________________________________//// ************************************************************************** //// ************** assign_op ************** //// ************************************************************************** //template<typename CharT1, typename CharT2>inline voidassign_op( std::basic_string<CharT1>& target, basic_cstring<CharT2> src, int ){ target.assign( src.begin(), src.size() );}//____________________________________________________________________________//} // namespace unit_test} // namespace boost//____________________________________________________________________________//#include <boost/test/detail/enable_warnings.hpp>#endif // BOOST_TEST_BASIC_CSTRING_HPP_071894GER
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?