From 854facc49eda9f7e561e73a5722296bb1ad5734a Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Fri, 17 Jul 2015 11:27:28 +0100 Subject: [PATCH] Use the V1.x image filename sorting method. --- src/lib/image_filename_sorter.cc | 62 ++++++++++++++++---------------- 1 file changed, 31 insertions(+), 31 deletions(-) diff --git a/src/lib/image_filename_sorter.cc b/src/lib/image_filename_sorter.cc index 037446398..69114b2bd 100644 --- a/src/lib/image_filename_sorter.cc +++ b/src/lib/image_filename_sorter.cc @@ -17,59 +17,59 @@ */ -#include "raw_convert.h" +#include #include #include -#include +#include "raw_convert.h" class ImageFilenameSorter { public: bool operator() (boost::filesystem::path a, boost::filesystem::path b) { - std::vector na = extract_numbers (a); - std::vector nb = extract_numbers (b); - - std::vector::const_iterator i = na.begin (); - std::vector::const_iterator j = nb.begin (); - - while (true) { - if (i == na.end () || j == nb.end ()) { - return false; - } - - if (*i != *j) { - return *i < *j; - } - - ++i; - ++j; + boost::optional na = extract_number (a); + boost::optional nb = extract_number (b); + if (!na || !nb) { + return a.string() < b.string(); } - /* NOT REACHED */ - return false; + return na.get() < nb.get(); } private: - std::vector extract_numbers (boost::filesystem::path p) + boost::optional extract_number (boost::filesystem::path p) { p = p.leaf (); + + std::list numbers; - std::vector numbers; - std::string number; + std::string current; for (size_t i = 0; i < p.string().size(); ++i) { if (isdigit (p.string()[i])) { - number += p.string()[i]; - } else if (!number.empty ()) { - numbers.push_back (raw_convert (number)); - number.clear (); + current += p.string()[i]; + } else { + if (!current.empty ()) { + numbers.push_back (current); + current.clear (); + } + } + } + + if (!current.empty ()) { + 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 (!number.empty ()) { - numbers.push_back (raw_convert (number)); + if (longest.empty ()) { + return boost::optional (); } - return numbers; + return raw_convert (longest); } }; -- 2.30.2