2 * mlt.i - Swig Bindings for mlt++
3 * Copyright (C) 2004-2005 Charles Yates
4 * Author: Charles Yates <charles.yates@pandora.be>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU Lesser General Public License as published
8 * by the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software Foundation,
18 * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
23 %array_class(unsigned char, unsignedCharArray);
26 #include <mlt++/Mlt.h>
27 int mlt_log_get_level( void );
28 void mlt_log_set_level( int );
31 /** These methods return objects which should be gc'd.
35 %newobject Factory::init( const char * );
36 %newobject Factory::producer( Profile &, char *, char * );
37 %newobject Factory::filter( Profile &, char *, char * );
38 %newobject Factory::transition( Profile &, char *, char * );
39 %newobject Factory::consumer( Profile &, char *, char * );
40 %newobject Properties::listen( const char *, void *, mlt_listener );
41 %newobject Properties::setup_wait_for( const char * );
42 %newobject Properties::parse_yaml( const char * );
43 %newobject Service::producer( );
44 %newobject Service::consumer( );
45 %newobject Service::get_frame( int );
46 %newobject Service::filter( int );
47 %newobject Producer::filter( int );
48 %newobject Producer::cut( int, int );
49 %newobject Playlist::current( );
50 %newobject Playlist::clip_info( int );
51 %newobject Playlist::get_clip( int );
52 %newobject Multitrack::track( int );
53 %newobject Tractor::multitrack( );
54 %newobject Tractor::field( );
55 %newobject Tractor::track( int );
56 %newobject Frame::get_original_producer( );
57 %newobject Repository::consumers( );
58 %newobject Repository::filters( );
59 %newobject Repository::producers( );
60 %newobject Repository::transitions( );
61 %newobject Repository::metadata( mlt_service_type, const char * );
62 %newobject Repository::languages( );
63 %newobject Profile::list();
69 %include <framework/mlt_types.h>
70 %include <framework/mlt_factory.h>
71 %include <framework/mlt_version.h>
72 int mlt_log_get_level( void );
73 void mlt_log_set_level( int );
74 %include <MltFactory.h>
75 %include <MltRepository.h>
77 %include <MltProperties.h>
79 %include <MltGeometry.h>
80 %include <MltService.h>
81 %include <MltProducer.h>
82 %include <MltProfile.h>
83 %include <MltPlaylist.h>
84 %include <MltConsumer.h>
85 %include <MltFilter.h>
86 %include <MltTransition.h>
87 %include <MltMultitrack.h>
89 %include <MltTractor.h>
90 %include <MltParser.h>
91 %include <MltFilteredConsumer.h>
97 static void ruby_listener( mlt_properties owner, void *object );
106 RubyListener( Mlt::Properties &properties, char *id, VALUE callback ) :
109 event = properties.listen( id, this, ( mlt_listener )ruby_listener );
119 ((void (*)(VALUE))(rb_gc_mark))( callback );
124 ID method = rb_intern( "call" );
125 rb_funcall( callback, method, 0 );
129 static void ruby_listener( mlt_properties owner, void *object )
131 RubyListener *o = static_cast< RubyListener * >( object );
135 void markRubyListener( void* p )
137 RubyListener *o = static_cast<RubyListener*>( p );
144 %rename( Listener ) RubyListener;
145 %markfunc RubyListener "markRubyListener";
150 RubyListener( Mlt::Properties &properties, char *id, VALUE callback );
155 #if defined(SWIGPYTHON)
162 binary_data frame_get_waveform( Mlt::Frame &frame, int w, int h )
164 binary_data result = {
166 (char*) frame.get_waveform( w, h )
173 %typemap(out) binary_data {
174 $result = PyString_FromStringAndSize( $1.data, $1.size );
177 binary_data frame_get_waveform(Mlt::Frame&, int, int);