summaryrefslogtreecommitdiff
path: root/src/lib/filter.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2023-11-08 00:59:42 +0100
committerCarl Hetherington <cth@carlh.net>2023-11-20 07:34:23 +0100
commit83a948956916abb7b2c13c25141323d326b38708 (patch)
tree83bbeba8d94aa9c49dc248fdf54ff2a854f64d87 /src/lib/filter.cc
parentbb3a9a12116a4b2a5bc1fef38e73853f576a773a (diff)
Cleanup: handle Filter objects by value rather than by reference.
Diffstat (limited to 'src/lib/filter.cc')
-rw-r--r--src/lib/filter.cc63
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();
}