From 6d84be2051ad471323a34041b2d153b1e2733419 Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Thu, 18 Feb 2016 15:38:33 +0100 Subject: [PATCH 1/8] working on directory_only_iterator --- include/nana/filesystem/filesystem.hpp | 13 +++--- include/nana/filesystem/filesystem_ext.hpp | 48 +++++++++++++++++++--- 2 files changed, 48 insertions(+), 13 deletions(-) diff --git a/include/nana/filesystem/filesystem.hpp b/include/nana/filesystem/filesystem.hpp index 61ce8223..88b9dbd0 100644 --- a/include/nana/filesystem/filesystem.hpp +++ b/include/nana/filesystem/filesystem.hpp @@ -297,15 +297,12 @@ namespace nana { namespace experimental { namespace filesystem std::uintmax_t file_size(const path& p); //uintmax_t file_size(const path& p, error_code& ec) noexcept; - inline bool is_directory(file_status s) { return s.type() == file_type::directory ;} - bool is_directory(const path& p); - inline bool is_directory(const directory_entry& d) - { - return is_directory(d.status()); - } - //bool is_directory(const path& p, error_code& ec) noexcept; + inline bool is_directory(file_status s) noexcept + { return s.type() == file_type::directory ;} - //bool is_regular_file(file_status s) noexcept; + bool is_directory(const path& p); + + //bool is_directory(const path& p, error_code& ec) noexcept; inline bool is_empty(const path& p) { diff --git a/include/nana/filesystem/filesystem_ext.hpp b/include/nana/filesystem/filesystem_ext.hpp index 0e75b249..35aeec7c 100644 --- a/include/nana/filesystem/filesystem_ext.hpp +++ b/include/nana/filesystem/filesystem_ext.hpp @@ -26,18 +26,56 @@ namespace nana {namespace experimental {namespace filesystem {namespace ext { constexpr auto def_rootname = "Root/"; #endif -// nana::experimental::filesystem::path_user()); // REPLACE !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! to filesystem_ext.hhp +// nana::experimental::filesystem::path_user()); // REPLACE !!!!!!!!!! to filesystem_ext.hhp -template // DI = directory_iterator from std, boost, or nana +inline bool is_directory(const directory_entry& d) noexcept +{ + return is_directory(d.status()); +} + + +template // DI = directory_iterator from std, boost, or nana : return directory_entry class directory_only_iterator : public DI { - // if (!this->is_directory()) continue; + DI& find_first() + { + while(( (*this) != DI{}) || !is_directory((*this)) ) + this->DI::operator++(); + return (*this); + } +public: + template + directory_only_iterator(Arg&&... arg ): DI(std::forward(arg)...) + { + find_first(); + } + directory_only_iterator& operator++() + { + this->DI::operator++(); + return find_first(); + } }; -template // DI = directory_iterator from std, boost, or nana +template // DI = directory_iterator from std, boost, or nana : value_type directory_entry class regular_file_only_iterator : public DI { - // if (this->is_directory()) continue; + DI& find_first() + { + while(( (*this) != DI{}) || !is_regular_file(*this) ) + this->DI::operator++(); + return (*this); + } +public: + template + regular_file_only_iterator(Arg&&... arg ): DI(std::forward(arg)...) + { + find_first(); + } + regular_file_only_iterator& operator++() + { + this->DI::operator++(); + return find_first(); + } }; }}}} From d8a06989f34d48afb990654e499b47e67e687846 Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Thu, 18 Feb 2016 16:00:17 +0100 Subject: [PATCH 2/8] working on directory_only_iterator --- include/nana/filesystem/filesystem_ext.hpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/include/nana/filesystem/filesystem_ext.hpp b/include/nana/filesystem/filesystem_ext.hpp index 35aeec7c..90b9978d 100644 --- a/include/nana/filesystem/filesystem_ext.hpp +++ b/include/nana/filesystem/filesystem_ext.hpp @@ -39,7 +39,7 @@ class directory_only_iterator : public DI { DI& find_first() { - while(( (*this) != DI{}) || !is_directory((*this)) ) + while(( (*this) != DI{}) || !is_directory((*this)->status()) ) this->DI::operator++(); return (*this); } @@ -61,7 +61,7 @@ class regular_file_only_iterator : public DI { DI& find_first() { - while(( (*this) != DI{}) || !is_regular_file(*this) ) + while(( (*this) != DI{}) || !is_regular_file((*this)->status()) ) this->DI::operator++(); return (*this); } From 9f430f7220a6f2b3870fb7652549dfcd52df4183 Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Fri, 19 Feb 2016 13:52:15 +0100 Subject: [PATCH 3/8] more standard features for filesystem --- include/nana/filesystem/filesystem.hpp | 70 +++++++++++++++----------- source/filesystem/filesystem.cpp | 8 +-- 2 files changed, 43 insertions(+), 35 deletions(-) diff --git a/include/nana/filesystem/filesystem.hpp b/include/nana/filesystem/filesystem.hpp index 88b9dbd0..c44345c6 100644 --- a/include/nana/filesystem/filesystem.hpp +++ b/include/nana/filesystem/filesystem.hpp @@ -1,4 +1,4 @@ -/* +/** * A ISO C++ filesystem Implementation * Nana C++ Library(http://www.nanapro.org) * Copyright(C) 2003-2016 Jinhao(cnjinhao@hotmail.com) @@ -7,17 +7,17 @@ * (See accompanying file LICENSE_1_0.txt or copy at * http://www.boost.org/LICENSE_1_0.txt) * - * @file: nana/filesystem/filesystem.hpp - * Modiffied by Ariel Vina-Rodriguez: - * Now mimic std::experimental::filesystem::v1 (boost v3) - * and need VC2015 or a C++11 compiler. With a few correction will be compiler by VC2013 + * @file nana/filesystem/filesystem.hpp + * @author Jinhao, conributed: Ariel Vina-Rodriguez + * @brief Mimic std::experimental::filesystem::v1 (boost v3) + * and need VC2015 or a C++11 compiler. With a few correction can be compiler by VC2013 */ +// http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4100.pdf --- last pdf of std draft N4100 2014-07-04 // http://en.cppreference.com/w/cpp/experimental/fs // http://cpprocks.com/introduction-to-tr2-filesystem-library-in-vs2012/ --- TR2 filesystem in VS2012 // https://msdn.microsoft.com/en-us/library/hh874694%28v=vs.140%29.aspx --- C++ 14, the header VS2015 // https://msdn.microsoft.com/en-us/library/hh874694%28v=vs.120%29.aspx --- header VS2013 -// http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4100.pdf --- last pdf of std draft N4100 2014-07-04 // http://cplusplus.github.io/filesystem-ts/working-draft.html --- in html format // http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2014/n4099.html --- in html format // http://article.gmane.org/gmane.comp.lib.boost.devel/256220 --- The filesystem TS unanimously approved by ISO. @@ -47,7 +47,7 @@ namespace nana { namespace experimental { namespace filesystem { #endif - enum class file_type + enum class file_type { 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 @@ -78,7 +78,7 @@ namespace nana { namespace experimental { namespace filesystem uintmax_t available; }; - using file_time_type = std::chrono::time_point;// trivial-clock> ; + using file_time_type = std::chrono::time_point; ///< trivial-clock> ; class file_status { @@ -112,7 +112,7 @@ namespace nana { namespace experimental { namespace filesystem public: #if defined(NANA_WINDOWS) using value_type = wchar_t; - const static value_type preferred_separator = '\\'; + const static value_type preferred_separator = '\\'; //? L'\\' ? #else using value_type = char; const static value_type preferred_separator = '/'; @@ -199,8 +199,9 @@ namespace nana { namespace experimental { namespace filesystem 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 - const path& path2() const; //noexcept + const path& path1() const noexcept; + const path& path2() const noexcept; + // const char* what() const noexcept; private: path path1_; path path2_; @@ -225,33 +226,23 @@ namespace nana { namespace experimental { namespace filesystem filesystem::path path_; }; - /// an iterator for a sequence of directory_entry elements representing the files in a directory, not an recursive_directory_iterator - //template + /// 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 { using find_handle = void*; public: - using value_type = directory_entry ; - typedef ptrdiff_t difference_type; - typedef const directory_entry* pointer; - typedef const directory_entry& reference; - typedef std::input_iterator_tag iterator_category; - directory_iterator(); - directory_iterator(const path& file_path); + directory_iterator() noexcept; + explicit directory_iterator(const path& dir); const value_type& operator*() const; const value_type* operator->() const; directory_iterator& operator++(); - directory_iterator operator++(int); + directory_iterator operator++(int); ///< extention - bool equal(const directory_iterator& x) const; + bool equal(const directory_iterator& x) const; - // enable directory_iterator range-based for statements - directory_iterator begin(); - directory_iterator end(); - private: template static bool _m_ignore(const Char * p) @@ -271,6 +262,16 @@ namespace nana { namespace experimental { namespace filesystem find_handle handle_{nullptr}; value_type value_; }; + /// enable directory_iterator range-based for statements + inline directory_iterator begin( directory_iterator iter) noexcept + { + return iter; + } + + inline directory_iterator end( const directory_iterator&) noexcept + { + return {}; + } //class recursive_directory_iterator; @@ -304,6 +305,17 @@ namespace nana { namespace experimental { namespace filesystem //bool is_directory(const path& p, error_code& ec) noexcept; + inline bool is_regular_file(file_status s) noexcept + { + return s.type() == file_type::regular; + } + inline bool is_regular_file(const path& p) + { + return is_regular_file(status(p)); + } + // bool is_regular_file(const path& p, error_code& ec) noexcept; + // Returns: is_regular_file(status(p, ec)).Returns false if an error occurs. + inline bool is_empty(const path& p) { auto fs = status(p); @@ -313,7 +325,7 @@ namespace nana { namespace experimental { namespace filesystem return (file_size(p) == 0); } - //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); @@ -325,11 +337,11 @@ namespace nana { namespace experimental { namespace filesystem bool modified_file_time(const path& p, struct tm&); - path path_user(); + path path_user(); ///< extention ? path current_path(); //path current_path(error_code& ec); - void current_path(const path& p); + void current_path(const path& p); ///< chdir //void current_path(const path& p, error_code& ec) noexcept; diff --git a/source/filesystem/filesystem.cpp b/source/filesystem/filesystem.cpp index 3f432fbd..fc68a885 100644 --- a/source/filesystem/filesystem.cpp +++ b/source/filesystem/filesystem.cpp @@ -384,7 +384,7 @@ namespace nana { namespace experimental { namespace filesystem } }; - directory_iterator::directory_iterator() + directory_iterator::directory_iterator() noexcept : end_(true), handle_(nullptr) {} @@ -414,14 +414,10 @@ namespace nana { namespace experimental { namespace filesystem bool directory_iterator::equal(const directory_iterator& x) const { if (end_ && (end_ == x.end_)) return true; - return (value_.path().filename() == x.value_.path().filename()); + return (value_.path().filename() == x.value_.path().filename()); } - // enable directory_iterator range-based for statements - directory_iterator directory_iterator::begin() { return *this; } - directory_iterator directory_iterator::end() { return{}; } - void directory_iterator::_m_prepare(const path& file_path) { path_ = file_path.native(); From 17782a60e1e93e2238fa2c7ee6336d30a9827366 Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Fri, 19 Feb 2016 13:58:14 +0100 Subject: [PATCH 4/8] directory_only_iterator is OK now --- include/nana/filesystem/filesystem_ext.hpp | 61 ++++++++++++++++------ 1 file changed, 45 insertions(+), 16 deletions(-) diff --git a/include/nana/filesystem/filesystem_ext.hpp b/include/nana/filesystem/filesystem_ext.hpp index 90b9978d..7e33ae9e 100644 --- a/include/nana/filesystem/filesystem_ext.hpp +++ b/include/nana/filesystem/filesystem_ext.hpp @@ -26,22 +26,28 @@ namespace nana {namespace experimental {namespace filesystem {namespace ext { constexpr auto def_rootname = "Root/"; #endif -// nana::experimental::filesystem::path_user()); // REPLACE !!!!!!!!!! to filesystem_ext.hhp +// nana::experimental::filesystem::path_user()); -inline bool is_directory(const directory_entry& d) noexcept +inline bool is_directory(const std::experimental::filesystem::directory_entry& dir) noexcept { - return is_directory(d.status()); + return is_directory(dir.status()); } -template // DI = directory_iterator from std, boost, or nana : return directory_entry -class directory_only_iterator : public DI -{ - DI& find_first() +//template // DI = directory_iterator from std, boost, or nana : return directory_entry +class directory_only_iterator : public std::experimental::filesystem::directory_iterator +{ + using DI = std::experimental::filesystem::directory_iterator; + directory_only_iterator& find_first() { - while(( (*this) != DI{}) || !is_directory((*this)->status()) ) - this->DI::operator++(); - return (*this); + auto end = directory_only_iterator{}; + while (*this != end) + { + if (is_directory((**this).status())) + return *this; + this->DI::operator++(); + } + return end; } public: template @@ -49,19 +55,31 @@ public: { find_first(); } + directory_only_iterator( ) {} directory_only_iterator& operator++() { this->DI::operator++(); return find_first(); } }; - -template // DI = directory_iterator from std, boost, or nana : value_type directory_entry -class regular_file_only_iterator : public DI +inline directory_only_iterator begin(directory_only_iterator iter) noexcept { - DI& find_first() + return iter; +} + +inline directory_only_iterator end(const directory_only_iterator&) noexcept +{ + return{}; +} + + +//template // DI = directory_iterator from std, boost, or nana : value_type directory_entry +class regular_file_only_iterator : public std::experimental::filesystem::directory_iterator +{ + using DI = std::experimental::filesystem::directory_iterator; + regular_file_only_iterator& find_first() { - while(( (*this) != DI{}) || !is_regular_file((*this)->status()) ) + while(( (*this) != DI{}) && !is_regular_file((**this).status())) this->DI::operator++(); return (*this); } @@ -71,6 +89,7 @@ public: { find_first(); } + regular_file_only_iterator() : DI() {} regular_file_only_iterator& operator++() { this->DI::operator++(); @@ -78,5 +97,15 @@ public: } }; - }}}} +inline regular_file_only_iterator begin(regular_file_only_iterator iter) noexcept +{ + return iter; +} + +inline regular_file_only_iterator end(const regular_file_only_iterator&) noexcept +{ + return{}; +} + +}}}} #endif //NANA_FILESYSTEM_EXT_HPP From 11f216434f28d15fa933ebf14d1d7f8575376a57 Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Fri, 19 Feb 2016 13:59:51 +0100 Subject: [PATCH 5/8] better integration of the nana filesystem extensions and possible force to use it --- include/nana/filesystem/filesystem_ext.hpp | 2 ++ include/nana/filesystem/filesystem_selector.hpp | 4 ++-- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/include/nana/filesystem/filesystem_ext.hpp b/include/nana/filesystem/filesystem_ext.hpp index 7e33ae9e..289bab0a 100644 --- a/include/nana/filesystem/filesystem_ext.hpp +++ b/include/nana/filesystem/filesystem_ext.hpp @@ -15,6 +15,8 @@ #ifndef NANA_FILESYSTEM_EXT_HPP #define NANA_FILESYSTEM_EXT_HPP +#include + namespace nana {namespace experimental {namespace filesystem {namespace ext { #if defined(NANA_WINDOWS) constexpr auto def_root = "C:"; diff --git a/include/nana/filesystem/filesystem_selector.hpp b/include/nana/filesystem/filesystem_selector.hpp index b168ce30..af4cf298 100644 --- a/include/nana/filesystem/filesystem_selector.hpp +++ b/include/nana/filesystem/filesystem_selector.hpp @@ -28,7 +28,7 @@ #include -#if defined(NANA_BOOST_FILESYSTEM_AVAILABLE) && ( defined(NANA_BOOST_FILESYSTEM_FORCE) || (defined(STD_FILESYSTEM_NOT_SUPPORTED) && defined(NANA_BOOST_FILESYSTEM_PREFERRED) ) ) +#if (!defined(NANA_FILESYSTEM_FORCE) && defined(NANA_BOOST_FILESYSTEM_AVAILABLE) && ( defined(NANA_BOOST_FILESYSTEM_FORCE) || (defined(STD_FILESYSTEM_NOT_SUPPORTED) && defined(NANA_BOOST_FILESYSTEM_PREFERRED) ) )) # include @@ -48,7 +48,7 @@ namespace std { } // std -#elif defined(STD_FILESYSTEM_NOT_SUPPORTED) +#elif (defined(NANA_FILESYSTEM_FORCE) || defined(STD_FILESYSTEM_NOT_SUPPORTED)) # include From 83bb669ff106b70fcd2c297a4f66cdfd624be1dd Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Fri, 19 Feb 2016 14:03:28 +0100 Subject: [PATCH 6/8] test travis with dev_dir_it, check in master ! before pushing back into master check what branch in nana-demo correspond --- .travis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 02ceda02..6e840779 100644 --- a/.travis.yml +++ b/.travis.yml @@ -55,7 +55,7 @@ matrix: - llvm-toolchain-precise before_install: - - git clone --depth=50 --branch=master https://github.com/qPCR4vir/nana-demo.git nana-demo + - git clone --depth=50 --branch=dev_dir_it https://github.com/qPCR4vir/nana-demo.git nana-demo - export PATH="$HOME/bin:$PATH" - mkdir ~/bin - wget --no-check-certificate --no-clobber -O /tmp/tools/cmake https://cmake.org/files/v3.4/cmake-3.4.0-rc3-Linux-x86_64.sh || true From 2e8b9264bfde0838f5c9b32153656b80c9f855ff Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Fri, 19 Feb 2016 14:16:34 +0100 Subject: [PATCH 7/8] fix compiler error noexeption --- source/filesystem/filesystem.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/source/filesystem/filesystem.cpp b/source/filesystem/filesystem.cpp index fc68a885..63795147 100644 --- a/source/filesystem/filesystem.cpp +++ b/source/filesystem/filesystem.cpp @@ -59,12 +59,12 @@ namespace nana { namespace experimental { namespace filesystem path2_(path2) {} - const path& filesystem_error::path1() const + const path& filesystem_error::path1() const noexcept { return path1_; } - const path&filesystem_error::path2() const + const path& filesystem_error::path2() const noexcept { return path2_; } From 6d383d288d516a55bf81074167f1e6bdf036da3e Mon Sep 17 00:00:00 2001 From: qPCR4vir Date: Fri, 19 Feb 2016 14:26:30 +0100 Subject: [PATCH 8/8] fix return local end --- include/nana/filesystem/filesystem_ext.hpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/include/nana/filesystem/filesystem_ext.hpp b/include/nana/filesystem/filesystem_ext.hpp index 289bab0a..3c911b2b 100644 --- a/include/nana/filesystem/filesystem_ext.hpp +++ b/include/nana/filesystem/filesystem_ext.hpp @@ -49,7 +49,7 @@ class directory_only_iterator : public std::experimental::filesystem::directory_ return *this; this->DI::operator++(); } - return end; + return *this; } public: template