std::shared_ptr<void> parallel_yadif_ctx_;\r
std::vector<PixelFormat> pix_fmts_;\r
std::queue<std::shared_ptr<AVFrame>> bypass_;\r
- int in_format_;\r
- bool warned_;\r
\r
implementation(const std::wstring& filters, const std::vector<PixelFormat>& pix_fmts) \r
: filters_(narrow(filters))\r
, parallel_yadif_ctx_(nullptr)\r
, pix_fmts_(pix_fmts)\r
- , in_format_(0)\r
- , warned_(false)\r
{\r
if(pix_fmts_.empty())\r
{\r
{\r
try\r
{\r
- in_format_ = frame->format;\r
graph_.reset(avfilter_graph_alloc(), [](AVFilterGraph* p){avfilter_graph_free(&p);});\r
\r
// Input\r
frame->key_frame = picref->video->key_frame;\r
frame->pict_type = picref->video->pict_type;\r
frame->sample_aspect_ratio = picref->video->sample_aspect_ratio;\r
-\r
- // HACK: Workaround for missing format bug in libavfilter.\r
- if(frame->format == 0)\r
- {\r
- if(in_format_ == PIX_FMT_YUV444P10)\r
- frame->format = PIX_FMT_YUV420P;//PIX_FMT_YUV444P;\r
- else if(in_format_ == PIX_FMT_YUV422P10)\r
- frame->format = PIX_FMT_YUV420P;//PIX_FMT_YUV422P;\r
- else\r
- BOOST_THROW_EXCEPTION(invalid_operation() << msg_info("libavfilter bug: frame format == 0."));\r
- \r
- if(!warned_)\r
- {\r
- CASPAR_LOG(warning) << "[ffmpeg] libavfilter bug workaround: frame format == 0, guessing PIX_FMT_YUV420P.";\r
- warned_ = true;\r
- }\r
- }\r
-\r
+ \r
return frame;\r
}\r
}\r