Add blur and wave filters from Leny Grisel
[melted] / src / modules / core / factory.c
index 650cca8..09b5591 100644 (file)
 
 #include <string.h>
 
+#include "producer_colour.h"
+#include "producer_framebuffer.h"
+#include "producer_noise.h"
 #include "producer_ppm.h"
+#include "filter_boxblur.h"
 #include "filter_brightness.h"
-#include "filter_deinterlace.h"
+#include "filter_channelcopy.h"
+#include "filter_data.h"
 #include "filter_gamma.h"
 #include "filter_greyscale.h"
+#include "filter_luma.h"
+#include "filter_mirror.h"
+#include "filter_mono.h"
 #include "filter_obscure.h"
+#include "filter_rescale.h"
 #include "filter_resize.h"
-#include "filter_volume.h"
+#include "filter_region.h"
+#include "filter_transition.h"
 #include "filter_watermark.h"
+#include "filter_wave.h"
 #include "transition_composite.h"
 #include "transition_luma.h"
 #include "transition_mix.h"
+#include "transition_region.h"
+#include "consumer_null.h"
 
 void *mlt_create_producer( char *id, void *arg )
 {
+       if ( !strcmp( id, "color" ) )
+               return producer_colour_init( arg );
+       if ( !strcmp( id, "colour" ) )
+               return producer_colour_init( arg );
+       if ( !strcmp( id, "framebuffer" ) )
+               return producer_framebuffer_init( arg );
+       if ( !strcmp( id, "noise" ) )
+               return producer_noise_init( arg );
        if ( !strcmp( id, "ppm" ) )
                return producer_ppm_init( arg );
        return NULL;
@@ -42,22 +63,40 @@ void *mlt_create_producer( char *id, void *arg )
 
 void *mlt_create_filter( char *id, void *arg )
 {
+       if ( !strcmp( id, "boxblur" ) )
+               return filter_boxblur_init( arg );
        if ( !strcmp( id, "brightness" ) )
                return filter_brightness_init( arg );
-       if ( !strcmp( id, "deinterlace" ) )
-               return filter_deinterlace_init( arg );
+       if ( !strcmp( id, "channelcopy" ) )
+               return filter_channelcopy_init( arg );
+       if ( !strcmp( id, "data_feed" ) )
+               return filter_data_feed_init( arg );
+       if ( !strcmp( id, "data_show" ) )
+               return filter_data_show_init( arg );
        if ( !strcmp( id, "gamma" ) )
                return filter_gamma_init( arg );
        if ( !strcmp( id, "greyscale" ) )
                return filter_greyscale_init( arg );
+       if ( !strcmp( id, "luma" ) )
+               return filter_luma_init( arg );
+       if ( !strcmp( id, "mirror" ) )
+               return filter_mirror_init( arg );
+       if ( !strcmp( id, "mono" ) )
+               return filter_mono_init( arg );
        if ( !strcmp( id, "obscure" ) )
                return filter_obscure_init( arg );
+       if ( !strcmp( id, "region" ) )
+               return filter_region_init( arg );
+       if ( !strcmp( id, "rescale" ) )
+               return filter_rescale_init( arg );
        if ( !strcmp( id, "resize" ) )
                return filter_resize_init( arg );
-       if ( !strcmp( id, "volume" ) )
-               return filter_volume_init( arg );
+       else if ( !strcmp( id, "transition" ) )
+               return filter_transition_init( arg );
        if ( !strcmp( id, "watermark" ) )
                return filter_watermark_init( arg );
+       if ( !strcmp( id, "wave" ) )
+               return filter_wave_init( arg );
        return NULL;
 }
 
@@ -69,11 +108,14 @@ void *mlt_create_transition( char *id, void *arg )
                return transition_luma_init( arg );
        if ( !strcmp( id, "mix" ) )
                return transition_mix_init( arg );
+       if ( !strcmp( id, "region" ) )
+               return transition_region_init( arg );
        return NULL;
 }
 
 void *mlt_create_consumer( char *id, void *arg )
 {
+       if ( !strcmp( id, "null" ) )
+               return consumer_null_init( arg );
        return NULL;
 }
-