diff --git a/src/engine/gstenginepipeline.cpp b/src/engine/gstenginepipeline.cpp index e6291878d9..bdcd75285d 100644 --- a/src/engine/gstenginepipeline.cpp +++ b/src/engine/gstenginepipeline.cpp @@ -404,7 +404,7 @@ bool GstEnginePipeline::Finish() { Disconnect(); - if (state() == GST_STATE_NULL) { + if (IsStateNull()) { finished_ = true; } else { @@ -1784,6 +1784,19 @@ qint64 GstEnginePipeline::position() const { } +bool GstEnginePipeline::IsStateNull() const { + + if (!pipeline_) return true; + + GstState s = GST_STATE_NULL, sp = GST_STATE_NULL; + if (gst_element_get_state(pipeline_, &s, &sp, kGstStateTimeoutNanosecs) == GST_STATE_CHANGE_FAILURE) { + return false; + } + + return s == GST_STATE_NULL; + +} + QFuture GstEnginePipeline::SetStateAsync(const GstState state) { qLog(Debug) << "Setting pipeline" << id() << "state to" << GstStateText(state); diff --git a/src/engine/gstenginepipeline.h b/src/engine/gstenginepipeline.h index 4e255f38b4..a91c04fe42 100644 --- a/src/engine/gstenginepipeline.h +++ b/src/engine/gstenginepipeline.h @@ -162,6 +162,7 @@ class GstEnginePipeline : public QObject { private: static QString GstStateText(const GstState state); GstElement *CreateElement(const QString &factory_name, const QString &name, GstElement *bin, QString &error) const; + bool IsStateNull() const; bool InitAudioBin(QString &error); void SetupVolume(GstElement *element);