Merge branch 'hotfix-1.7.2' into develop
This commit is contained in:
		
						commit
						0ab4225262
					
				| @ -44,7 +44,7 @@ matrix: | |||||||
| 
 | 
 | ||||||
| before_install: | before_install: | ||||||
|   - cd .. |   - cd .. | ||||||
|   - git clone --depth=1 --branch=master https://github.com/qPCR4vir/nana-demo.git nana-demo |   - git clone --depth=1 --branch=hotfix https://github.com/qPCR4vir/nana-demo.git nana-demo | ||||||
|   - export PATH="$HOME/bin:$PATH" |   - export PATH="$HOME/bin:$PATH" | ||||||
|   - wget --no-check-certificate --no-clobber -O /tmp/tools/cmake https://cmake.org/files/v3.12/cmake-3.12.0-rc3-Linux-x86_64.sh || true |   - wget --no-check-certificate --no-clobber -O /tmp/tools/cmake https://cmake.org/files/v3.12/cmake-3.12.0-rc3-Linux-x86_64.sh || true | ||||||
|   - chmod -R +x /tmp/tools |   - chmod -R +x /tmp/tools | ||||||
|  | |||||||
| @ -22,7 +22,7 @@ | |||||||
| # cmake 3.12 have more better modern c++ support | # cmake 3.12 have more better modern c++ support | ||||||
| 
 | 
 | ||||||
| cmake_minimum_required(VERSION 3.12  FATAL_ERROR) | cmake_minimum_required(VERSION 3.12  FATAL_ERROR) | ||||||
| project(nana VERSION      1.7.1 | project(nana VERSION      1.7.2 | ||||||
|         DESCRIPTION "C++ GUI library" |         DESCRIPTION "C++ GUI library" | ||||||
|         HOMEPAGE_URL http://nanapro.org |         HOMEPAGE_URL http://nanapro.org | ||||||
|         LANGUAGES CXX         ) |         LANGUAGES CXX         ) | ||||||
| @ -116,7 +116,7 @@ option(NANA_CMAKE_ENABLE_MINGW_STD_THREADS_WITH_MEGANZ "replaced boost.thread wi | |||||||
| 
 | 
 | ||||||
| ######## Nana options | ######## Nana options | ||||||
| 
 | 
 | ||||||
| target_compile_definitions(nana PRIVATE NANA_IGNORE_CONF)    # really ? | target_compile_definitions(nana PRIVATE NANA_IGNORE_CONF)    # really ?? | ||||||
| if(NANA_CMAKE_AUTOMATIC_GUI_TESTING) | if(NANA_CMAKE_AUTOMATIC_GUI_TESTING) | ||||||
|     target_compile_definitions(nana PUBLIC NANA_AUTOMATIC_GUI_TESTING) |     target_compile_definitions(nana PUBLIC NANA_AUTOMATIC_GUI_TESTING) | ||||||
|     # todo: enable_testing()       #  ?? |     # todo: enable_testing()       #  ?? | ||||||
|  | |||||||
| @ -1,30 +1,36 @@ | |||||||
| # The ISO C++ File System Technical Specification (ISO-TS, or STD) was optional. | # The ISO C++ File System Technical Specification (ISO-TS, or STD) was optional. | ||||||
| #              http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4100.pdf | #              http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4100.pdf | ||||||
| # It is part of c++17. | # It is part of c++17. | ||||||
| # The library may be not available or working correctly in the std library in use. As a workaround we may try | # The library may be not available or working correctly in the std library you use. As a workaround we may try | ||||||
| # to "implement" it (ab)using Boost (almost compatible) | # to "implement" it (ab)using Boost (almost compatible) | ||||||
| #              http://www.boost.org/doc/libs/1_60_0/libs/filesystem/doc/index.htm | #              http://www.boost.org/doc/libs/1_60_0/libs/filesystem/doc/index.htm | ||||||
| # or you can choose to use the (partial, but functional) implementation provided by nana. | # or you can choose to use the (partial, but functional) implementation provided by nana. | ||||||
| # If you include the file <nana/filesystem/filesystem.hpp> or <nana/filesystem/filesystem_ext.hpp> | # If you include the file <nana/filesystem/filesystem.hpp> or <nana/filesystem/filesystem_ext.hpp> | ||||||
| # the selected option will be set by nana into std::filesystem | # the selected option will be inlined by nana into std::filesystem | ||||||
| # By default Nana will try to use the STD. If STD is not available and NANA_CMAKE_FIND_BOOST_FILESYSTEM | # By default Nana will try to use the STD. If STD is not available Nana own implementation will be used. | ||||||
| # is set to ON nana will try to use boost if available. Nana own implementation will be use if none of |  | ||||||
| # the previus were selected or available. |  | ||||||
| # You can change that default if you change one of the following | # You can change that default if you change one of the following | ||||||
| # (please don't define more than one of the _XX_FORCE options): | # (please don't define more than one of the _XX_FORCE options): | ||||||
| option(NANA_CMAKE_NANA_FILESYSTEM_FORCE "Force nana filesystem over ISO and boost?" OFF) | option(NANA_CMAKE_NANA_FILESYSTEM_FORCE "Force nana filesystem over ISO and boost?" OFF) | ||||||
| option(NANA_CMAKE_STD_FILESYSTEM_FORCE "Use of STD filesystem?(a compilation error will ocurre if not available)" OFF) | option(NANA_CMAKE_STD_FILESYSTEM_FORCE "Use of STD filesystem?(a compilation error will ocurre if not available)" OFF) | ||||||
| option(NANA_CMAKE_BOOST_FILESYSTEM_FORCE "Force use of Boost filesystem if available (over STD)?" OFF) | option(NANA_CMAKE_BOOST_FILESYSTEM_FORCE "Force use of Boost filesystem if available (over STD)?" OFF) | ||||||
| option(NANA_CMAKE_FIND_BOOST_FILESYSTEM "Search: Is Boost filesystem available?" OFF) | set (TEST_FS_LIB OFF) | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| if(NANA_CMAKE_NANA_FILESYSTEM_FORCE) | if(NANA_CMAKE_NANA_FILESYSTEM_FORCE) | ||||||
|  |     if(NANA_CMAKE_STD_FILESYSTEM_FORCE) | ||||||
|  |         message (FATAL_ERROR "Defined NANA_CMAKE_NANA_FILESYSTEM_FORCE and NANA_CMAKE_STD_FILESYSTEM_FORCE") | ||||||
|  |     endif() | ||||||
|  |     if(NANA_CMAKE_BOOST_FILESYSTEM_FORCE) | ||||||
|  |         message (FATAL_ERROR "Defined NANA_CMAKE_NANA_FILESYSTEM_FORCE and NANA_CMAKE_BOOST_FILESYSTEM_FORCE") | ||||||
|  |     endif() | ||||||
|  | 
 | ||||||
|     target_compile_definitions(nana PUBLIC NANA_FILESYSTEM_FORCE) |     target_compile_definitions(nana PUBLIC NANA_FILESYSTEM_FORCE) | ||||||
| 
 | 
 | ||||||
| elseif(NANA_CMAKE_STD_FILESYSTEM_FORCE) |  | ||||||
|     target_compile_definitions(nana PUBLIC STD_FILESYSTEM_FORCE) |  | ||||||
|     target_link_libraries     (nana PUBLIC stdc++fs) |  | ||||||
| 
 |  | ||||||
| elseif(NANA_CMAKE_BOOST_FILESYSTEM_FORCE) | elseif(NANA_CMAKE_BOOST_FILESYSTEM_FORCE) | ||||||
|  |     if(NANA_CMAKE_STD_FILESYSTEM_FORCE) | ||||||
|  |         message (FATAL_ERROR "Defined NANA_CMAKE_BOOST_FILESYSTEM_FORCE and NANA_CMAKE_STD_FILESYSTEM_FORCE") | ||||||
|  |     endif() | ||||||
|  | 
 | ||||||
|     target_compile_definitions(nana PUBLIC BOOST_FILESYSTEM_FORCE) |     target_compile_definitions(nana PUBLIC BOOST_FILESYSTEM_FORCE) | ||||||
|     # https://cmake.org/cmake/help/git-master/module/FindBoost.html |     # https://cmake.org/cmake/help/git-master/module/FindBoost.html | ||||||
|     # Implicit dependencies such as Boost::filesystem requiring Boost::system will be automatically detected and satisfied, |     # Implicit dependencies such as Boost::filesystem requiring Boost::system will be automatically detected and satisfied, | ||||||
| @ -43,14 +49,101 @@ elseif(NANA_CMAKE_BOOST_FILESYSTEM_FORCE) | |||||||
|     set(Boost_USE_STATIC_RUNTIME ON) |     set(Boost_USE_STATIC_RUNTIME ON) | ||||||
| 
 | 
 | ||||||
| else() | else() | ||||||
|     # todo   test for std    (for now just force nana or boost if there no std) |  | ||||||
|     target_link_libraries     (nana PUBLIC stdc++fs) |  | ||||||
| 
 | 
 | ||||||
|     # todo if not test for boost |     if(NANA_CMAKE_STD_FILESYSTEM_FORCE) | ||||||
|     # if not add nana filesystem |         target_compile_definitions(nana PUBLIC STD_FILESYSTEM_FORCE) | ||||||
|  |     endif() | ||||||
|  | 
 | ||||||
|  |     check_include_file_cxx (filesystem              NANA_HAVE_FILESYSTEM) | ||||||
|  |     check_include_file_cxx (experimental/filesystem NANA_HAVE_EXP_FILESYSTEM) | ||||||
|  | 
 | ||||||
|  |     if (NANA_HAVE_FILESYSTEM) | ||||||
|  |         message (STATUS "C++ Filesystem header:      <filesystem>") | ||||||
|  |         set (TEST_FS_LIB ON) | ||||||
|  |         set (CXXSTD_FS_TEST_SOURCE | ||||||
|  |            "#include <filesystem> | ||||||
|  |             int main() | ||||||
|  |             { | ||||||
|  |                 std::filesystem::path p{\"\tmp/\"}; | ||||||
|  |                 throw std::filesystem::filesystem_error(\"Empty file name!\", std::make_error_code(std::errc::invalid_argument)); | ||||||
|  |             }") | ||||||
|  |     elseif (NANA_HAVE_EXP_FILESYSTEM) | ||||||
|  |         message (STATUS "C++ Filesystem header:      <experimental/filesystem>") | ||||||
|  |         set (TEST_FS_LIB ON) | ||||||
|  |         set (CXXSTD_FS_TEST_SOURCE | ||||||
|  |            "#include <experimental/filesystem> | ||||||
|  |             int main() | ||||||
|  |             { | ||||||
|  |                 std::experimental::filesystem::path p{\"/tmp/\"}; | ||||||
|  |                 throw std::experimental::filesystem::filesystem_error(\"Empty file name!\", std::make_error_code(std::errc::invalid_argument)); | ||||||
|  |             }") | ||||||
|  |     else () | ||||||
|  |         message (WARNING "No std::filesystem include file found: nana::filesystem will be used. | ||||||
|  |                           Set NANA_CMAKE_NANA_FILESYSTEM_FORCE to ON to avoid this warning.") | ||||||
|  |         target_compile_definitions(nana PUBLIC STD_FILESYSTEM_NOT_SUPPORTED) | ||||||
|  |         set (TEST_FS_LIB OFF) | ||||||
|  |     endif () | ||||||
|  | 
 | ||||||
|  |     if (TEST_FS_LIB) | ||||||
|  |         include (FindPackageMessage) | ||||||
|  |         include (CheckIncludeFileCXX) | ||||||
|  |         include (CheckCXXSourceCompiles) | ||||||
|  |         # CMAKE_REQUIRED_FLAGS = string of compile command line flags | ||||||
|  |         # CMAKE_REQUIRED_DEFINITIONS = list of macros to define (-DFOO=bar) | ||||||
|  |         # CMAKE_REQUIRED_INCLUDES = list of include directories | ||||||
|  |         set (CMAKE_REQUIRED_INCLUDES    ${CMAKE_INCLUDE_PATH}) | ||||||
|  |         set (CMAKE_REQUIRED_FLAGS       ${CMAKE_CXX_FLAGS}) | ||||||
|  |         set (CMAKE_REQUIRED_FLAGS_ORIGINAL ${CMAKE_REQUIRED_FLAGS}) | ||||||
|  | 
 | ||||||
|  |         set (CXXSTD_TEST_SOURCE | ||||||
|  |                 "#if !defined (__cplusplus) || (__cplusplus < 201703L) | ||||||
|  |                 #error NOCXX17 | ||||||
|  |                 #endif | ||||||
|  |                 int main() {}") | ||||||
|  | 
 | ||||||
|  |         check_cxx_source_compiles ("${CXXSTD_TEST_SOURCE}" CXX17_BUILTIN) | ||||||
|  | 
 | ||||||
|  |         if (CXX17_BUILTIN) | ||||||
|  |             message (STATUS "C++ Standard-17 support:    builtin") | ||||||
|  |         else () | ||||||
|  |             set (CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS_ORIGINAL} -std=c++17") | ||||||
|  |             check_cxx_source_compiles ("${CXXSTD_TEST_SOURCE}" CXX17_FLAG) | ||||||
|  |             if (CXX17_FLAG) | ||||||
|  |                 message (STATUS "C++ Standard-17 support:    via -std=c++17") | ||||||
|  |             else () | ||||||
|  |                 message (WARNING "nana requires C++17??, but your compiler does not support it.") | ||||||
|  |             endif () | ||||||
|  |         endif () | ||||||
|  | 
 | ||||||
|  |         set (CMAKE_REQUIRED_LIBRARIES_ORIGINAL ${CMAKE_REQUIRED_LIBRARIES}) | ||||||
|  |         check_cxx_source_compiles ("${CXXSTD_TEST_SOURCE}" C++17FS_FLAG) | ||||||
|  | 
 | ||||||
|  |         if (C++17FS_FLAG) | ||||||
|  |             message (STATUS "C++ Filesystem library:     builtin") | ||||||
|  |         else () | ||||||
|  |             set (C++17FS_LIB "") | ||||||
|  |             foreach (_LIB stdc++fs) | ||||||
|  |                 set (CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES_ORIGINAL} ${_LIB}) | ||||||
|  |                 check_cxx_source_compiles ("${CXXSTD_FS_TEST_SOURCE}" C++17FS_LIB-l${_LIB}) | ||||||
|  |                 message (STATUS "C++ Filesystem library:    testing -l${_LIB}") | ||||||
|  |                 if (C++17FS_LIB-l${_LIB}) | ||||||
|  |                     target_link_libraries     (nana PUBLIC ${_LIB}) | ||||||
|  |                     message (STATUS "C++ Filesystem library:     via -l${_LIB}") | ||||||
|  |                     set (C++17FS_LIB ${_LIB}) | ||||||
|  |                     break () | ||||||
|  |                 endif () | ||||||
|  |                 set (CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES_ORIGINAL}) | ||||||
|  |             endforeach () | ||||||
|  | 
 | ||||||
|  |             if (C++17FS_LIB) | ||||||
|  |                 message (STATUS "C++ Filesystem library:     via -l${C++17FS_LIB}") | ||||||
|  |             else () | ||||||
|  |                 message (WARNING "No std::filesystem library found: nana::filesystem will be used. | ||||||
|  |                           Set NANA_CMAKE_NANA_FILESYSTEM_FORCE to ON to avoid this warning.") | ||||||
|  |                 target_compile_definitions(nana PUBLIC STD_FILESYSTEM_NOT_SUPPORTED) | ||||||
|  |             endif () | ||||||
|  |         endif () | ||||||
|  |     endif () | ||||||
| endif() | endif() | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| #define NANA_ANY_HPP | #define NANA_ANY_HPP | ||||||
| #include <typeinfo> | #include <typeinfo> | ||||||
| #include <type_traits> | #include <type_traits> | ||||||
|  | #include <utility> | ||||||
| 
 | 
 | ||||||
| #include "c++defines.hpp" | #include "c++defines.hpp" | ||||||
| 
 | 
 | ||||||
| @ -74,7 +75,7 @@ namespace nana | |||||||
| 		any(Value && value, | 		any(Value && value, | ||||||
| 				typename std::enable_if<!std::is_same<any&, Value>::value>::type * = nullptr, | 				typename std::enable_if<!std::is_same<any&, Value>::value>::type * = nullptr, | ||||||
| 				typename std::enable_if<!std::is_const<Value>::value>::type* = nullptr) | 				typename std::enable_if<!std::is_const<Value>::value>::type* = nullptr) | ||||||
| 			: content_(new holder<typename std::decay<Value>::type>(static_cast<Value&&>(value))) | 			: content_(new holder<typename std::decay<Value>::type>(std::forward<Value>(value))) | ||||||
| 		{ | 		{ | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| @ -87,7 +88,7 @@ namespace nana | |||||||
| 		template<class Value> | 		template<class Value> | ||||||
| 		any& operator=(Value&& other) | 		any& operator=(Value&& other) | ||||||
| 		{ | 		{ | ||||||
| 			any(other).swap(*this); | 			any(std::forward<Value>(other)).swap(*this); | ||||||
| 			return *this; | 			return *this; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -9,7 +9,7 @@ | |||||||
|  * |  * | ||||||
|  *	@file nana/filesystem/filesystem.hpp |  *	@file nana/filesystem/filesystem.hpp | ||||||
|  *  @author Ariel Vina-Rodriguez, Jinhao |  *  @author Ariel Vina-Rodriguez, Jinhao | ||||||
|  *  @brief Mimic std::experimental::filesystem::v1   (boost v3) |  *  @brief Mimic std::filesystem | ||||||
|  *  and need VC2015 or a C++11 compiler. With a few correction can be compiler by VC2013 |  *  and need VC2015 or a C++11 compiler. With a few correction can be compiler by VC2013 | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| @ -34,32 +34,26 @@ | |||||||
| //Filesystem Selection
 | //Filesystem Selection
 | ||||||
| #include <nana/config.hpp> | #include <nana/config.hpp> | ||||||
| 
 | 
 | ||||||
| #if defined(NANA_USING_NANA_FILESYSTEM) || defined(NANA_USING_STD_FILESYSTEM) || defined(NANA_USING_BOOST_FILESYSTEM) |  | ||||||
| #undef NANA_USING_NANA_FILESYSTEM |  | ||||||
| #undef NANA_USING_STD_FILESYSTEM |  | ||||||
| #undef NANA_USING_BOOST_FILESYSTEM |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #define NANA_USING_NANA_FILESYSTEM  0 | #define NANA_USING_NANA_FILESYSTEM  0 | ||||||
| #define NANA_USING_STD_FILESYSTEM   0 | #define NANA_USING_STD_FILESYSTEM   0 | ||||||
| #define NANA_USING_BOOST_FILESYSTEM 0 | #define NANA_USING_BOOST_FILESYSTEM 0 | ||||||
| 
 | 
 | ||||||
| #if (defined(NANA_FILESYSTEM_FORCE) || ( (defined(STD_FILESYSTEM_NOT_SUPPORTED) && !defined(BOOST_FILESYSTEM_AVAILABLE)) && !(defined(BOOST_FILESYSTEM_FORCE) || defined(STD_FILESYSTEM_FORCE)) ) ) | //#define NANA_FILESYSTEM_FORCE 1
 | ||||||
| 
 | 
 | ||||||
|  | #if (defined(NANA_FILESYSTEM_FORCE) || ( (defined(STD_FILESYSTEM_NOT_SUPPORTED) && !defined(BOOST_FILESYSTEM_AVAILABLE)) && !(defined(BOOST_FILESYSTEM_FORCE) || defined(STD_FILESYSTEM_FORCE)) ) ) | ||||||
| #undef  NANA_USING_NANA_FILESYSTEM | #undef  NANA_USING_NANA_FILESYSTEM | ||||||
| #define NANA_USING_NANA_FILESYSTEM  1 | #define NANA_USING_NANA_FILESYSTEM  1 | ||||||
| 
 | 
 | ||||||
| #elif (defined(BOOST_FILESYSTEM_AVAILABLE) && ( defined(BOOST_FILESYSTEM_FORCE) || ( defined(STD_FILESYSTEM_NOT_SUPPORTED) && !defined(STD_FILESYSTEM_FORCE) ) )) | #elif (defined(BOOST_FILESYSTEM_AVAILABLE) && ( defined(BOOST_FILESYSTEM_FORCE) || ( defined(STD_FILESYSTEM_NOT_SUPPORTED) && !defined(STD_FILESYSTEM_FORCE) ) )) | ||||||
| 
 |  | ||||||
| #undef  NANA_USING_BOOST_FILESYSTEM | #undef  NANA_USING_BOOST_FILESYSTEM | ||||||
| #define NANA_USING_BOOST_FILESYSTEM 1 | #define NANA_USING_BOOST_FILESYSTEM 1 | ||||||
| #   include <chrono> | #   include <chrono> | ||||||
| #   include <boost/filesystem.hpp> | #   include <boost/filesystem.hpp> | ||||||
| 
 | 
 | ||||||
| // add boost::filesystem into std::experimental::filesystem
 | // inline boost::filesystem into std::filesystem
 | ||||||
| namespace std { | namespace std { | ||||||
| 	namespace experimental { |  | ||||||
| 	namespace filesystem { | 	namespace filesystem { | ||||||
|  | 	    inline namespace boost_filesystem { | ||||||
| 			using namespace boost::filesystem; | 			using namespace boost::filesystem; | ||||||
| 			using file_time_type = std::chrono::time_point<std::chrono::system_clock>; | 			using file_time_type = std::chrono::time_point<std::chrono::system_clock>; | ||||||
| 
 | 
 | ||||||
| @ -75,16 +69,16 @@ namespace std { | |||||||
| 				socket = boost::filesystem::file_type::socket_file, | 				socket = boost::filesystem::file_type::socket_file, | ||||||
| 				unknown = boost::filesystem::file_type::type_unknown, | 				unknown = boost::filesystem::file_type::type_unknown, | ||||||
| 			}; | 			}; | ||||||
| // Boost dont include generic_u8string
 |             // Boost dont include generic_u8string
 | ||||||
| // http://www.boost.org/doc/libs/1_66_0/boost/filesystem/path.hpp
 |             // http://www.boost.org/doc/libs/1_66_0/boost/filesystem/path.hpp
 | ||||||
| //
 |             //
 | ||||||
| // Boost versions: 1.67.0, 1.66.0, ... 1.56.0 enable directory_iterator C++11 range-base for
 |             // Boost versions: 1.67.0, 1.66.0, ... 1.56.0 enable directory_iterator C++11 range-base for
 | ||||||
| // http://www.boost.org/doc/libs/1_66_0/boost/filesystem/operations.hpp
 |             // http://www.boost.org/doc/libs/1_66_0/boost/filesystem/operations.hpp
 | ||||||
| // but travis come with an oooold version of boost
 |             // but travis come with an oooold version of boost
 | ||||||
| // 1.55.0 NOT enable directory_iterator C++11 range-base for
 |             // 1.55.0 NOT enable directory_iterator C++11 range-base for
 | ||||||
| // http://www.boost.org/doc/libs/1_54_0/boost/filesystem/operations.hpp
 |             // http://www.boost.org/doc/libs/1_54_0/boost/filesystem/operations.hpp
 | ||||||
| #if BOOST_VERSION < 105600 |             #if BOOST_VERSION < 105600 | ||||||
|             namespace boost |                 namespace boost {      // todo  ??
 | ||||||
|                     //  enable directory_iterator C++11 range-base for statement use  --------------------//
 |                     //  enable directory_iterator C++11 range-base for statement use  --------------------//
 | ||||||
| 
 | 
 | ||||||
|                     //  begin() and end() are only used by a range-based for statement in the context of
 |                     //  begin() and end() are only used by a range-based for statement in the context of
 | ||||||
| @ -99,19 +93,10 @@ namespace std { | |||||||
|                     { |                     { | ||||||
|                         return directory_iterator(); |                         return directory_iterator(); | ||||||
|                     } |                     } | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| 		} // filesystem
 |  | ||||||
| 	} // experimental
 |  | ||||||
| 
 |  | ||||||
| 	namespace filesystem |  | ||||||
| 	{ |  | ||||||
| 		using namespace experimental::filesystem; |  | ||||||
|                 } |                 } | ||||||
| 
 |             #endif | ||||||
| #ifndef __cpp_lib_experimental_filesystem | 		} // boost_filesystem
 | ||||||
| #   define __cpp_lib_experimental_filesystem 201406 | 	} // filesystem
 | ||||||
| #endif |  | ||||||
| } // std
 | } // std
 | ||||||
| 
 | 
 | ||||||
| #else | #else | ||||||
| @ -148,25 +133,21 @@ namespace std { | |||||||
| 
 | 
 | ||||||
| #include <nana/deploy.hpp> | #include <nana/deploy.hpp> | ||||||
| 
 | 
 | ||||||
| namespace nana  { namespace experimental { namespace filesystem | namespace nana { | ||||||
| { |     namespace filesystem { | ||||||
| #ifndef CXX_NO_INLINE_NAMESPACE |  | ||||||
| 			inline namespace v1 |  | ||||||
| 			{ |  | ||||||
| #endif |  | ||||||
| 
 | 
 | ||||||
|         enum class file_type |         enum class file_type | ||||||
|         { |         { | ||||||
|             none      = 0,   ///< has not been determined or an error occurred while trying to determine
 |             none      = 0,   ///< has not been determined or an error occurred while trying to determine
 | ||||||
|             not_found = -1, ///< Pseudo-type: file was not found. Is not considered an error
 |             not_found = -1, ///< Pseudo-type: file was not found. Is not considered an error
 | ||||||
|             regular   = 1, |             regular   = 1, | ||||||
| 		directory = 2  , |             directory = 2, | ||||||
| 		symlink =3, ///< Symbolic link file
 |             symlink   = 3, ///< Symbolic link file
 | ||||||
| 		block =4,  ///< Block special file
 |             block     = 4,  ///< Block special file
 | ||||||
| 		character= 5 ,  ///< Character special file
 |             character = 5,  ///< Character special file
 | ||||||
| 		fifo = 6 ,  ///< FIFO or pipe file
 |             fifo      = 6,  ///< FIFO or pipe file
 | ||||||
| 		socket =7, |             socket    = 7, | ||||||
| 		unknown= 8  ///< The file does exist, but is of an operating system dependent type not covered by any of the other
 |             unknown   = 8  ///< The file does exist, but is of an operating system dependent type not covered by any of the other
 | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         enum class perms |         enum class perms | ||||||
| @ -204,11 +185,14 @@ namespace nana  { namespace experimental { namespace filesystem | |||||||
| 
 | 
 | ||||||
|             // observers
 |             // observers
 | ||||||
|             file_type type() const; |             file_type type() const; | ||||||
|  | 
 | ||||||
|             perms permissions() const; |             perms permissions() const; | ||||||
| 
 | 
 | ||||||
|             // modifiers
 |             // modifiers
 | ||||||
|             void type(file_type ft); |             void type(file_type ft); | ||||||
|  | 
 | ||||||
|             void permissions(perms prms); |             void permissions(perms prms); | ||||||
|  | 
 | ||||||
|           private: |           private: | ||||||
|             file_type value_; |             file_type value_; | ||||||
|             perms     perms_; |             perms     perms_; | ||||||
| @ -236,105 +220,142 @@ namespace nana  { namespace experimental { namespace filesystem | |||||||
|             path() = default; |             path() = default; | ||||||
| 
 | 
 | ||||||
|             template<typename Source> |             template<typename Source> | ||||||
| 		path(const Source& source) |             path(const Source &source) | ||||||
|             { |             { | ||||||
|                 _m_assign(source); |                 _m_assign(source); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             // modifiers
 |             // modifiers
 | ||||||
|             void clear() noexcept; |             void clear() noexcept; | ||||||
| 		path& make_preferred(); | 
 | ||||||
| 		path& remove_filename(); |             path &make_preferred(); | ||||||
|  | 
 | ||||||
|  |             path &remove_filename(); | ||||||
|             //path& replace_filename(const path& replacement);
 |             //path& replace_filename(const path& replacement);
 | ||||||
|             //path& replace_extension(const path& replacement = path());
 |             //path& replace_extension(const path& replacement = path());
 | ||||||
|             //void swap(path& rhs) noexcept;
 |             //void swap(path& rhs) noexcept;
 | ||||||
| 
 | 
 | ||||||
|             // decomposition
 |             // decomposition
 | ||||||
|             path root_name() const; |             path root_name() const; | ||||||
|  | 
 | ||||||
|             path root_directory() const; |             path root_directory() const; | ||||||
|  | 
 | ||||||
|             path root_path() const; |             path root_path() const; | ||||||
|  | 
 | ||||||
|             path relative_path() const; |             path relative_path() const; | ||||||
|  | 
 | ||||||
|             path parent_path() const; |             path parent_path() const; | ||||||
|  | 
 | ||||||
|             path filename() const; |             path filename() const; | ||||||
|  | 
 | ||||||
|             path stem() const; |             path stem() const; | ||||||
|  | 
 | ||||||
|             path extension() const; |             path extension() const; | ||||||
| 
 | 
 | ||||||
|             // query
 |             // query
 | ||||||
|             bool empty() const noexcept; |             bool empty() const noexcept; | ||||||
| 		bool has_root_name() const { return !root_name().empty();  } | 
 | ||||||
| 		bool has_root_directory() const { return !root_directory().empty();  } |             bool has_root_name() const | ||||||
| 		bool has_root_path() const { return !root_path().empty();  } |             { return !root_name().empty(); } | ||||||
| 		bool has_relative_path() const { return !relative_path().empty(); } | 
 | ||||||
| 		bool has_parent_path() const { return !parent_path().empty(); };   // temp;;
 |             bool has_root_directory() const | ||||||
| 		bool has_filename() const    { return !filename().empty(); };   // temp;
 |             { return !root_directory().empty(); } | ||||||
|  | 
 | ||||||
|  |             bool has_root_path() const | ||||||
|  |             { return !root_path().empty(); } | ||||||
|  | 
 | ||||||
|  |             bool has_relative_path() const | ||||||
|  |             { return !relative_path().empty(); } | ||||||
|  | 
 | ||||||
|  |             bool has_parent_path() const | ||||||
|  |             { return !parent_path().empty(); };   // temp;;
 | ||||||
|  |             bool has_filename() const | ||||||
|  |             { return !filename().empty(); };   // temp;
 | ||||||
|             //bool has_stem() const;
 |             //bool has_stem() const;
 | ||||||
| 		bool has_extension() const   { return !extension().empty(); };   // temp
 |             bool has_extension() const | ||||||
|  |             { return !extension().empty(); };   // temp
 | ||||||
|             bool is_absolute() const; |             bool is_absolute() const; | ||||||
|  | 
 | ||||||
|             bool is_relative() const; |             bool is_relative() const; | ||||||
| 
 | 
 | ||||||
| 		int compare(const path& other) const; |             int compare(const path &other) const; | ||||||
| 
 | 
 | ||||||
|             file_type what() const; |             file_type what() const; | ||||||
| 
 | 
 | ||||||
| 		const value_type*c_str() const; |             const value_type *c_str() const; | ||||||
| 		const string_type& native() const; | 
 | ||||||
|  |             const string_type &native() const; | ||||||
|  | 
 | ||||||
|             operator string_type() const; |             operator string_type() const; | ||||||
| 
 | 
 | ||||||
|             std::string string() const; |             std::string string() const; | ||||||
|  | 
 | ||||||
|             std::wstring wstring() const; |             std::wstring wstring() const; | ||||||
| 		std::string u8string() const; | 
 | ||||||
|  |             // std::string u8string() const;
 | ||||||
|             // std::u16string u16string() const;
 |             // std::u16string u16string() const;
 | ||||||
|             // std::u32string u32string() const;
 |             // std::u32string u32string() const;
 | ||||||
| 
 | 
 | ||||||
| 		std::string generic_string() const ; |             std::string generic_string() const; | ||||||
|  | 
 | ||||||
|             std::wstring generic_wstring() const; |             std::wstring generic_wstring() const; | ||||||
| 		std::string generic_u8string() const; | 
 | ||||||
|  |             // std::string generic_u8string() const;
 | ||||||
|             // std::u16string generic_u16string() const;
 |             // std::u16string generic_u16string() const;
 | ||||||
|             // std::u32string generic_u32string() const;
 |             // std::u32string generic_u32string() const;
 | ||||||
| 
 | 
 | ||||||
|             path lexically_normal() const; |             path lexically_normal() const; | ||||||
| 
 | 
 | ||||||
|             //appends
 |             //appends
 | ||||||
| 		path& operator/=(const path& other); |             path &operator/=(const path &other); | ||||||
| 
 | 
 | ||||||
|             template<typename Source> |             template<typename Source> | ||||||
| 		path& operator/=(const Source& source) |             path &operator/=(const Source &source) | ||||||
|             { |             { | ||||||
|                 path other(source); |                 path other(source); | ||||||
|                 return this->operator/=(other); |                 return this->operator/=(other); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             template<typename Source> |             template<typename Source> | ||||||
| 		path& append(const Source& source) |             path &append(const Source &source) | ||||||
|             { |             { | ||||||
|                 path other(source); |                 path other(source); | ||||||
|                 return this->operator/=(other); |                 return this->operator/=(other); | ||||||
|             } |             } | ||||||
|  | 
 | ||||||
|           private: |           private: | ||||||
| 		void _m_assign(const std::string& source_utf8); |             void _m_assign(const std::string &source_utf8); | ||||||
| 		void _m_assign(const std::wstring& source); | 
 | ||||||
|  |             void _m_assign(const std::wstring &source); | ||||||
|  | 
 | ||||||
|           private: |           private: | ||||||
|             string_type pathstr_; |             string_type pathstr_; | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
| 	bool operator==(const path& lhs, const path& rhs); |         bool operator==(const path &lhs, const path &rhs); | ||||||
| 	bool operator!=(const path& lhs, const path& rhs); | 
 | ||||||
| 	bool operator<(const path& lhs, const path& rhs); |         bool operator!=(const path &lhs, const path &rhs); | ||||||
| 	bool operator>(const path& lhs, const path& rhs); | 
 | ||||||
| 	path operator/(const path& lhs, const path& rhs); |         bool operator<(const path &lhs, const path &rhs); | ||||||
|  | 
 | ||||||
|  |         bool operator>(const path &lhs, const path &rhs); | ||||||
|  | 
 | ||||||
|  |         path operator/(const path &lhs, const path &rhs); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         class filesystem_error |         class filesystem_error | ||||||
|                 : public std::system_error |                 : public std::system_error | ||||||
|         { |         { | ||||||
|           public: |           public: | ||||||
| 		explicit filesystem_error(const std::string& msg, std::error_code); |             explicit filesystem_error(const std::string &msg, std::error_code); | ||||||
| 
 | 
 | ||||||
| 		filesystem_error(const std::string& msg, const path& path1, std::error_code err); |             filesystem_error(const std::string &msg, const path &path1, std::error_code err); | ||||||
| 		filesystem_error(const std::string& msg, const path& path1, const path& path2, std::error_code err); |  | ||||||
| 
 | 
 | ||||||
| 		const path& path1() const noexcept; |             filesystem_error(const std::string &msg, const path &path1, const path &path2, std::error_code err); | ||||||
| 		const path& path2() const noexcept; | 
 | ||||||
|  |             const path &path1() const noexcept; | ||||||
|  | 
 | ||||||
|  |             const path &path2() const noexcept; | ||||||
|             // const char* what() const noexcept;
 |             // const char* what() const noexcept;
 | ||||||
|           private: |           private: | ||||||
|             path path1_; |             path path1_; | ||||||
| @ -346,65 +367,78 @@ namespace nana  { namespace experimental { namespace filesystem | |||||||
|         { |         { | ||||||
|           public: |           public: | ||||||
|             directory_entry() = default; |             directory_entry() = default; | ||||||
| 		explicit directory_entry(const ::nana::experimental::filesystem::path&); | 
 | ||||||
|  |             explicit directory_entry(const filesystem::path &); | ||||||
| 
 | 
 | ||||||
|             //modifiers
 |             //modifiers
 | ||||||
| 		void assign(const ::nana::experimental::filesystem::path&); |             void assign(const filesystem::path &); | ||||||
| 		void replace_filename(const ::nana::experimental::filesystem::path&); | 
 | ||||||
|  |             void replace_filename(const filesystem::path &); | ||||||
| 
 | 
 | ||||||
|             //observers
 |             //observers
 | ||||||
|             file_status status() const; |             file_status status() const; | ||||||
| 		operator const filesystem::path&() const {	return path_;	}; | 
 | ||||||
| 		const filesystem::path& path() const; |             operator const filesystem::path &() const | ||||||
|  |             { return path_; }; | ||||||
|  | 
 | ||||||
|  |             const filesystem::path &path() const; | ||||||
|  | 
 | ||||||
|           private: |           private: | ||||||
| 		::nana::experimental::filesystem::path path_; |             filesystem::path path_; | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         /// InputIterator that iterate over the sequence of directory_entry elements representing the files in a directory, not an recursive_directory_iterator
 |         /// InputIterator that iterate over the sequence of directory_entry elements representing the files in a directory, not an recursive_directory_iterator
 | ||||||
| 	class directory_iterator 		:public std::iterator<std::input_iterator_tag, directory_entry> |         class directory_iterator : public std::iterator<std::input_iterator_tag, directory_entry> | ||||||
|         { |         { | ||||||
| 		using find_handle = void*; |             using find_handle = void *; | ||||||
|           public: |           public: | ||||||
| 
 | 
 | ||||||
|             directory_iterator() noexcept; |             directory_iterator() noexcept; | ||||||
| 		explicit directory_iterator(const path& p); |  | ||||||
| 		directory_iterator(const path& p, directory_options opt); |  | ||||||
| 
 | 
 | ||||||
| 		const value_type& operator*() const; |             explicit directory_iterator(const path &p); | ||||||
| 		const value_type* operator->() const; | 
 | ||||||
|  |             directory_iterator(const path &p, directory_options opt); | ||||||
|  | 
 | ||||||
|  |             const value_type &operator*() const; | ||||||
|  | 
 | ||||||
|  |             const value_type *operator->() const; | ||||||
|  | 
 | ||||||
|  |             directory_iterator &operator++(); | ||||||
| 
 | 
 | ||||||
| 		directory_iterator& operator++(); |  | ||||||
|             directory_iterator operator++(int);  ///< extention
 |             directory_iterator operator++(int);  ///< extention
 | ||||||
| 
 | 
 | ||||||
| 		bool equal(const directory_iterator& x) const; |             bool equal(const directory_iterator &x) const; | ||||||
| 
 | 
 | ||||||
|           private: |           private: | ||||||
|             template<typename Char> |             template<typename Char> | ||||||
| 		static bool _m_ignore(const Char * p) |             static bool _m_ignore(const Char *p) | ||||||
|             { |             { | ||||||
| 			while(*p == '.') |                 while (*p == '.') | ||||||
|                     ++p; |                     ++p; | ||||||
|                 return (*p == 0); |                 return (*p == 0); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
| 		void _m_prepare(const path& file_path); |             void _m_prepare(const path &file_path); | ||||||
|  | 
 | ||||||
|             void _m_read(); |             void _m_read(); | ||||||
|  | 
 | ||||||
|           private: |           private: | ||||||
|             bool              end_{false}; |             bool              end_{false}; | ||||||
|             path::string_type path_; |             path::string_type path_; | ||||||
| 		directory_options option_{ directory_options::none }; |             directory_options option_{directory_options::none}; | ||||||
| 
 | 
 | ||||||
|             std::shared_ptr<find_handle> find_ptr_; |             std::shared_ptr<find_handle> find_ptr_; | ||||||
|             find_handle                  handle_{nullptr}; |             find_handle                  handle_{nullptr}; | ||||||
|             value_type                   value_; |             value_type                   value_; | ||||||
|         }; |         }; | ||||||
|  | 
 | ||||||
|         /// enable directory_iterator range-based for statements
 |         /// enable directory_iterator range-based for statements
 | ||||||
| 	inline directory_iterator begin( directory_iterator iter) noexcept |         inline directory_iterator begin(directory_iterator iter) noexcept | ||||||
|         { |         { | ||||||
|             return iter; |             return iter; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| 	inline directory_iterator end(	const directory_iterator&) noexcept |         inline directory_iterator end(const directory_iterator &) noexcept | ||||||
|         { |         { | ||||||
|             return {}; |             return {}; | ||||||
|         } |         } | ||||||
| @ -416,42 +450,46 @@ namespace nana  { namespace experimental { namespace filesystem | |||||||
|         //recursive_directory_iterator end(const recursive_directory_iterator&) noexcept;
 |         //recursive_directory_iterator end(const recursive_directory_iterator&) noexcept;
 | ||||||
| 
 | 
 | ||||||
|         //template<typename Value_Type>
 |         //template<typename Value_Type>
 | ||||||
| 	inline bool operator==(const directory_iterator/*<Value_Type>*/ & x, const directory_iterator/*<Value_Type>*/ & y) |         inline bool operator==(const directory_iterator/*<Value_Type>*/ &x, const directory_iterator/*<Value_Type>*/ &y) | ||||||
|         { |         { | ||||||
|             return x.equal(y); |             return x.equal(y); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         //template<typename Value_Type>
 |         //template<typename Value_Type>
 | ||||||
| 	inline bool operator!=(const directory_iterator/*<Value_Type>*/ & x, const directory_iterator/*<Value_Type>*/ & y) |         inline bool operator!=(const directory_iterator/*<Value_Type>*/ &x, const directory_iterator/*<Value_Type>*/ &y) | ||||||
|         { |         { | ||||||
|             return !x.equal(y); |             return !x.equal(y); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 	file_status status(const path& p); |         file_status status(const path &p); | ||||||
| 	file_status status(const path& p, std::error_code&); |  | ||||||
| 
 | 
 | ||||||
| 	std::uintmax_t file_size(const path& p); |         file_status status(const path &p, std::error_code &); | ||||||
| 	std::uintmax_t file_size(const path& p, std::error_code& ec) noexcept; | 
 | ||||||
|  |         std::uintmax_t file_size(const path &p); | ||||||
|  | 
 | ||||||
|  |         std::uintmax_t file_size(const path &p, std::error_code &ec) noexcept; | ||||||
| 
 | 
 | ||||||
|         inline bool is_directory(file_status s) noexcept |         inline bool is_directory(file_status s) noexcept | ||||||
| 	{ return s.type() == file_type::directory ;} |         { return s.type() == file_type::directory; } | ||||||
| 
 | 
 | ||||||
| 	bool is_directory(const path& p); |         bool is_directory(const path &p); | ||||||
|     bool is_directory(const path& p, std::error_code& ec) noexcept; | 
 | ||||||
|  |         bool is_directory(const path &p, std::error_code &ec) noexcept; | ||||||
| 
 | 
 | ||||||
|         inline bool is_regular_file(file_status s) noexcept |         inline bool is_regular_file(file_status s) noexcept | ||||||
|         { |         { | ||||||
|             return s.type() == file_type::regular; |             return s.type() == file_type::regular; | ||||||
|         } |         } | ||||||
| 	inline bool is_regular_file(const path& p) | 
 | ||||||
|  |         inline bool is_regular_file(const path &p) | ||||||
|         { |         { | ||||||
|             return is_regular_file(status(p)); |             return is_regular_file(status(p)); | ||||||
|         } |         } | ||||||
| 	// bool is_regular_file(const path& p, error_code& ec) noexcept;
 |         // bool is_regular_file(const path& p, error_code& ec) noexcept;  // todo:
 | ||||||
|     // Returns: is_regular_file(status(p, ec)).Returns false if an error occurs.
 |         // Returns: is_regular_file(status(p, ec)).Returns false if an error occurs. // todo:
 | ||||||
| 
 | 
 | ||||||
| 	inline bool is_empty(const path& p) |         inline bool is_empty(const path &p) | ||||||
|         { |         { | ||||||
|             auto fs = status(p); |             auto fs = status(p); | ||||||
| 
 | 
 | ||||||
| @ -463,34 +501,38 @@ namespace nana  { namespace experimental { namespace filesystem | |||||||
|         // bool is_empty(const path& p, error_code& ec) noexcept;
 |         // bool is_empty(const path& p, error_code& ec) noexcept;
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 	bool create_directories(const path& p); |         bool create_directories(const path &p); | ||||||
|  | 
 | ||||||
|         //bool create_directories(const path& p, error_code& ec) noexcept;
 |         //bool create_directories(const path& p, error_code& ec) noexcept;
 | ||||||
| 	bool create_directory(const path& p); |         bool create_directory(const path &p); | ||||||
|  | 
 | ||||||
|         //bool create_directory(const path& p, error_code& ec) noexcept;
 |         //bool create_directory(const path& p, error_code& ec) noexcept;
 | ||||||
| 	bool create_directory(const path& p, const path& attributes); |         bool create_directory(const path &p, const path &attributes); | ||||||
|         //bool create_directory(const path& p, const path& attributes,     error_code& ec) noexcept;
 |         //bool create_directory(const path& p, const path& attributes,     error_code& ec) noexcept;
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         /// The time of last data modification of p, determined as if by the value of the POSIX
 |         /// The time of last data modification of p, determined as if by the value of the POSIX
 | ||||||
|         /// stat structure member st_mtime obtained as if by POSIX stat().
 |         /// stat structure member st_mtime obtained as if by POSIX stat().
 | ||||||
| 	file_time_type last_write_time(const path& p); |         file_time_type last_write_time(const path &p); | ||||||
|         /// returns file_time_type::min() if an error occurs
 |         /// returns file_time_type::min() if an error occurs
 | ||||||
|         //file_time_type last_write_time(const path& p, error_code& ec) noexcept;
 |         //file_time_type last_write_time(const path& p, error_code& ec) noexcept;
 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         path current_path(); |         path current_path(); | ||||||
|  | 
 | ||||||
|         //path current_path(error_code& ec);
 |         //path current_path(error_code& ec);
 | ||||||
| 	void current_path(const path& p);   ///< chdir
 |         void current_path(const path &p);   ///< chdir
 | ||||||
|         //void current_path(const path& p, error_code& ec) noexcept;
 |         //void current_path(const path& p, error_code& ec) noexcept;
 | ||||||
| 
 | 
 | ||||||
| 	bool remove(const path& p); |         bool remove(const path &p); | ||||||
| 	bool remove(const path& p, std::error_code& ec); // noexcept;
 | 
 | ||||||
|  |         bool remove(const path &p, std::error_code &ec); // noexcept;
 | ||||||
| 
 | 
 | ||||||
|         //uintmax_t remove_all(const path& p);
 |         //uintmax_t remove_all(const path& p);
 | ||||||
|         //uintmax_t remove_all(const path& p, error_code& ec) noexcept;
 |         //uintmax_t remove_all(const path& p, error_code& ec) noexcept;
 | ||||||
| 
 | 
 | ||||||
|         template<typename CharType> |         template<typename CharType> | ||||||
| 	std::basic_string<CharType> parent_path(const std::basic_string<CharType>& path) |         std::basic_string<CharType> parent_path(const std::basic_string<CharType> &path) | ||||||
|         { |         { | ||||||
|             auto index = path.size(); |             auto index = path.size(); | ||||||
| 
 | 
 | ||||||
| @ -515,34 +557,41 @@ namespace nana  { namespace experimental { namespace filesystem | |||||||
| 
 | 
 | ||||||
|             return index ? path.substr(0, index + 1) : std::basic_string<CharType>(); |             return index ? path.substr(0, index + 1) : std::basic_string<CharType>(); | ||||||
|         } |         } | ||||||
| #ifndef CXX_NO_INLINE_NAMESPACE |  | ||||||
| } //end namespace v1
 |  | ||||||
| #endif |  | ||||||
| } //end namespace filesystem
 |  | ||||||
| } //end namespace experimental
 |  | ||||||
| 
 | 
 | ||||||
|   //namespace filesystem = experimental::filesystem;
 |         path absolute(const path& p); | ||||||
|  |         path absolute(const path& p, std::error_code& err); | ||||||
|  | 
 | ||||||
|  |         path canonical(const path& p); | ||||||
|  |         path canonical(const path& p, std::error_code& err); | ||||||
|  | 
 | ||||||
|  |         path weakly_canonical(const path& p); | ||||||
|  |         path weakly_canonical(const path& p, std::error_code& err); | ||||||
|  | 
 | ||||||
|  |         bool exists( file_status s ) noexcept; | ||||||
|  |         bool exists( const path& p ); | ||||||
|  |         bool exists( const path& p, std::error_code& ec ) noexcept; | ||||||
|  |     } //end namespace filesystem
 | ||||||
| } //end namespace nana
 | } //end namespace nana
 | ||||||
| 
 | 
 | ||||||
|  | namespace std | ||||||
|  | { | ||||||
|  |     namespace filesystem | ||||||
|  |     { | ||||||
|  |         inline namespace nana_filesystem | ||||||
|  |         { | ||||||
|  |             using namespace ::nana::filesystem; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| namespace std { |  | ||||||
| 	namespace experimental { |  | ||||||
| 		namespace filesystem { |  | ||||||
| 
 | 
 | ||||||
| #       ifdef CXX_NO_INLINE_NAMESPACE | #else //#if NANA_USING_NANA_FILESYSTEM
 | ||||||
| 			using namespace nana::experimental::filesystem; | //Implements the missing functions for various version of experimental/filesystem
 | ||||||
| #       else | 	namespace std | ||||||
| 			using namespace nana::experimental::filesystem::v1; | 	{ | ||||||
| #       endif | 		namespace filesystem | ||||||
| 
 | 		{ | ||||||
| 		} // filesystem
 | #if defined(_MSC_VER) && ((!defined(_MSVC_LANG)) || (_MSVC_LANG < 201703)) | ||||||
| 	} // experimental
 |  | ||||||
| 
 |  | ||||||
| 	namespace filesystem { |  | ||||||
| 		using namespace std::experimental::filesystem; |  | ||||||
| 
 |  | ||||||
| #if defined(NANA_FILESYSTEM_FORCE) || \ |  | ||||||
|     (defined(_MSC_VER) && ((!defined(_MSVC_LANG)) || (_MSVC_LANG < 201703))) |  | ||||||
|         path absolute(const path& p); |         path absolute(const path& p); | ||||||
|         path absolute(const path& p, std::error_code& err); |         path absolute(const path& p, std::error_code& err); | ||||||
| 
 | 
 | ||||||
| @ -553,19 +602,12 @@ namespace std { | |||||||
|         path weakly_canonical(const path& p, std::error_code& err); |         path weakly_canonical(const path& p, std::error_code& err); | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #if defined(NANA_FILESYSTEM_FORCE) || defined(NANA_MINGW) | #if defined(NANA_MINGW)   // todo ??
 | ||||||
|         bool exists( std::filesystem::file_status s ) noexcept; |         bool exists( std::filesystem::file_status s ) noexcept; | ||||||
|         bool exists( const std::filesystem::path& p ); |         bool exists( const std::filesystem::path& p ); | ||||||
|         bool exists( const std::filesystem::path& p, std::error_code& ec ) noexcept; |         bool exists( const std::filesystem::path& p, std::error_code& ec ) noexcept; | ||||||
| #endif | #endif | ||||||
| 	} | 
 | ||||||
| } // std
 |  | ||||||
| #else //#if NANA_USING_NANA_FILESYSTEM
 |  | ||||||
| //Implements the missing functions for various version of experimental/filesystem
 |  | ||||||
| 	namespace std |  | ||||||
| 	{ |  | ||||||
| 		namespace filesystem |  | ||||||
| 		{ |  | ||||||
| 		    //Visual Studio 2017
 | 		    //Visual Studio 2017
 | ||||||
| #if	(defined(NANA_USING_STD_EXPERIMENTAL_FILESYSTEM) && defined(_MSC_VER) && (_MSC_VER > 1912)) ||	\ | #if	(defined(NANA_USING_STD_EXPERIMENTAL_FILESYSTEM) && defined(_MSC_VER) && (_MSC_VER > 1912)) ||	\ | ||||||
| 				(!defined(__clang__) && defined(__GNUC__) && (__cplusplus < 201603 || (__GNUC__* 100 + __GNUC_MINOR__ < 801))) | 				(!defined(__clang__) && defined(__GNUC__) && (__cplusplus < 201603 || (__GNUC__* 100 + __GNUC_MINOR__ < 801))) | ||||||
|  | |||||||
| @ -1,13 +1,13 @@ | |||||||
| /**
 | /**
 | ||||||
| *	Nana C++ Library(http://www.nanapro.org)
 | *	Nana C++ Library(http://www.nanapro.org)
 | ||||||
| *	Copyright(C) 2003-2018 Jinhao(cnjinhao@hotmail.com) | *	Copyright(C) 2003-2019 Jinhao(cnjinhao@hotmail.com) | ||||||
| * | * | ||||||
| *	Distributed under the Boost Software License, Version 1.0. | *	Distributed under the Boost Software License, Version 1.0. | ||||||
| *	(See accompanying file LICENSE_1_0.txt or copy at | *	(See accompanying file LICENSE_1_0.txt or copy at | ||||||
| *	http://www.boost.org/LICENSE_1_0.txt)
 | *	http://www.boost.org/LICENSE_1_0.txt)
 | ||||||
| * | * | ||||||
| *	@file nana\filesystem\filesystem_ext.hpp | *	@file nana\filesystem\filesystem_ext.hpp | ||||||
| *   @autor by Ariel Vina-Rodriguez: | *   @autor Ariel Vina-Rodriguez: | ||||||
| *	@brief Some convenient extensions to the filesystem library. | *	@brief Some convenient extensions to the filesystem library. | ||||||
| * | * | ||||||
| */ | */ | ||||||
| @ -35,16 +35,6 @@ namespace filesystem_ext | |||||||
| 
 | 
 | ||||||
| std::filesystem::path path_user();    ///< extention ?
 | std::filesystem::path path_user();    ///< extention ?
 | ||||||
| 
 | 
 | ||||||
| 													/// workaround Boost not having path.generic_u8string() - a good point for http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2016/p0251r0.pdf
 |  | ||||||
| inline std::string generic_u8string(const std::filesystem::path& p) |  | ||||||
| { |  | ||||||
| #if NANA_USING_BOOST_FILESYSTEM |  | ||||||
| 	return nana::to_utf8(p.generic_wstring()); |  | ||||||
| #else |  | ||||||
| 	return p.generic_u8string(); |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| inline bool is_directory(const std::filesystem::directory_entry& dir) noexcept | inline bool is_directory(const std::filesystem::directory_entry& dir) noexcept | ||||||
| { | { | ||||||
|     return is_directory(dir.status()); |     return is_directory(dir.status()); | ||||||
| @ -57,10 +47,10 @@ class directory_only_iterator : public std::filesystem::directory_iterator | |||||||
| 
 | 
 | ||||||
| 	directory_only_iterator& find_first() | 	directory_only_iterator& find_first() | ||||||
| 	{ | 	{ | ||||||
| 		auto end = directory_only_iterator{}; |         directory_only_iterator end{}; | ||||||
| 		while (*this != end) | 		while (*this != end) | ||||||
| 		{ | 		{ | ||||||
| 			if (is_directory((**this).status())) | 			if (is_directory((*(*this)).status())) | ||||||
| 				return *this; | 				return *this; | ||||||
| 			this->directory_iterator::operator++(); | 			this->directory_iterator::operator++(); | ||||||
| 		} | 		} | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| /*
 | /**
 | ||||||
|  *	A ISO C++ FileSystem Implementation |  *	A ISO C++ FileSystem Implementation | ||||||
|  *	Copyright(C) 2003-2019 Jinhao(cnjinhao@hotmail.com) |  *	Copyright(C) 2003-2019 Jinhao(cnjinhao@hotmail.com) | ||||||
|  * |  * | ||||||
| @ -6,14 +6,15 @@ | |||||||
|  *	(See accompanying file LICENSE_1_0.txt or copy at |  *	(See accompanying file LICENSE_1_0.txt or copy at | ||||||
|  *	http://www.boost.org/LICENSE_1_0.txt)
 |  *	http://www.boost.org/LICENSE_1_0.txt)
 | ||||||
|  * |  * | ||||||
|  *	@file: nana/filesystem/filesystem.cpp |  *	@file  nana/filesystem/filesystem.cpp | ||||||
|  *	@description: |  *	@description | ||||||
|  *		provide some interface for file management |  *		provide some interface for file management | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #include <nana/filesystem/filesystem_ext.hpp> | #include <nana/filesystem/filesystem_ext.hpp> | ||||||
| #include <vector> | #include <vector> | ||||||
| #include <sstream> | #include <sstream> | ||||||
|  | #include <string> | ||||||
| 
 | 
 | ||||||
| #include <nana/config.hpp> | #include <nana/config.hpp> | ||||||
| #ifdef _nana_std_put_time | #ifdef _nana_std_put_time | ||||||
| @ -150,14 +151,11 @@ namespace nana | |||||||
| 
 | 
 | ||||||
| #if NANA_USING_NANA_FILESYSTEM | #if NANA_USING_NANA_FILESYSTEM | ||||||
| 
 | 
 | ||||||
| namespace nana_fs = nana::experimental::filesystem; | namespace nana_fs = nana::filesystem; | ||||||
| 
 | namespace nana | ||||||
| namespace nana {	namespace experimental {	namespace filesystem | { | ||||||
| 	{ | namespace filesystem | ||||||
| #ifndef CXX_NO_INLINE_NAMESPACE | { | ||||||
| 			inline namespace v1 { |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
|     //class filesystem_error
 |     //class filesystem_error
 | ||||||
|         filesystem_error::filesystem_error(const std::string& msg, std::error_code err) |         filesystem_error::filesystem_error(const std::string& msg, std::error_code err) | ||||||
|             : std::system_error(err, msg) |             : std::system_error(err, msg) | ||||||
| @ -185,7 +183,6 @@ namespace nana {	namespace experimental {	namespace filesystem | |||||||
|         } |         } | ||||||
|     //end class filesystem_error
 |     //end class filesystem_error
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|     //Because of No wide character version of POSIX
 |     //Because of No wide character version of POSIX
 | ||||||
| #if defined(NANA_POSIX) | #if defined(NANA_POSIX) | ||||||
| 		const char* separators = "/"; | 		const char* separators = "/"; | ||||||
| @ -512,10 +509,10 @@ namespace nana {	namespace experimental {	namespace filesystem | |||||||
| 			return to_wstring(pathstr_); | 			return to_wstring(pathstr_); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		std::string path::u8string() const | 		/*std::string path::u8string() const
 | ||||||
| 		{ | 		{ | ||||||
| 			return to_utf8(pathstr_); | 			return to_utf8(pathstr_); | ||||||
| 		} | 		}*/ | ||||||
| 		std::string path::generic_string() const | 		std::string path::generic_string() const | ||||||
| 		{ | 		{ | ||||||
| 			auto str = string(); | 			auto str = string(); | ||||||
| @ -528,12 +525,12 @@ namespace nana {	namespace experimental {	namespace filesystem | |||||||
| 			std::replace(str.begin(), str.end(), L'\\', L'/'); | 			std::replace(str.begin(), str.end(), L'\\', L'/'); | ||||||
| 			return str; | 			return str; | ||||||
| 		} | 		} | ||||||
| 		std::string path::generic_u8string() const // uppss ...
 | 		/*std::string path::generic_u8string() const // uppss ...
 | ||||||
| 		{ | 		{ | ||||||
| 			auto str = pathstr_; | 			auto str = pathstr_; | ||||||
| 			std::replace(str.begin(), str.end(), '\\', '/');  // uppss ...  revise this !!!!!
 | 			std::replace(str.begin(), str.end(), '\\', '/');  // uppss ...  revise this !!!!!
 | ||||||
| 			return to_utf8(str); | 			return to_utf8(str); | ||||||
| 		} | 		}*/ | ||||||
| 
 | 
 | ||||||
| 		path path::lexically_normal() const | 		path path::lexically_normal() const | ||||||
| 		{ | 		{ | ||||||
| @ -667,7 +664,7 @@ namespace nana {	namespace experimental {	namespace filesystem | |||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		//class directory_entry
 | 		//class directory_entry
 | ||||||
| 			directory_entry::directory_entry(const nana_fs::path& p) | 			directory_entry::directory_entry(const filesystem::path& p) | ||||||
| 				:path_{ p } | 				:path_{ p } | ||||||
| 			{} | 			{} | ||||||
| 
 | 
 | ||||||
| @ -978,7 +975,6 @@ namespace nana {	namespace experimental {	namespace filesystem | |||||||
| #endif | #endif | ||||||
| 		}//end namespace detail
 | 		}//end namespace detail
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 		file_status status(const path& p) | 		file_status status(const path& p) | ||||||
| 		{ | 		{ | ||||||
| 			std::error_code err; | 			std::error_code err; | ||||||
| @ -1182,19 +1178,216 @@ namespace nana {	namespace experimental {	namespace filesystem | |||||||
| #endif | #endif | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| #ifndef CXX_NO_INLINE_NAMESPACE |         path absolute(const path& p) | ||||||
| 		} //end namespace v1
 |         { | ||||||
|  |             if (p.empty()) | ||||||
|  |                 return p; | ||||||
|  | 
 | ||||||
|  |             auto abs_base = current_path(); | ||||||
|  | 
 | ||||||
|  |             //  store expensive to compute values that are needed multiple times
 | ||||||
|  |             path p_root_name(p.root_name()); | ||||||
|  |             path base_root_name(abs_base.root_name()); | ||||||
|  |             path p_root_directory(p.root_directory()); | ||||||
|  | 
 | ||||||
|  |             if (!p_root_name.empty())  // p.has_root_name()
 | ||||||
|  |             { | ||||||
|  |                 if (p_root_directory.empty())  // !p.has_root_directory()
 | ||||||
|  |                     return p_root_name / abs_base.root_directory() | ||||||
|  |                            / abs_base.relative_path() / p.relative_path(); | ||||||
|  |                 // p is absolute, so fall through to return p at end of block
 | ||||||
|  |             } | ||||||
|  |             else if (!p_root_directory.empty())  // p.has_root_directory()
 | ||||||
|  |             { | ||||||
|  | #ifdef NANA_POSIX | ||||||
|  |                 // POSIX can have root name it it is a network path
 | ||||||
|  |                 if (base_root_name.empty())   // !abs_base.has_root_name()
 | ||||||
|  |                     return p; | ||||||
| #endif | #endif | ||||||
| 		}//end namespace filesystem
 |                 return base_root_name / p; | ||||||
| 	} //end namespace experimental
 |             } | ||||||
|  |             else | ||||||
|  |                 return abs_base / p; | ||||||
|  | 
 | ||||||
|  |             return p;  // p.is_absolute() is true
 | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         path absolute(const path& p, std::error_code& /*err*/) | ||||||
|  |         { | ||||||
|  |             return absolute(p); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         path canonical(const path& p, std::error_code* err) | ||||||
|  |         { | ||||||
|  |             path source(p.is_absolute() ? p : absolute(p)); | ||||||
|  |             path root(source.root_path()); | ||||||
|  |             path result; | ||||||
|  | 
 | ||||||
|  |             std::error_code local_ec; | ||||||
|  |             file_status stat(status(source, local_ec)); | ||||||
|  | 
 | ||||||
|  |             if (stat.type() == file_type::not_found) | ||||||
|  |             { | ||||||
|  |                 if (nullptr == err) | ||||||
|  |                     throw (filesystem_error( | ||||||
|  |                             "nana::filesystem::canonical", source, | ||||||
|  |                             std::error_code(static_cast<int>(std::errc::no_such_file_or_directory), std::generic_category()))); | ||||||
|  |                 err->assign(static_cast<int>(std::errc::no_such_file_or_directory), std::generic_category()); | ||||||
|  |                 return result; | ||||||
|  |             } | ||||||
|  |             else if (local_ec) | ||||||
|  |             { | ||||||
|  |                 if (nullptr == err) | ||||||
|  |                     throw (filesystem_error( | ||||||
|  |                             "nana::filesystem::canonical", source, local_ec)); | ||||||
|  |                 *err = local_ec; | ||||||
|  |                 return result; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |             auto tmp_p = source; | ||||||
|  | 
 | ||||||
|  |             std::vector<path> source_elements; | ||||||
|  |             while (tmp_p != root) | ||||||
|  |             { | ||||||
|  |                 source_elements.emplace(source_elements.begin(), tmp_p.filename()); | ||||||
|  |                 tmp_p.remove_filename(); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             result = root; | ||||||
|  | 
 | ||||||
|  |             for(auto & e : source_elements) | ||||||
|  |             { | ||||||
|  |                 auto str = e.string(); | ||||||
|  |                 if("." == str) | ||||||
|  |                     continue; | ||||||
|  |                 else if(".." == str) | ||||||
|  |                 { | ||||||
|  |                     if(result != root) | ||||||
|  |                         result.remove_filename(); | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 result /= e; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (err) | ||||||
|  |                 err->clear(); | ||||||
|  | 
 | ||||||
|  |             return result; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         path canonical(const path& p) | ||||||
|  |         { | ||||||
|  |             return canonical(p, nullptr); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         path canonical(const path& p, std::error_code& err) | ||||||
|  |         { | ||||||
|  |             return canonical(p, &err); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         bool try_throw(int err_val, const path& p, std::error_code* ec, const char* message) | ||||||
|  |         { | ||||||
|  |             if (0 == err_val) | ||||||
|  |             { | ||||||
|  |                 if (ec) ec->clear(); | ||||||
|  |             } | ||||||
|  |             else | ||||||
|  |             {	//error
 | ||||||
|  |                 if (nullptr == ec) | ||||||
|  |                     throw (filesystem_error( | ||||||
|  |                             message, p, | ||||||
|  |                             std::error_code(err_val, std::generic_category()))); | ||||||
|  |                 else | ||||||
|  |                     ec->assign(err_val, std::system_category()); | ||||||
|  |             } | ||||||
|  |             return err_val != 0; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         path weakly_canonical(const path& p, std::error_code* err) | ||||||
|  |         { | ||||||
|  |             path head{ p }; | ||||||
|  | 
 | ||||||
|  |             std::error_code tmp_err; | ||||||
|  |             std::vector<path> elements; | ||||||
|  |             while (!head.empty()) | ||||||
|  |             { | ||||||
|  |                 auto head_status = status(head, tmp_err); | ||||||
|  | 
 | ||||||
|  |                 if (head_status.type() == file_type::unknown) | ||||||
|  |                 { | ||||||
|  |                     if (try_throw(static_cast<int>(std::errc::invalid_argument), head, err, "nana::filesystem::weakly_canonical")) | ||||||
|  |                         return path{}; | ||||||
|  |                 } | ||||||
|  |                 if (head_status.type() != file_type::not_found) | ||||||
|  |                     break; | ||||||
|  | 
 | ||||||
|  |                 elements.emplace_back(head.filename()); | ||||||
|  |                 head.remove_filename(); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             bool tail_has_dots = false; | ||||||
|  |             path tail; | ||||||
|  | 
 | ||||||
|  |             for (auto & e : elements) | ||||||
|  |             { | ||||||
|  |                 tail /= e; | ||||||
|  |                 // for a later optimization, track if any dot or dot-dot elements are present
 | ||||||
|  |                 if (e.native().size() <= 2 | ||||||
|  |                     && e.native()[0] == '.' | ||||||
|  |                     && (e.native().size() == 1 || e.native()[1] == '.')) | ||||||
|  |                     tail_has_dots = true; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (head.empty()) | ||||||
|  |                 return p.lexically_normal(); | ||||||
|  |             head = canonical(head, tmp_err); | ||||||
|  |             if (try_throw(tmp_err.value(), head, err, "nana::filesystem::weakly_canonical")) | ||||||
|  |                 return path(); | ||||||
|  |             return tail.empty() | ||||||
|  |                    ? head | ||||||
|  |                    : (tail_has_dots  // optimization: only normalize if tail had dot or dot-dot element
 | ||||||
|  |                       ? (head / tail).lexically_normal() | ||||||
|  |                       : head / tail); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         path weakly_canonical(const path& p) | ||||||
|  |         { | ||||||
|  |             return weakly_canonical(p, nullptr); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         path weakly_canonical(const path& p, std::error_code& err) | ||||||
|  |         { | ||||||
|  |             return weakly_canonical(p, &err); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         bool exists( std::filesystem::file_status s ) noexcept | ||||||
|  |     { | ||||||
|  |         return s.type() != file_type::not_found; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |         bool exists( const std::filesystem::path& p ) | ||||||
|  |     { | ||||||
|  |         return exists(status(p)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |         bool exists( const std::filesystem::path& p, std::error_code& ec ) noexcept | ||||||
|  |     { | ||||||
|  |         return exists(status(p, ec)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 		} //end namespace filesystem
 | ||||||
| }//end namespace nana
 | }//end namespace nana
 | ||||||
|  | #else | ||||||
| 
 | 
 | ||||||
| namespace std | namespace std | ||||||
| { | { | ||||||
| 	namespace filesystem | 	namespace filesystem | ||||||
| 	{ | 	{ | ||||||
| #if defined(NANA_FILESYSTEM_FORCE) || \ | #if defined(_MSC_VER) && ((!defined(_MSVC_LANG)) || (_MSVC_LANG < 201703)) | ||||||
|     (defined(_MSC_VER) && ((!defined(_MSVC_LANG)) || (_MSVC_LANG < 201703))) | 
 | ||||||
| 		path absolute(const path& p) | 		path absolute(const path& p) | ||||||
| 		{ | 		{ | ||||||
| 			if (p.empty()) | 			if (p.empty()) | ||||||
| @ -1379,8 +1572,8 @@ namespace std | |||||||
| 			return weakly_canonical(p, &err); | 			return weakly_canonical(p, &err); | ||||||
| 		} | 		} | ||||||
| #endif | #endif | ||||||
| 
 | /*
 | ||||||
| #if defined(NANA_FILESYSTEM_FORCE) || defined(NANA_MINGW) | #if defined(NANA_MINGW) | ||||||
|     bool exists( std::filesystem::file_status s ) noexcept |     bool exists( std::filesystem::file_status s ) noexcept | ||||||
|     { |     { | ||||||
|         return s.type() != file_type::not_found; |         return s.type() != file_type::not_found; | ||||||
| @ -1395,17 +1588,10 @@ namespace std | |||||||
|     { |     { | ||||||
|         return exists(status(p, ec)); |         return exists(status(p, ec)); | ||||||
|     } |     } | ||||||
| #endif | */ | ||||||
|  }//end namespace filesystem
 |  }//end namespace filesystem
 | ||||||
| }//end namespace std
 | }//end namespace std
 | ||||||
| 
 | 
 | ||||||
| #else 	//else NANA_USING_NANA_FILESYSTEM
 |  | ||||||
| 
 |  | ||||||
| 	//Defines the functions that are not provided by experimental/filesystem
 |  | ||||||
| 	namespace std |  | ||||||
| 	{ |  | ||||||
| 		namespace filesystem |  | ||||||
| 		{ |  | ||||||
| #if		(defined(NANA_USING_STD_EXPERIMENTAL_FILESYSTEM) && defined(_MSC_VER) && (_MSC_VER > 1912)) ||	\ | #if		(defined(NANA_USING_STD_EXPERIMENTAL_FILESYSTEM) && defined(_MSC_VER) && (_MSC_VER > 1912)) ||	\ | ||||||
| 			(!defined(__clang__) && defined(__GNUC__) && (__cplusplus < 201603 || (__GNUC__* 100 + __GNUC_MINOR__ < 801))) | 			(!defined(__clang__) && defined(__GNUC__) && (__cplusplus < 201603 || (__GNUC__* 100 + __GNUC_MINOR__ < 801))) | ||||||
| 
 | 
 | ||||||
| @ -1550,9 +1736,9 @@ namespace std | |||||||
| 			{ | 			{ | ||||||
| 				return weakly_canonical(p, &err); | 				return weakly_canonical(p, &err); | ||||||
| 			} | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| #endif | #endif | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| #endif //NANA_USING_NANA_FILESYSTEM
 | #endif //NANA_USING_NANA_FILESYSTEM
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1522,7 +1522,7 @@ namespace nana | |||||||
| 			if (!*str) | 			if (!*str) | ||||||
| 			{ | 			{ | ||||||
| 				targets.emplace_back(parent_path); | 				targets.emplace_back(parent_path); | ||||||
| 				impl_->path = parent_path.parent_path().u8string(); | 				impl_->path = parent_path.parent_path().string(); | ||||||
| 			} | 			} | ||||||
| 			else | 			else | ||||||
| 			{ | 			{ | ||||||
| @ -1532,7 +1532,7 @@ namespace nana | |||||||
| 					targets.emplace_back(parent_path / path_type{str}); | 					targets.emplace_back(parent_path / path_type{str}); | ||||||
| 					str += (len + 1); | 					str += (len + 1); | ||||||
| 				} | 				} | ||||||
| 				impl_->path = parent_path.u8string(); | 				impl_->path = parent_path.string(); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		else | 		else | ||||||
| @ -1540,7 +1540,7 @@ namespace nana | |||||||
| 			wfile.resize(std::wcslen(wfile.data())); | 			wfile.resize(std::wcslen(wfile.data())); | ||||||
| 
 | 
 | ||||||
| 			targets.emplace_back(wfile); | 			targets.emplace_back(wfile); | ||||||
| 			impl_->path = targets.front().parent_path().u8string(); | 			impl_->path = targets.front().parent_path().string(); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| #elif defined(NANA_POSIX) | #elif defined(NANA_POSIX) | ||||||
|  | |||||||
| @ -1267,7 +1267,7 @@ namespace nana | |||||||
| 			auto files = impl->fbox.show(); | 			auto files = impl->fbox.show(); | ||||||
| 			if(!files.empty()) | 			if(!files.empty()) | ||||||
| 			{ | 			{ | ||||||
| 				impl->value = files.front().u8string(); | 				impl->value = files.front().string(); | ||||||
| 				impl->path_edit.caption(impl->value); | 				impl->path_edit.caption(impl->value); | ||||||
| 			} | 			} | ||||||
| 		}); | 		}); | ||||||
|  | |||||||
| @ -2401,7 +2401,9 @@ namespace nana | |||||||
| 								nana::rectangle r; | 								nana::rectangle r; | ||||||
| 								if (rect_lister(r)) | 								if (rect_lister(r)) | ||||||
| 								{ | 								{ | ||||||
| 									auto top = new_where.second * item_h + header_visible_px(); | 									//potential displacement due to partially visible first visible item
 | ||||||
|  | 									auto disp = origin.y - first_display().item * item_h; | ||||||
|  | 									auto top = new_where.second * item_h + header_visible_px() - disp; | ||||||
| 									if (checkarea(item_xpos(r), static_cast<int>(top)).is_hit(pos)) | 									if (checkarea(item_xpos(r), static_cast<int>(top)).is_hit(pos)) | ||||||
| 										new_where.first = parts::checker; | 										new_where.first = parts::checker; | ||||||
| 								} | 								} | ||||||
| @ -6000,6 +6002,7 @@ namespace nana | |||||||
| 		{ | 		{ | ||||||
| 			internal_scope_guard lock; | 			internal_scope_guard lock; | ||||||
| 			_m_ess().lister.sort_column(col, &reverse); | 			_m_ess().lister.sort_column(col, &reverse); | ||||||
|  | 			_m_ess().update(); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		auto listbox::sort_col() const -> size_type | 		auto listbox::sort_col() const -> size_type | ||||||
|  | |||||||
| @ -1229,7 +1229,8 @@ namespace nana | |||||||
| 
 | 
 | ||||||
| 				void trigger::erase(std::size_t pos) | 				void trigger::erase(std::size_t pos) | ||||||
| 				{ | 				{ | ||||||
| 					layouter_->erase(pos); | 					if (layouter_->erase(pos)) | ||||||
|  | 						API::refresh_window(layouter_->widget_handle()); | ||||||
| 				} | 				} | ||||||
| 
 | 
 | ||||||
| 				void trigger::tab_color(std::size_t i, bool is_bgcolor, const ::nana::color& clr) | 				void trigger::tab_color(std::size_t i, bool is_bgcolor, const ::nana::color& clr) | ||||||
|  | |||||||
| @ -1274,7 +1274,10 @@ namespace nana | |||||||
| 
 | 
 | ||||||
| 				item_proxy	item_proxy::operator++(int) | 				item_proxy	item_proxy::operator++(int) | ||||||
| 				{ | 				{ | ||||||
| 					return sibling(); | 					item_proxy ip(*this); | ||||||
|  | 					if(trigger_ && node_) | ||||||
|  | 						node_ = node_->next; | ||||||
|  | 					return ip; | ||||||
| 				} | 				} | ||||||
| 
 | 
 | ||||||
| 				item_proxy& item_proxy::operator*() | 				item_proxy& item_proxy::operator*() | ||||||
| @ -1952,7 +1955,7 @@ namespace nana | |||||||
| 					impl_->attr.tree_cont.for_each<item_locator&>(shape.first, nl); | 					impl_->attr.tree_cont.for_each<item_locator&>(shape.first, nl); | ||||||
| 
 | 
 | ||||||
| 					auto const node = nl.node(); | 					auto const node = nl.node(); | ||||||
| 					if (!node) | 					if (!node || !node->child) | ||||||
| 						return; | 						return; | ||||||
| 
 | 
 | ||||||
| 					switch (nl.what()) | 					switch (nl.what()) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Jinhao
						Jinhao