?? path.hpp
字號(hào):
typedef unixstl_ns_qual(basic_path__)<C, T, A> class_type;
public:
typedef ss_typename_type_k parent_class_type::char_type char_type;
typedef ss_typename_type_k parent_class_type::traits_type traits_type;
typedef ss_typename_type_k parent_class_type::allocator_type allocator_type;
typedef ss_typename_type_k parent_class_type::size_type size_type;
public:
basic_path__()
: parent_class_type()
{}
ss_explicit_k basic_path__(char_type const *path)
: parent_class_type(path)
{}
# ifdef STLSOFT_CF_MEMBER_TEMPLATE_CTOR_SUPPORT
/// Constructs a path from \c path
template<ss_typename_param_k S>
ss_explicit_k basic_path__(S const &s)
: parent_class_type(s)
{}
# endif /* STLSOFT_CF_MEMBER_TEMPLATE_CTOR_SUPPORT */
basic_path__(char_type const *path, size_type cch)
: parent_class_type(path, cch)
{}
basic_path__(class_type const &rhs)
: parent_class_type(rhs)
{}
class_type &operator =(class_type const &rhs)
{
parent_class_type::operator =(rhs);
return *this;
}
class_type &operator =(char_type const *rhs)
{
parent_class_type::operator =(rhs);
return *this;
}
# ifdef STLSOFT_CF_MEMBER_TEMPLATE_FUNCTION_SUPPORT
template<ss_typename_param_k S>
class_type &operator =(S const &s)
{
parent_class_type::operator =(s);
return *this;
}
# endif /* STLSOFT_CF_MEMBER_TEMPLATE_FUNCTION_SUPPORT */
};
#endif /* !STLSOFT_DOCUMENTATION_SKIP_SECTION */
/* /////////////////////////////////////////////////////////////////////////
* Operators
*/
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline us_bool_t operator ==(basic_path<C, T, A> const &lhs, ss_typename_type_k basic_path<C, T, A>::char_type const *rhs)
{
return lhs.equal(rhs);
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline us_bool_t operator !=(basic_path<C, T, A> const &lhs, ss_typename_type_k basic_path<C, T, A>::char_type const *rhs)
{
return !lhs.equal(rhs);
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline us_bool_t operator ==(ss_typename_type_k basic_path<C, T, A>::char_type const *lhs, basic_path<C, T, A> const &rhs)
{
return rhs.equal(lhs);
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline us_bool_t operator !=(ss_typename_type_k basic_path<C, T, A>::char_type const *lhs, basic_path<C, T, A> const &rhs)
{
return !rhs.equal(lhs);
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline us_bool_t operator ==(basic_path<C, T, A> const &lhs, basic_path<C, T, A> const &rhs)
{
return lhs.equal(rhs);
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline us_bool_t operator !=(basic_path<C, T, A> const &lhs, basic_path<C, T, A> const &rhs)
{
return !lhs.equal(rhs);
}
// operator /
/// \brief Concatenates \c rhs to the path \c lhs
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline basic_path<C, T, A> operator /(basic_path<C, T, A> const &lhs, ss_typename_type_k basic_path<C, T, A>::char_type const *rhs)
{
return basic_path<C, T, A>(lhs) /= rhs;
}
/// \brief Concatenates \c rhs to the path \c lhs
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline basic_path<C, T, A> operator /(ss_typename_type_k basic_path<C, T, A>::char_type const *lhs, basic_path<C, T, A> const &rhs)
{
return basic_path<C, T, A>(lhs) /= rhs;
}
/// \brief Concatenates \c rhs to the path \c lhs
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline basic_path<C, T, A> operator /(basic_path<C, T, A> const &lhs, basic_path<C, T, A> const &rhs)
{
return basic_path<C, T, A>(lhs) /= rhs;
}
/* /////////////////////////////////////////////////////////////////////////
* Helper functions
*/
#if !defined(STLSOFT_COMPILER_IS_MSVC) || \
_MSC_VER >= 1100
/// This helper function makes a path variable without needing to
/// qualify the template parameter.
template<ss_typename_param_k C>
inline basic_path<C> make_path(C const *path)
{
return basic_path<C>(path);
}
#endif /* compiler */
/* /////////////////////////////////////////////////////////////////////////
* swapping
*/
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline void swap(basic_path<C, T, A> &lhs, basic_path<C, T, A> &rhs)
{
lhs.swap(rhs);
}
/* /////////////////////////////////////////////////////////////////////////
* Shims
*/
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline C const *c_str_ptr_null(basic_path<C, T, A> const &b)
{
return stlsoft_ns_qual(c_str_ptr_null)(b.c_str());
}
template< ss_typename_param_k T
, ss_typename_param_k A
>
inline us_char_a_t const *c_str_ptr_null_a(basic_path<us_char_a_t, T, A> const &b)
{
return stlsoft_ns_qual(c_str_ptr_null_a)(b.c_str());
}
template< ss_typename_param_k T
, ss_typename_param_k A
>
inline us_char_w_t const *c_str_ptr_null_w(basic_path<us_char_w_t, T, A> const &b)
{
return stlsoft_ns_qual(c_str_ptr_null_w)(b.c_str());
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline C const *c_str_ptr(basic_path<C, T, A> const &b)
{
return b.c_str();
}
template< ss_typename_param_k T
, ss_typename_param_k A
>
inline us_char_a_t const *c_str_ptr_a(basic_path<us_char_a_t, T, A> const &b)
{
return b.c_str();
}
template< ss_typename_param_k T
, ss_typename_param_k A
>
inline us_char_w_t const *c_str_ptr_w(basic_path<us_char_w_t, T, A> const &b)
{
return b.c_str();
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline C const *c_str_data(basic_path<C, T, A> const &b)
{
return b.c_str();
}
template< ss_typename_param_k T
, ss_typename_param_k A
>
inline us_char_a_t const *c_str_data_a(basic_path<us_char_a_t, T, A> const &b)
{
return b.c_str();
}
template< ss_typename_param_k T
, ss_typename_param_k A
>
inline us_char_w_t const *c_str_data_w(basic_path<us_char_w_t, T, A> const &b)
{
return b.c_str();
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline us_size_t c_str_len(basic_path<C, T, A> const &b)
{
return stlsoft_ns_qual(c_str_len)(b.c_str());
}
#if 0
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline us_size_t c_str_size(basic_path<C, T, A> const &b)
{
return stlsoft_ns_qual(c_str_size)(b.c_str());
}
#endif /* 0 */
template< ss_typename_param_k S
, ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline S &operator <<(S & s, basic_path<C, T, A> const &b)
{
s << b.c_str();
return s;
}
////////////////////////////////////////////////////////////////////////////
// Unit-testing
#ifdef STLSOFT_UNITTEST
# include "./unittest/path_unittest_.h"
#endif /* STLSOFT_UNITTEST */
////////////////////////////////////////////////////////////////////////////
// Implementation
#ifndef STLSOFT_DOCUMENTATION_SKIP_SECTION
# if defined(STLSOFT_COMPILER_IS_MSVC) && \
_MSC_VER >= 1300
# pragma warning(push)
# pragma warning(disable : 4702)
# endif /* compiler*/
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline /* static */ ss_typename_param_k basic_path<C, T, A>::char_type const *basic_path<C, T, A>::next_slash_or_end(ss_typename_param_k basic_path<C, T, A>::char_type const *p)
{
for(; ; ++p)
{
switch(*p)
{
case '/':
#ifdef _WIN32
case '\\':
#endif /* _WIN32 */
++p;
case '\0':
return p;
default:
break;
}
}
return NULL;
}
# if defined(STLSOFT_COMPILER_IS_MSVC) && \
_MSC_VER >= 1300
# pragma warning(pop)
# endif /* compiler*/
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline /* static */ ss_typename_param_k basic_path<C, T, A>::char_type basic_path<C, T, A>::path_name_separator_alt()
{
return '\\';
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline void basic_path<C, T, A>::swap(basic_path<C, T, A> &rhs)
{
m_buffer.swap(rhs.m_buffer);
std::swap(m_len, rhs.m_len);
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline ss_typename_param_k basic_path<C, T, A>::class_type &basic_path<C, T, A>::concat_(ss_typename_param_k basic_path<C, T, A>::char_type const *rhs)
{
m_len = traits_type::str_len(traits_type::str_cat(&m_buffer[0], rhs));
return *this;
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline ss_typename_param_k basic_path<C, T, A>::class_type &basic_path<C, T, A>::concat_(basic_path<C, T, A> const &rhs)
{
m_len = traits_type::str_len(traits_type::str_cat(&m_buffer[0], rhs.c_str()));
return *this;
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline basic_path<C, T, A>::basic_path()
: m_len(0)
{
m_buffer[0] = '\0';
}
template< ss_typename_param_k C
, ss_typename_param_k T
, ss_typename_param_k A
>
inline /* ss_explicit_k */ basic_path<C, T, A>::basic_path(ss_typename_type_k basic_path<C, T, A>::char_type const *path)
: m_len(0)
{
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -