1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-26 04:26:38 +00:00

fix crash when video file doesn't exist

This commit is contained in:
scrawl 2012-12-14 01:44:00 +01:00
parent 27cd9ff732
commit 82564e07c7

View file

@ -776,13 +776,14 @@ public:
} }
void init_state(VideoState *is, const std::string& resourceName) void init_state(VideoState *is, const std::string& resourceName)
{
try
{ {
int video_index = -1; int video_index = -1;
int audio_index = -1; int audio_index = -1;
unsigned int i; unsigned int i;
is->av_sync_type = DEFAULT_AV_SYNC_TYPE; is->av_sync_type = DEFAULT_AV_SYNC_TYPE;
is->format_ctx = avformat_alloc_context();
is->videoStream = -1; is->videoStream = -1;
is->audioStream = -1; is->audioStream = -1;
is->refresh = 0; is->refresh = 0;
@ -792,14 +793,23 @@ public:
if(is->stream.isNull()) if(is->stream.isNull())
throw std::runtime_error("Failed to open video resource"); throw std::runtime_error("Failed to open video resource");
is->format_ctx = avformat_alloc_context();
is->format_ctx->pb = avio_alloc_context(NULL, 0, 0, is, OgreResource_Read, OgreResource_Write, OgreResource_Seek); is->format_ctx->pb = avio_alloc_context(NULL, 0, 0, is, OgreResource_Read, OgreResource_Write, OgreResource_Seek);
if(!is->format_ctx->pb) if(!is->format_ctx->pb)
{
avformat_free_context(is->format_ctx);
throw std::runtime_error("Failed to allocate ioContext "); throw std::runtime_error("Failed to allocate ioContext ");
}
// Open video file // Open video file
/// \todo leak here, ffmpeg or valgrind bug ? /// \todo leak here, ffmpeg or valgrind bug ?
if (avformat_open_input(&is->format_ctx, resourceName.c_str(), NULL, NULL)) if (avformat_open_input(&is->format_ctx, resourceName.c_str(), NULL, NULL))
{
// "Note that a user-supplied AVFormatContext will be freed on failure."
is->format_ctx = NULL;
throw std::runtime_error("Failed to open video input"); throw std::runtime_error("Failed to open video input");
}
// Retrieve stream information // Retrieve stream information
if(avformat_find_stream_info(is->format_ctx, NULL) < 0) if(avformat_find_stream_info(is->format_ctx, NULL) < 0)
@ -821,6 +831,17 @@ public:
if(video_index >= 0) if(video_index >= 0)
stream_component_open(is, video_index, is->format_ctx); stream_component_open(is, video_index, is->format_ctx);
} }
catch (std::runtime_error& e)
{
is->quit = 1;
throw;
}
catch (Ogre::Exception& e)
{
is->quit = 1;
throw;
}
}
void deinit_state(VideoState *is) void deinit_state(VideoState *is)
{ {
@ -835,12 +856,16 @@ public:
if(is->videoStream >= 0) if(is->videoStream >= 0)
avcodec_close(is->video_st->codec); avcodec_close(is->video_st->codec);
if (is->sws_context)
sws_freeContext(is->sws_context); sws_freeContext(is->sws_context);
if (is->format_ctx)
{
AVIOContext *ioContext = is->format_ctx->pb; AVIOContext *ioContext = is->format_ctx->pb;
avformat_close_input(&is->format_ctx); avformat_close_input(&is->format_ctx);
av_free(ioContext); av_free(ioContext);
} }
}
VideoPlayer::VideoPlayer(Ogre::SceneManager* sceneMgr) VideoPlayer::VideoPlayer(Ogre::SceneManager* sceneMgr)
: mState(NULL) : mState(NULL)