Constness changes
[melted] / mlt++ / src / MltProducer.cpp
index 31ace14..4302243 100644 (file)
 
 #include "MltProducer.h"
 #include "MltFilter.h"
+#include "MltProfile.h"
 using namespace Mlt;
 
 Producer::Producer( ) :
-       instance( NULL )
+       instance( NULL ),
+       parent_( NULL )
 {
 }
 
-Producer::Producer( char *id, char *service ) :
-       instance( NULL )
+Producer::Producer( Profile& profile, const char *id, const char *service ) :
+       instance( NULL ),
+       parent_( NULL )
 {
        if ( id != NULL && service != NULL )
-               instance = mlt_factory_producer( id, service );
+               instance = mlt_factory_producer( profile.get_profile(), id, service );
        else
-               instance = mlt_factory_producer( "fezzik", id != NULL ? id : service );
+               instance = mlt_factory_producer( profile.get_profile(), "fezzik", id != NULL ? id : 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,20 +53,33 @@ 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( ) )
+       Mlt::Service( producer ),
+       instance( producer.get_producer( ) ),
+       parent_( NULL )
 {
        inc_ref( );
 }
 
+Producer::Producer( Producer *producer ) :
+       instance( producer != NULL ? producer->get_producer( ) : NULL ),
+       parent_( NULL )
+{
+       if ( is_valid( ) )
+               inc_ref( );
+}
+
 Producer::~Producer( )
 {
+       delete parent_;
        mlt_producer_close( instance );
+       instance = NULL;
 }
 
 mlt_producer Producer::get_producer( )
@@ -75,6 +92,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( ) );
@@ -145,7 +169,12 @@ Producer *Producer::cut( int in, int out )
 
 bool Producer::is_cut( )
 {
-       return mlt_producer_is_cut( get_producer( ) );
+       return mlt_producer_is_cut( get_producer( ) ) != 0;
+}
+
+bool Producer::is_blank( )
+{
+       return mlt_producer_is_blank( get_producer( ) ) != 0;
 }
 
 bool Producer::same_clip( Producer &that )
@@ -157,3 +186,8 @@ bool Producer::runs_into( Producer &that )
 {
        return same_clip( that ) && get_out( ) == ( that.get_in( ) - 1 );
 }
+
+void Producer::optimise( )
+{
+       mlt_producer_optimise( get_producer( ) );
+}