summaryrefslogtreecommitdiff
path: root/src/lib
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2013-02-02 14:27:54 +0000
committerCarl Hetherington <cth@carlh.net>2013-02-02 14:27:54 +0000
commit98bbaf1e907e927dbd26131cbdef243a82fdc2d1 (patch)
treeb5863c26d3368c44269755f7af9f5e4b7b117ea7 /src/lib
parent8b4aa224882d2451f81c0a3ad07ec2d4ea098d5a (diff)
Only offer filters and postproc that exist.
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/filter.cc68
-rw-r--r--src/lib/filter.h1
-rw-r--r--src/lib/filter_graph.cc2
-rw-r--r--src/lib/util.cc2
4 files changed, 47 insertions, 26 deletions
diff --git a/src/lib/filter.cc b/src/lib/filter.cc
index 446cc111d..c23882726 100644
--- a/src/lib/filter.cc
+++ b/src/lib/filter.cc
@@ -22,6 +22,10 @@
*/
#include "filter.h"
+extern "C" {
+#include <libavfilter/avfilter.h>
+#include <libpostproc/postprocess.h>
+}
using namespace std;
@@ -57,30 +61,46 @@ Filter::setup_filters ()
{
/* Note: "none" is a magic id name, so don't use it here */
- _filters.push_back (new Filter ("pphb", "Horizontal deblocking filter", "", "hb"));
- _filters.push_back (new Filter ("ppvb", "Vertical deblocking filter", "", "vb"));
- _filters.push_back (new Filter ("ppha", "Horizontal deblocking filter A", "", "ha"));
- _filters.push_back (new Filter ("ppva", "Vertical deblocking filter A", "", "va"));
- _filters.push_back (new Filter ("pph1", "Experimental horizontal deblocking filter 1", "", "h1"));
- _filters.push_back (new Filter ("pphv", "Experimental vertical deblocking filter 1", "", "v1"));
- _filters.push_back (new Filter ("ppdr", "Deringing filter", "", "dr"));
- _filters.push_back (new Filter ("pplb", "Linear blend deinterlacer", "", "lb"));
- _filters.push_back (new Filter ("ppli", "Linear interpolating deinterlacer", "", "li"));
- _filters.push_back (new Filter ("ppci", "Cubic interpolating deinterlacer", "", "ci"));
- _filters.push_back (new Filter ("ppmd", "Median deinterlacer", "", "md"));
- _filters.push_back (new Filter ("ppfd", "FFMPEG deinterlacer", "", "fd"));
- _filters.push_back (new Filter ("ppl5", "FIR low-pass deinterlacer", "", "l5"));
- _filters.push_back (new Filter ("mcdeint", "Motion compensating deinterlacer", "mcdeint", ""));
- _filters.push_back (new Filter ("kerndeint", "Kernel deinterlacer", "kerndeint", ""));
- _filters.push_back (new Filter ("yadif", "Yet Another Deinterlacing Filter", "yadif", ""));
- _filters.push_back (new Filter ("pptn", "Temporal noise reducer", "", "tn"));
- _filters.push_back (new Filter ("ppfq", "Force quantizer", "", "fq"));
- _filters.push_back (new Filter ("gradfun", "Gradient debander", "gradfun", ""));
- _filters.push_back (new Filter ("unsharp", "Unsharp mask and Gaussian blur", "unsharp", ""));
- _filters.push_back (new Filter ("denoise3d", "3D denoiser", "denoise3d", ""));
- _filters.push_back (new Filter ("hqdn3d", "High quality 3D denoiser", "hqdn3d", ""));
- _filters.push_back (new Filter ("telecine", "Telecine filter", "telecine", ""));
- _filters.push_back (new Filter ("ow", "Overcomplete wavelet denoiser", "mp=ow", ""));
+ maybe_add ("pphb", "Horizontal deblocking filter", "", "hb");
+ maybe_add ("ppvb", "Vertical deblocking filter", "", "vb");
+ maybe_add ("ppha", "Horizontal deblocking filter A", "", "ha");
+ maybe_add ("ppva", "Vertical deblocking filter A", "", "va");
+ maybe_add ("pph1", "Experimental horizontal deblocking filter 1", "", "h1");
+ maybe_add ("pphv", "Experimental vertical deblocking filter 1", "", "v1");
+ maybe_add ("ppdr", "Deringing filter", "", "dr");
+ maybe_add ("pplb", "Linear blend deinterlacer", "", "lb");
+ maybe_add ("ppli", "Linear interpolating deinterlacer", "", "li");
+ maybe_add ("ppci", "Cubic interpolating deinterlacer", "", "ci");
+ maybe_add ("ppmd", "Median deinterlacer", "", "md");
+ maybe_add ("ppfd", "FFMPEG deinterlacer", "", "fd");
+ maybe_add ("ppl5", "FIR low-pass deinterlacer", "", "l5");
+ maybe_add ("mcdeint", "Motion compensating deinterlacer", "mcdeint", "");
+ maybe_add ("kerndeint", "Kernel deinterlacer", "kerndeint", "");
+ maybe_add ("yadif", "Yet Another Deinterlacing Filter", "yadif", "");
+ maybe_add ("pptn", "Temporal noise reducer", "", "tn");
+ maybe_add ("ppfq", "Force quantizer", "", "fq");
+ maybe_add ("gradfun", "Gradient debander", "gradfun", "");
+ maybe_add ("unsharp", "Unsharp mask and Gaussian blur", "unsharp", "");
+ maybe_add ("denoise3d", "3D denoiser", "denoise3d", "");
+ maybe_add ("hqdn3d", "High quality 3D denoiser", "hqdn3d", "");
+ maybe_add ("telecine", "Telecine filter", "telecine", "");
+ maybe_add ("ow", "Overcomplete wavelet denoiser", "mp=ow", "");
+}
+
+void
+Filter::maybe_add (string i, string n, string v, string p)
+{
+ if (!v.empty ()) {
+ if (avfilter_get_by_name (i.c_str())) {
+ _filters.push_back (new Filter (i, n, v, p));
+ }
+ } else if (!p.empty ()) {
+ pp_mode* m = pp_get_mode_by_name_and_quality (p.c_str(), PP_QUALITY_MAX);
+ if (m) {
+ _filters.push_back (new Filter (i, n, v, p));
+ pp_free_mode (m);
+ }
+ }
}
/** @param filters Set of filters.
diff --git a/src/lib/filter.h b/src/lib/filter.h
index 20c55049c..e7e8b389f 100644
--- a/src/lib/filter.h
+++ b/src/lib/filter.h
@@ -73,6 +73,7 @@ private:
/** all available filters */
static std::vector<Filter const *> _filters;
+ static void maybe_add (std::string, std::string, std::string, std::string);
};
#endif
diff --git a/src/lib/filter_graph.cc b/src/lib/filter_graph.cc
index 3a13d93d0..b0991a2da 100644
--- a/src/lib/filter_graph.cc
+++ b/src/lib/filter_graph.cc
@@ -68,8 +68,6 @@ FilterGraph::FilterGraph (shared_ptr<Film> film, FFmpegDecoder* decoder, libdcp:
filters += crop_string (Position (film->crop().left, film->crop().top), film->cropped_size (decoder->native_size()));
- avfilter_register_all ();
-
AVFilterGraph* graph = avfilter_graph_alloc();
if (graph == 0) {
throw DecodeError ("Could not create filter graph.");
diff --git a/src/lib/util.cc b/src/lib/util.cc
index 872985024..ce89d5355 100644
--- a/src/lib/util.cc
+++ b/src/lib/util.cc
@@ -233,6 +233,8 @@ seconds (struct timeval t)
void
dvdomatic_setup ()
{
+ avfilter_register_all ();
+
Format::setup_formats ();
DCPContentType::setup_dcp_content_types ();
Scaler::setup_scalers ();