]> git.sesse.net Git - kdenlive/blobdiff - src/renderer.cpp
Fix some more threading crashes, almost there :)
[kdenlive] / src / renderer.cpp
index c9c23e29c8688d7bd8a3fd76050bd82d7431f1bb..be627e3bb6de8b4045a6885d48c3ac6644762d9f 100644 (file)
@@ -977,13 +977,14 @@ int Render::setProducer(Mlt::Producer *producer, int position)
     QString currentId;
     int consumerPosition = 0;
     if (m_winid == -1) return -1;
+    if (m_mltProducer) m_mltProducer->set_speed(0);
     if (m_mltConsumer) {
+        m_mltConsumer->set("refresh", 0);
+        m_mltConsumer->purge();
         consumerPosition = m_mltConsumer->position();
         if (!m_mltConsumer->is_stopped()) {
             m_mltConsumer->stop();
-            m_mltConsumer->purge();
         }
-        m_mltConsumer->set("refresh", 0);
     }
     else {
         return -1;
@@ -991,7 +992,6 @@ int Render::setProducer(Mlt::Producer *producer, int position)
 
     if (m_mltProducer) {
         currentId = m_mltProducer->get("id");
-        m_mltProducer->set_speed(0);
         delete m_mltProducer;
         m_mltProducer = NULL;
         emit stopped();