/* Copyright (C) 2017-2021 Carl Hetherington 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. 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 DCP-o-matic. If not, see . */ #include "dcpomatic_time.h" #include namespace dcpomatic { /** @param periods Set of periods in ascending order of from time */ template std::list> coalesce (std::list> periods) { bool did_something; std::list> coalesced; do { coalesced.clear (); did_something = false; for (auto i = periods.begin(); i != periods.end(); ++i) { auto j = i; ++j; if (j != periods.end() && (i->overlap(*j) || i->to == j->from)) { coalesced.push_back(TimePeriod(std::min(i->from, j->from), std::max(i->to, j->to))); did_something = true; ++i; } else { coalesced.push_back (*i); } } periods = coalesced; } while (did_something); return periods; } }