--- /dev/null
+#include "mlt_producer.h"
+#include "mlt_consumer.h"
+#include "mlt_filter.h"
+#include "mlt_tractor.h"
+#include "mlt_transition.h"
+#include "mlt_multitrack.h"
+
+#include "producer_libdv.h"
+#include "producer_ppm.h"
+#include "filter_deinterlace.h"
+#include "filter_greyscale.h"
+#include "consumer_sdl.h"
+
+#include <stdio.h>
+
+int main( int argc, char **argv )
+{
+ char temp[ 132 ];
+ char *file1 = NULL;
+ char *file2 = NULL;
+
+ // Start the consumer...
+ mlt_consumer sdl_out = consumer_sdl_init( NULL );
+
+ fprintf( stderr, "Press return to continue\n" );
+ fgets( temp, 132, stdin );
+
+ if ( argc >= 2 )
+ file1 = argv[ 1 ];
+ if ( argc >= 3 )
+ file2 = argv[ 2 ];
+
+ // Create the producer(s)
+ //mlt_producer dv1 = producer_ppm_init( NULL );
+ //mlt_producer dv2 = producer_ppm_init( NULL );
+ mlt_producer dv1 = producer_libdv_init( file1 );
+ mlt_producer dv2 = producer_libdv_init( file2 );
+
+ mlt_consumer_connect( sdl_out, mlt_producer_service( dv1 ) );
+
+ fprintf( stderr, "Press return to continue\n" );
+ fgets( temp, 132, stdin );
+
+ // Register producers(s) with a multitrack object
+ mlt_multitrack multitrack = mlt_multitrack_init( );
+ mlt_multitrack_connect( multitrack, dv1, 0 );
+ mlt_multitrack_connect( multitrack, dv2, 1 );
+
+ // Create a filter and associate it to track 0
+ mlt_filter filter = filter_deinterlace_init( NULL );
+ mlt_filter_connect( filter, mlt_multitrack_service( multitrack ), 0 );
+ mlt_filter_set_in_and_out( filter, 0, 5 );
+
+ // Create another
+ mlt_filter greyscale = filter_greyscale_init( NULL );
+ mlt_filter_connect( greyscale, mlt_filter_service( filter ), 0 );
+ mlt_filter_set_in_and_out( greyscale, 0, 10 );
+
+ // Buy a tractor and connect it to the filter
+ mlt_tractor tractor = mlt_tractor_init( );
+ mlt_tractor_connect( tractor, mlt_filter_service( greyscale ) );
+
+ // Connect the tractor to the consumer
+ mlt_consumer_connect( sdl_out, mlt_tractor_service( tractor ) );
+
+ // Do stuff until we're told otherwise...
+ fprintf( stderr, "Press return to continue\n" );
+ fgets( temp, 132, stdin );
+
+ // Close everything...
+ mlt_consumer_close( sdl_out );
+ mlt_tractor_close( tractor );
+ mlt_filter_close( filter );
+ mlt_multitrack_close( multitrack );
+ mlt_producer_close( dv1 );
+ mlt_producer_close( dv2 );
+
+ return 0;
+}