X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=mlt%2B%2B%2Fsrc%2FMltService.cpp;h=88751ab54f325dfc9e0c8247463ab3a18d809d31;hb=55757b000043f6e370b9e963ce2e3542962c03c0;hp=61034b8efa0265445831fd55517cfe4b05a49183;hpb=b61d43804b15c0ddf8a3579cdcd2146105d9be26;p=melted diff --git a/mlt++/src/MltService.cpp b/mlt++/src/MltService.cpp index 61034b8..88751ab 100644 --- a/mlt++/src/MltService.cpp +++ b/mlt++/src/MltService.cpp @@ -18,22 +18,35 @@ * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ +#include #include "MltService.h" +#include "MltFilter.h" +#include "MltProfile.h" using namespace Mlt; Service::Service( ) : + Properties( false ), instance( NULL ) { } Service::Service( Service &service ) : + Properties( false ), instance( service.get_service( ) ) { + inc_ref( ); } Service::Service( mlt_service service ) : + Properties( false ), instance( service ) { + inc_ref( ); +} + +Service::~Service( ) +{ + mlt_service_close( instance ); } mlt_service Service::get_service( ) @@ -46,6 +59,16 @@ mlt_properties Service::get_properties( ) return mlt_service_properties( get_service( ) ); } +void Service::lock( ) +{ + mlt_service_lock( get_service( ) ); +} + +void Service::unlock( ) +{ + mlt_service_unlock( get_service( ) ); +} + int Service::connect_producer( Service &producer, int index ) { return mlt_service_connect_producer( get_service( ), producer.get_service( ), index ); @@ -61,10 +84,38 @@ Service *Service::consumer( ) return new Service( mlt_service_consumer( get_service( ) ) ); } +Profile *Service::profile( ) +{ + return new Profile( mlt_service_profile( get_service() ) ); +} + Frame *Service::get_frame( int index ) { mlt_frame frame = NULL; mlt_service_get_frame( get_service( ), &frame, index ); - return new Frame( frame ); + Frame *result = new Frame( frame ); + mlt_frame_close( frame ); + return result; +} + +mlt_service_type Service::type( ) +{ + return mlt_service_identify( get_service( ) ); +} + +int Service::attach( Filter &filter ) +{ + return mlt_service_attach( get_service( ), filter.get_filter( ) ); +} + +int Service::detach( Filter &filter ) +{ + return mlt_service_detach( get_service( ), filter.get_filter( ) ); +} + +Filter *Service::filter( int index ) +{ + mlt_filter result = mlt_service_filter( get_service( ), index ); + return result == NULL ? NULL : new Filter( result ); }