Also use test frame decoding parameters when creating a test renderer

This commit is contained in:
Cameron Gutman 2023-09-14 18:21:53 -05:00
parent 1dd6cdb567
commit 1df0da4d4a
2 changed files with 3 additions and 2 deletions

View file

@ -138,6 +138,7 @@ public:
return true; return true;
} }
// NOTE: This can be called BEFORE initialize()!
virtual bool needsTestFrame() { virtual bool needsTestFrame() {
// No test frame required by default // No test frame required by default
return false; return false;

View file

@ -820,8 +820,8 @@ bool FFmpegVideoDecoder::tryInitializeRenderer(const AVCodec* decoder,
#endif #endif
SDL_assert(m_BackendRenderer == nullptr); SDL_assert(m_BackendRenderer == nullptr);
if ((m_BackendRenderer = createRendererFunc()) != nullptr && if ((m_BackendRenderer = createRendererFunc()) != nullptr &&
m_BackendRenderer->initialize(m_BackendRenderer->needsTestFrame() ? &testFrameDecoderParams : params) && m_BackendRenderer->initialize((m_TestOnly || m_BackendRenderer->needsTestFrame()) ? &testFrameDecoderParams : params) &&
completeInitialization(decoder, m_BackendRenderer->needsTestFrame() ? &testFrameDecoderParams : params, m_TestOnly || m_BackendRenderer->needsTestFrame(), i == 0 /* EGL/DRM */)) { completeInitialization(decoder, (m_TestOnly || m_BackendRenderer->needsTestFrame()) ? &testFrameDecoderParams : params, m_TestOnly || m_BackendRenderer->needsTestFrame(), i == 0 /* EGL/DRM */)) {
if (m_TestOnly) { if (m_TestOnly) {
// This decoder is only for testing capabilities, so don't bother // This decoder is only for testing capabilities, so don't bother
// creating a usable renderer // creating a usable renderer