From f48bc596944b57b4d1ac1f9996e8e51059f29927 Mon Sep 17 00:00:00 2001 From: Thomas Goyne Date: Fri, 4 Nov 2011 05:11:31 +0000 Subject: [PATCH] Add locks around CSRI operations as VSFilter isn't even vaguely threadsafe Originally committed to SVN as r5810. --- aegisub/src/subtitles_provider_csri.cpp | 28 +++++++++++-------------- 1 file changed, 12 insertions(+), 16 deletions(-) diff --git a/aegisub/src/subtitles_provider_csri.cpp b/aegisub/src/subtitles_provider_csri.cpp index a0b55c734..9210dfb57 100644 --- a/aegisub/src/subtitles_provider_csri.cpp +++ b/aegisub/src/subtitles_provider_csri.cpp @@ -38,28 +38,29 @@ #ifdef WITH_CSRI -#include "ass_file.h" +#ifndef AGI_PRE +#include +#endif + #include "subtitles_provider_csri.h" + +#include "ass_file.h" #include "text_file_writer.h" #include "video_context.h" #include "video_frame.h" -/// @brief Constructor -/// @param type -/// +static wxMutex csri_mutex; + CSRISubtitlesProvider::CSRISubtitlesProvider(std::string type) : subType(type) { } -/// @brief Destructor -/// CSRISubtitlesProvider::~CSRISubtitlesProvider() { if (!tempfile.empty()) wxRemoveFile(tempfile); } -/// @brief Load subtitles -/// @param subs -/// void CSRISubtitlesProvider::LoadSubtitles(AssFile *subs) { + wxMutexLocker lock(csri_mutex); + // CSRI variables csri_rend *cur,*renderer=NULL; @@ -101,15 +102,12 @@ void CSRISubtitlesProvider::LoadSubtitles(AssFile *subs) { } } -/// @brief Draw subtitles -/// @param dst -/// @param time -/// @return -/// void CSRISubtitlesProvider::DrawSubtitles(AegiVideoFrame &dst,double time) { // Check if CSRI loaded properly if (!instance.get()) return; + wxMutexLocker lock(csri_mutex); + // Load data into frame csri_frame frame; if (dst.flipped) { @@ -134,8 +132,6 @@ void CSRISubtitlesProvider::DrawSubtitles(AegiVideoFrame &dst,double time) { csri_render(instance.get(),&frame,time); } -/// @brief Get CSRI subtypes -/// std::vector CSRISubtitlesProvider::GetSubTypes() { std::vector final; for (csri_rend *cur = csri_renderer_default();cur;cur = csri_renderer_next(cur)) {