* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
+#include <stdlib.h>
+#include <string.h>
#include "MltFilter.h"
+#include "MltProfile.h"
using namespace Mlt;
-mlt_service Filter::get_service( )
+Filter::Filter( Profile& profile, const char *id, const char *arg ) :
+ instance( NULL )
{
- return mlt_filter_service( get_filter( ) );
+ if ( arg != NULL )
+ {
+ instance = mlt_factory_filter( profile.get_profile(), id, arg );
+ }
+ else
+ {
+ if ( strchr( id, ':' ) )
+ {
+ char *temp = strdup( id );
+ char *arg = strchr( temp, ':' ) + 1;
+ *( arg - 1 ) = '\0';
+ instance = mlt_factory_filter( profile.get_profile(), temp, arg );
+ free( temp );
+ }
+ else
+ {
+ instance = mlt_factory_filter( profile.get_profile(), id, NULL );
+ }
+ }
}
-int Filter::connect( Service &service, int index )
+Filter::Filter( Service &filter ) :
+ instance( NULL )
{
- return mlt_filter_connect( get_filter( ), service.get_service( ), index );
+ if ( filter.type( ) == filter_type )
+ {
+ instance = ( mlt_filter )filter.get_service( );
+ inc_ref( );
+ }
}
-void Filter::set_in_and_out( mlt_position in, mlt_position out )
+Filter::Filter( Filter &filter ) :
+ Mlt::Service( filter ),
+ instance( filter.get_filter( ) )
{
- mlt_filter_set_in_and_out( get_filter( ), in, out );
+ inc_ref( );
}
-mlt_position Filter::get_in( )
+Filter::Filter( mlt_filter filter ) :
+ instance( filter )
{
- return mlt_filter_get_in( get_filter( ) );
+ inc_ref( );
}
-mlt_position Filter::get_out( )
+Filter::~Filter( )
{
- return mlt_filter_get_out( get_filter( ) );
+ mlt_filter_close( instance );
}
-int Filter::get_track( )
+mlt_filter Filter::get_filter( )
{
- return mlt_filter_get_track( get_filter( ) );
+ return instance;
+}
+
+mlt_service Filter::get_service( )
+{
+ return mlt_filter_service( get_filter( ) );
}
-mlt_filter FilterInstance::get_filter( )
+int Filter::connect( Service &service, int index )
{
- return instance;
+ return mlt_filter_connect( get_filter( ), service.get_service( ), index );
}
-FilterInstance::FilterInstance( char *id, char *service ) :
- destroy( true ),
- instance( NULL )
+void Filter::set_in_and_out( int in, int out )
{
- instance = mlt_factory_filter( id, service );
+ mlt_filter_set_in_and_out( get_filter( ), in, out );
}
-FilterInstance::FilterInstance( Filter &filter ) :
- destroy( false ),
- instance( filter.get_filter( ) )
+int Filter::get_in( )
{
+ return mlt_filter_get_in( get_filter( ) );
}
-FilterInstance::FilterInstance( mlt_filter filter ) :
- destroy( false ),
- instance( filter )
+int Filter::get_out( )
{
+ return mlt_filter_get_out( get_filter( ) );
}
-FilterInstance::~FilterInstance( )
+int Filter::get_track( )
{
- if ( destroy )
- mlt_filter_close( instance );
+ return mlt_filter_get_track( get_filter( ) );
}