diff options
| author | Kevin Smith <git@kismith.co.uk> | 2012-08-02 20:41:55 (GMT) | 
|---|---|---|
| committer | Kevin Smith <git@kismith.co.uk> | 2012-08-02 21:03:09 (GMT) | 
| commit | d5ace22054203c7989691ae8b3fa4e4784d1b57e (patch) | |
| tree | 64d400cdb10644967df183d0f202fcbf8160a773 /3rdParty/Boost/src/boost/filesystem/v3 | |
| parent | 6f26d9aa86f0909af13b23b1a925b8d492e74154 (diff) | |
| download | swift-contrib-ks/boost1.47.zip swift-contrib-ks/boost1.47.tar.bz2 | |
Add two extra Boost dependencies, upgrade to 1.47.0ks/boost1.47
Diffstat (limited to '3rdParty/Boost/src/boost/filesystem/v3')
| -rw-r--r-- | 3rdParty/Boost/src/boost/filesystem/v3/operations.hpp | 34 | ||||
| -rw-r--r-- | 3rdParty/Boost/src/boost/filesystem/v3/path.hpp | 13 | 
2 files changed, 33 insertions, 14 deletions
| diff --git a/3rdParty/Boost/src/boost/filesystem/v3/operations.hpp b/3rdParty/Boost/src/boost/filesystem/v3/operations.hpp index 7d1608d..81a7a3f 100644 --- a/3rdParty/Boost/src/boost/filesystem/v3/operations.hpp +++ b/3rdParty/Boost/src/boost/filesystem/v3/operations.hpp @@ -623,7 +623,7 @@ namespace detail        directory_entry,        boost::single_pass_traversal_tag >::reference dereference() const       { -      BOOST_ASSERT(m_imp.get() && "attempt to dereference end iterator"); +      BOOST_ASSERT_MSG(m_imp.get(), "attempt to dereference end iterator");        return m_imp->dir_entry;      } @@ -706,7 +706,8 @@ namespace detail      inline      void recur_dir_itr_imp::pop()      { -      BOOST_ASSERT(m_level > 0 && "pop() on recursive_directory_iterator with level < 1"); +      BOOST_ASSERT_MSG(m_level > 0, +        "pop() on recursive_directory_iterator with level < 1");        do        { @@ -766,20 +767,23 @@ namespace detail      recursive_directory_iterator& increment(system::error_code& ec)      { -      BOOST_ASSERT(m_imp.get() && "increment() on end recursive_directory_iterator"); +      BOOST_ASSERT_MSG(m_imp.get(), +        "increment() on end recursive_directory_iterator");        m_imp->increment(&ec);        return *this;      }      int level() const      {  -      BOOST_ASSERT(m_imp.get() && "level() on end recursive_directory_iterator"); +      BOOST_ASSERT_MSG(m_imp.get(), +        "level() on end recursive_directory_iterator");        return m_imp->m_level;      }      bool no_push_pending() const      { -      BOOST_ASSERT(m_imp.get() && "is_no_push_requested() on end recursive_directory_iterator"); +      BOOST_ASSERT_MSG(m_imp.get(), +        "is_no_push_requested() on end recursive_directory_iterator");        return (m_imp->m_options & symlink_option::_detail_no_push)          == symlink_option::_detail_no_push;      } @@ -790,14 +794,16 @@ namespace detail      void pop()      {  -      BOOST_ASSERT(m_imp.get() && "pop() on end recursive_directory_iterator"); +      BOOST_ASSERT_MSG(m_imp.get(), +        "pop() on end recursive_directory_iterator");        m_imp->pop();        if (m_imp->m_stack.empty()) m_imp.reset(); // done, so make end iterator      }      void no_push(bool value=true)      { -      BOOST_ASSERT(m_imp.get() && "no_push() on end recursive_directory_iterator"); +      BOOST_ASSERT_MSG(m_imp.get(), +        "no_push() on end recursive_directory_iterator");        if (value)          m_imp->m_options |= symlink_option::_detail_no_push;        else @@ -806,15 +812,15 @@ namespace detail      file_status status() const      { -      BOOST_ASSERT(m_imp.get() -        && "status() on end recursive_directory_iterator"); +      BOOST_ASSERT_MSG(m_imp.get(), +        "status() on end recursive_directory_iterator");        return m_imp->m_stack.top()->status();      }      file_status symlink_status() const      { -      BOOST_ASSERT(m_imp.get() -        && "symlink_status() on end recursive_directory_iterator"); +      BOOST_ASSERT_MSG(m_imp.get(), +        "symlink_status() on end recursive_directory_iterator");        return m_imp->m_stack.top()->symlink_status();      } @@ -832,13 +838,15 @@ namespace detail        boost::single_pass_traversal_tag >::reference      dereference() const       { -      BOOST_ASSERT(m_imp.get() && "dereference of end recursive_directory_iterator"); +      BOOST_ASSERT_MSG(m_imp.get(), +        "dereference of end recursive_directory_iterator");        return *m_imp->m_stack.top();      }      void increment()      {  -      BOOST_ASSERT(m_imp.get() && "increment of end recursive_directory_iterator"); +      BOOST_ASSERT_MSG(m_imp.get(), +        "increment of end recursive_directory_iterator");        m_imp->increment(0);        if (m_imp->m_stack.empty())          m_imp.reset(); // done, so make end iterator diff --git a/3rdParty/Boost/src/boost/filesystem/v3/path.hpp b/3rdParty/Boost/src/boost/filesystem/v3/path.hpp index f81b631..de09c6b 100644 --- a/3rdParty/Boost/src/boost/filesystem/v3/path.hpp +++ b/3rdParty/Boost/src/boost/filesystem/v3/path.hpp @@ -125,7 +125,7 @@ namespace filesystem3      path(){}                                                path(const path& p) : m_pathname(p.m_pathname) {} -  +      template <class Source>      path(Source const& source,        typename boost::enable_if<path_traits::is_pathable< @@ -134,6 +134,17 @@ namespace filesystem3        path_traits::dispatch(source, m_pathname, codecvt());      } +    //  Overloads for the operating system API's native character type. Rationale: +    //    - Avoids use of codecvt() for native value_type strings. This limits the +    //      impact of locale("") initialization failures on POSIX systems to programs +    //      that actually depend on locale(""). It further ensures that exceptions thrown +    //      as a result of such failues occur after main() has started, so can be caught. +    //      This is a partial resolution of tickets 4688, 5100, and 5289. +    //    - A slight optimization for a common use case, particularly on POSIX since +    //      value_type is char and that is the most common useage. +    path(const value_type* s) : m_pathname(s) {} +    path(const std::basic_string<value_type>& s) : m_pathname(s) {} +      template <class Source>      path(Source const& source, const codecvt_type& cvt)      //  see note above explaining why codecvt() default arguments are not used | 
 Swift
 Swift