X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fimage_filename_sorter.cc;fp=src%2Flib%2Fimage_filename_sorter.cc;h=037446398115b66e665acd4dccf2bb299897907a;hp=5a3e1dcecf6ce11297ba7c94c00945393d4d7377;hb=12e20e180062dbc338e775bd1f5ec7a2af91df7f;hpb=b0a4408ea45787a71592c63526ea5a8f2fe3f1fe diff --git a/src/lib/image_filename_sorter.cc b/src/lib/image_filename_sorter.cc index 5a3e1dcec..037446398 100644 --- a/src/lib/image_filename_sorter.cc +++ b/src/lib/image_filename_sorter.cc @@ -27,35 +27,49 @@ 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) { - return a.string() < b.string(); + 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; } - return na.get() < nb.get(); + /* NOT REACHED */ + return false; } private: - boost::optional extract_number (boost::filesystem::path p) + std::vector extract_numbers (boost::filesystem::path p) { p = p.leaf (); + std::vector numbers; 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; - } + } else if (!number.empty ()) { + numbers.push_back (raw_convert (number)); + number.clear (); } } - if (number.empty ()) { - return boost::optional (); + if (!number.empty ()) { + numbers.push_back (raw_convert (number)); } - return raw_convert (number); + return numbers; } };