X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=mlt%2B%2B%2Fsrc%2FMltProducer.cpp;fp=mlt%2B%2B%2Fsrc%2FMltProducer.cpp;h=3a588195041eefe6fb399146cd79ae381e3b251e;hb=8433613ca206628beb6f5868d8eab73780fc1faa;hp=54473e7b7531f9e5061d1aa3447d2db65db84ef6;hpb=3723979ad22879a279252dea99bda209b480d57e;p=melted diff --git a/mlt++/src/MltProducer.cpp b/mlt++/src/MltProducer.cpp index 54473e7..3a58819 100644 --- a/mlt++/src/MltProducer.cpp +++ b/mlt++/src/MltProducer.cpp @@ -23,12 +23,14 @@ using namespace Mlt; Producer::Producer( ) : - instance( NULL ) + instance( NULL ), + parent_( NULL ) { } Producer::Producer( char *id, char *service ) : - instance( NULL ) + instance( NULL ), + parent_( NULL ) { if ( id != NULL && service != NULL ) instance = mlt_factory_producer( id, service ); @@ -37,7 +39,8 @@ Producer::Producer( char *id, char *service ) : } Producer::Producer( Service &producer ) : - instance( NULL ) + instance( NULL ), + parent_( NULL ) { mlt_service_type type = producer.type( ); if ( type == producer_type || type == playlist_type || @@ -49,19 +52,22 @@ Producer::Producer( Service &producer ) : } Producer::Producer( mlt_producer producer ) : - instance( producer ) + instance( producer ), + parent_( NULL ) { inc_ref( ); } Producer::Producer( Producer &producer ) : - instance( producer.get_producer( ) ) + instance( producer.get_producer( ) ), + parent_( NULL ) { inc_ref( ); } Producer::Producer( Producer *producer ) : - instance( producer != NULL ? producer->get_producer( ) : NULL ) + instance( producer != NULL ? producer->get_producer( ) : NULL ), + parent_( NULL ) { if ( is_valid( ) ) inc_ref( ); @@ -69,6 +75,7 @@ Producer::Producer( Producer *producer ) : Producer::~Producer( ) { + delete parent_; mlt_producer_close( instance ); instance = NULL; } @@ -83,6 +90,13 @@ mlt_producer Producer::get_parent( ) return get_producer( ) != NULL && mlt_producer_cut_parent( get_producer( ) ) != NULL ? mlt_producer_cut_parent( get_producer( ) ) : get_producer( ); } +Producer &Producer::parent( ) +{ + if ( is_cut( ) && parent_ == NULL ) + parent_ = new Producer( get_parent( ) ); + return parent_ == NULL ? *this : *parent_; +} + mlt_service Producer::get_service( ) { return mlt_producer_service( get_producer( ) );