X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Flib%2Fimage_filename_sorter.cc;h=25a8acb3da5455af942c5774af88c0876c1fe3a5;hb=73654117144c6de0ec4efe39ddc88485df546cc9;hp=5a3e1dcecf6ce11297ba7c94c00945393d4d7377;hpb=e60bb3e51bd1508b149e6b8f6608f09b5196ae26;p=dcpomatic.git diff --git a/src/lib/image_filename_sorter.cc b/src/lib/image_filename_sorter.cc index 5a3e1dcec..25a8acb3d 100644 --- a/src/lib/image_filename_sorter.cc +++ b/src/lib/image_filename_sorter.cc @@ -1,61 +1,89 @@ /* - Copyright (C) 2015 Carl Hetherington + Copyright (C) 2015-2016 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ -#include "raw_convert.h" +#include "image_filename_sorter.h" +#include #include -#include +#include #include -class ImageFilenameSorter +using std::list; +using dcp::raw_convert; + +bool +ImageFilenameSorter::operator() (boost::filesystem::path a, boost::filesystem::path b) { -public: - bool operator() (boost::filesystem::path a, boost::filesystem::path b) - { - boost::optional na = extract_number (a); - boost::optional nb = extract_number (b); - if (!na || !nb) { - return a.string() < b.string(); - } + std::list na = extract_numbers (a); + std::list nb = extract_numbers (b); + if (na.empty() || nb.empty()) { + return a.string() < b.string(); + } - return na.get() < nb.get(); + if (na.size() != nb.size()) { + /* Just use the first one */ + return na.front() < nb.front(); } -private: - boost::optional extract_number (boost::filesystem::path p) - { - p = p.leaf (); - - std::string number; - for (size_t i = 0; i < p.string().size(); ++i) { - if (isdigit (p.string()[i])) { - number += p.string()[i]; - } else { - if (!number.empty ()) { - break; - } - } + std::list::const_iterator i = na.begin (); + std::list::const_iterator j = nb.begin (); + + while (i != na.end()) { + if (*i != *j) { + return *i < *j; } + ++i; + ++j; + } + + /* All the same */ + return false; + +} - if (number.empty ()) { - return boost::optional (); +list +ImageFilenameSorter::extract_numbers (boost::filesystem::path p) +{ + p = p.leaf (); + + std::list numbers; + + std::string current; + for (size_t i = 0; i < p.string().size(); ++i) { + if (isdigit (p.string()[i])) { + current += p.string()[i]; + } else { + if (!current.empty ()) { + numbers.push_back (current); + current.clear (); + } } + } + + if (!current.empty ()) { + numbers.push_back (current); + } - return raw_convert (number); + std::list numbers_as_int; + BOOST_FOREACH (std::string i, numbers) { + numbers_as_int.push_back (raw_convert (i)); } -}; + + return numbers_as_int; +}