%{
#include <mlt++/Mlt.h>
+int mlt_log_get_level( void );
+void mlt_log_set_level( int );
%}
/** These methods return objects which should be gc'd.
%newobject Factory::filter( Profile &, char *, char * );
%newobject Factory::transition( Profile &, char *, char * );
%newobject Factory::consumer( Profile &, char *, char * );
-%newobject Properties::listen( char *, void *, mlt_listener );
+%newobject Properties::listen( const char *, void *, mlt_listener );
+%newobject Properties::setup_wait_for( const char * );
+%newobject Properties::parse_yaml( const char * );
%newobject Service::producer( );
%newobject Service::consumer( );
%newobject Service::get_frame( int );
%newobject Repository::producers( );
%newobject Repository::transitions( );
%newobject Repository::metadata( mlt_service_type, const char * );
+%newobject Repository::languages( );
+%newobject Profile::list();
+%newobject Repository::presets();
+
+#if defined(SWIGPYTHON)
+%feature("shadow") Frame::get_waveform(int, int) %{
+ def get_waveform(*args): return _mlt.frame_get_waveform(*args)
+%}
+%feature("shadow") Frame::get_image(mlt_image_format&, int&, int&) %{
+ def get_image(*args): return _mlt.frame_get_image(*args)
+%}
+#endif
+
}
/** Classes to wrap.
%include <framework/mlt_types.h>
%include <framework/mlt_factory.h>
+%include <framework/mlt_version.h>
+int mlt_log_get_level( void );
+void mlt_log_set_level( int );
%include <MltFactory.h>
%include <MltRepository.h>
%include <MltEvent.h>
%include <MltParser.h>
%include <MltFilteredConsumer.h>
+
+
#if defined(SWIGRUBY)
%{
class RubyListener
{
- private:
+ protected:
VALUE callback;
Mlt::Event *event;
public:
- RubyListener( Mlt::Properties &properties, char *id, VALUE callback ) :
+ RubyListener( VALUE callback ) : callback( callback )
+ {}
+
+ RubyListener( Mlt::Properties &properties, char *id, VALUE callback ) :
callback( callback )
{
event = properties.listen( id, this, ( mlt_listener )ruby_listener );
}
- ~RubyListener( )
+ virtual ~RubyListener( )
{
delete event;
}
- void mark( )
+ void mark( )
{
((void (*)(VALUE))(rb_gc_mark))( callback );
}
- void doit( )
+ void doit( )
{
ID method = rb_intern( "call" );
rb_funcall( callback, method, 0 );
o->mark( );
}
+static void on_playlist_next( mlt_properties owner, void *object, int i );
+
+class PlaylistNextListener : RubyListener
+{
+ private:
+ Mlt::Event *event;
+
+ public:
+ PlaylistNextListener( Mlt::Properties *properties, VALUE proc )
+ : RubyListener( proc )
+ {
+ event = properties->listen( "playlist-next", this, ( mlt_listener )on_playlist_next );
+ }
+
+ ~PlaylistNextListener()
+ {
+ delete event;
+ }
+
+ void yield( int i )
+ {
+ ID method = rb_intern( "call" );
+ rb_funcall( callback, method, 1, INT2FIX( i ) );
+ }
+};
+
+static void on_playlist_next( mlt_properties owner, void *object, int i )
+{
+ PlaylistNextListener *o = static_cast< PlaylistNextListener * >( object );
+ o->yield( i );
+}
+
%}
// Ruby wrapper
%rename( Listener ) RubyListener;
%markfunc RubyListener "markRubyListener";
+%markfunc PlaylistNextListener "markRubyListener";
-class RubyListener
+class RubyListener
{
public:
RubyListener( Mlt::Properties &properties, char *id, VALUE callback );
};
-#endif
+class PlaylistNextListener
+{
+ public:
+ PlaylistNextListener( Mlt::Properties *properties, VALUE proc );
+};
+
+#endif // SWIGGRUBY
+
+
+
+#if defined(SWIGPYTHON)
+%{
+typedef struct {
+ int size;
+ char* data;
+} binary_data;
+binary_data frame_get_waveform( Mlt::Frame &frame, int w, int h )
+{
+ binary_data result = {
+ w * h,
+ (char*) frame.get_waveform( w, h )
+ };
+ return result;
+}
+
+binary_data frame_get_image( Mlt::Frame &frame, mlt_image_format format, int w, int h )
+{
+ binary_data result = {
+ mlt_image_format_size( format, w, h, NULL ),
+ (char*) frame.get_image( format, w, h )
+ };
+ return result;
+}
+
+%}
+
+%typemap(out) binary_data {
+ $result = PyString_FromStringAndSize( $1.data, $1.size );
+}
+
+binary_data frame_get_waveform(Mlt::Frame&, int, int);
+binary_data frame_get_image(Mlt::Frame&, mlt_image_format, int, int);
+
+#endif