diff options
| author | Carl Hetherington <cth@carlh.net> | 2023-11-08 00:59:42 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2023-11-20 07:34:23 +0100 |
| commit | 83a948956916abb7b2c13c25141323d326b38708 (patch) | |
| tree | 83bbeba8d94aa9c49dc248fdf54ff2a854f64d87 /src/lib/filter.cc | |
| parent | bb3a9a12116a4b2a5bc1fef38e73853f576a773a (diff) | |
Cleanup: handle Filter objects by value rather than by reference.
Diffstat (limited to 'src/lib/filter.cc')
| -rw-r--r-- | src/lib/filter.cc | 63 |
1 files changed, 45 insertions, 18 deletions
diff --git a/src/lib/filter.cc b/src/lib/filter.cc index 9158cba5c..7db329b00 100644 --- a/src/lib/filter.cc +++ b/src/lib/filter.cc @@ -24,6 +24,7 @@ */ +#include "dcpomatic_assert.h" #include "filter.h" #include <dcp/warnings.h> LIBDCP_DISABLE_WARNINGS @@ -31,11 +32,13 @@ extern "C" { #include <libavfilter/avfilter.h> } LIBDCP_ENABLE_WARNINGS +#include <algorithm> #include "i18n.h" using namespace std; +using boost::optional; vector<Filter> Filter::_filters; @@ -57,14 +60,10 @@ Filter::Filter (string i, string n, string c, string f) /** @return All available filters */ -vector<Filter const *> +vector<Filter> Filter::all () { - vector<Filter const *> raw; - for (auto& filter: _filters) { - raw.push_back (&filter); - } - return raw; + return _filters; } @@ -113,15 +112,15 @@ Filter::maybe_add (string i, string n, string c, string f) * @return String to pass to FFmpeg for the video filters. */ string -Filter::ffmpeg_string (vector<Filter const *> const & filters) +Filter::ffmpeg_string(vector<Filter> const& filters) { string ff; - for (auto const i: filters) { + for (auto const& i: filters) { if (!ff.empty ()) { ff += N_(","); } - ff += i->ffmpeg (); + ff += i.ffmpeg(); } return ff; @@ -129,19 +128,47 @@ Filter::ffmpeg_string (vector<Filter const *> const & filters) /** @param d Our id. - * @return Corresponding Filter, or 0. + * @return Corresponding Filter, if found. */ -Filter const * -Filter::from_id (string d) +optional<Filter> +Filter::from_id(string id) +{ + auto iter = std::find_if(_filters.begin(), _filters.end(), [id](Filter const& filter) { return filter.id() == id; }); + if (iter == _filters.end()) { + return {}; + } + return *iter; +} + + +bool +operator==(Filter const& a, Filter const& b) +{ + return a.id() == b.id() && a.name() == b.name() && a.category() == b.category() && a.ffmpeg() == b.ffmpeg(); +} + + +bool +operator!=(Filter const& a, Filter const& b) +{ + return a.id() != b.id() || a.name() != b.name() || a.category() != b.category() || a.ffmpeg() != b.ffmpeg(); +} + + +bool +operator<(Filter const& a, Filter const& b) { - auto i = _filters.begin (); - while (i != _filters.end() && i->id() != d) { - ++i; + if (a.id() != b.id()) { + return a.id() < b.id(); + } + + if (a.name() != b.name()) { + return a.name() < b.name(); } - if (i == _filters.end ()) { - return nullptr; + if (a.category() != b.category()) { + return a.category() < b.category(); } - return &(*i); + return a.ffmpeg() < b.ffmpeg(); } |
