2 * @file ElementsKernel/_impl/PathSearch.tpp
3 * @brief implementation of the templates declared in ElementsKernel/Path.h
5 * @author Hubert Degaudenzi
8 * @copyright 2012-2020 Euclid Science Ground Segment
10 * This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General
11 * Public License as published by the Free Software Foundation; either version 3.0 of the License, or (at your option)
14 * This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied
15 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
18 * You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to
19 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 #ifndef ELEMENTSKERNEL_ELEMENTSKERNEL_PATHSEARCH_IMPL_
23 #error "This file should not be included directly! Use ElementsKernel/Path.h instead"
29 #include <boost/filesystem/operations.hpp>
31 #include "ElementsKernel/Path.h"
34 inline namespace Kernel {
35 //-----------------------------------------------------------------------------
37 template <typename T, typename ITER>
38 std::vector<T> pathSearch(const std::string& searched_name, T directory) {
40 // create the resulting vector
41 std::vector<T> searchResults{};
42 // make sure directory is ps::path, changing from string to path if T is string.
43 Path::Item l_directory{directory};
44 // the default constructor of ITER return a pointer to one-past last element
46 if (boost::filesystem::is_directory(l_directory)) {
47 // ITER constructor return a pointer to the first element of l_directory
48 for (ITER dir_iter(l_directory); dir_iter != end_iter; ++dir_iter) {
49 if (dir_iter->path().filename() == searched_name) {
50 // File found: make sure the result is T: string to string or string to
51 // boost::filesystem::path
52 T l_result{dir_iter->path().string()};
53 searchResults.emplace_back(l_result);
61 std::vector<T> searchOption(std::string searched_name, T directory, SearchType search_type) {
63 // create a local tmp vector result to avoid multiple return statements
64 std::vector<T> searchResults{};
65 switch (search_type) {
66 case SearchType::Local:
67 searchResults = pathSearch<T, boost::filesystem::directory_iterator>(searched_name, directory);
69 case SearchType::Recursive:
70 searchResults = pathSearch<T, boost::filesystem::recursive_directory_iterator>(searched_name, directory);
77 std::vector<T> pathSearch(const std::string& searched_name, T directory, SearchType search_type) {
78 return searchOption<T>(searched_name, directory, search_type);
82 } // namespace Elements
84 #endif // ELEMENTSKERNEL_ELEMENTSKERNEL_PATHSEARCH_IMPL_