X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=mlt%2B%2B%2Fsrc%2FMltService.cpp;h=88751ab54f325dfc9e0c8247463ab3a18d809d31;hb=30da6add4dfaeea81255d3d141a18e61f9a4a978;hp=3ffbb2de00851e81a25812da1d146dc3692c5f89;hpb=0caa0a91b0971439dfe00d0ed9bc05992b7dd609;p=melted diff --git a/mlt++/src/MltService.cpp b/mlt++/src/MltService.cpp index 3ffbb2d..88751ab 100644 --- a/mlt++/src/MltService.cpp +++ b/mlt++/src/MltService.cpp @@ -20,6 +20,8 @@ #include #include "MltService.h" +#include "MltFilter.h" +#include "MltProfile.h" using namespace Mlt; Service::Service( ) : @@ -57,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 ); @@ -72,43 +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 ); -} - -service_type Service::type( ) -{ - service_type type = invalid_type; - if ( is_valid( ) ) - { - char *mlt_type = get( "mlt_type" ); - char *resource = get( "resource" ); - if ( mlt_type == NULL ) - type = unknown_type; - else if ( !strcmp( mlt_type, "producer" ) ) - type = producer_type; - else if ( !strcmp( mlt_type, "mlt_producer" ) ) - { - if ( resource == NULL ) - type = producer_type; - else if ( !strcmp( resource, "" ) ) - type = playlist_type; - else if ( !strcmp( resource, "" ) ) - type = tractor_type; - else if ( !strcmp( resource, "" ) ) - type = multitrack_type; - } - else if ( !strcmp( mlt_type, "filter" ) ) - type = filter_type; - else if ( !strcmp( mlt_type, "transition" ) ) - type = transition_type; - else if ( !strcmp( mlt_type, "consumer" ) ) - type = consumer_type; - else - type = unknown_type; - } - return type; + 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 ); +} +