From d71cadd49158dde3fbb1eab5ee41943c288b45d0 Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Wed, 28 Oct 2015 11:29:55 +0000 Subject: More tweaks to image filename ordering. --- src/lib/image_filename_sorter.cc | 44 +++++++++++++++++++++++++--------------- 1 file changed, 28 insertions(+), 16 deletions(-) (limited to 'src/lib') diff --git a/src/lib/image_filename_sorter.cc b/src/lib/image_filename_sorter.cc index 69114b2bd..143daed71 100644 --- a/src/lib/image_filename_sorter.cc +++ b/src/lib/image_filename_sorter.cc @@ -20,6 +20,7 @@ #include #include #include +#include #include "raw_convert.h" class ImageFilenameSorter @@ -27,20 +28,37 @@ class ImageFilenameSorter 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) { + 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(); + } + + 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; } private: - boost::optional extract_number (boost::filesystem::path p) + std::list extract_numbers (boost::filesystem::path p) { p = p.leaf (); - + std::list numbers; std::string current; @@ -59,17 +77,11 @@ private: numbers.push_back (current); } - std::string longest; - for (std::list::const_iterator i = numbers.begin(); i != numbers.end(); ++i) { - if (i->length() > longest.length()) { - longest = *i; - } - } - - if (longest.empty ()) { - return boost::optional (); + std::list numbers_as_int; + BOOST_FOREACH (std::string i, numbers) { + numbers_as_int.push_back (raw_convert (i)); } - return raw_convert (longest); + return numbers_as_int; } }; -- cgit v1.2.3