2 * MltService.cpp - MLT Wrapper
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.
22 #include "MltService.h"
23 #include "MltFilter.h"
32 Service
::Service( Service
&service
) :
34 instance( service
.get_service( ) )
39 Service
::Service( mlt_service service
) :
48 mlt_service_close( instance
);
51 mlt_service Service
::get_service( )
56 mlt_properties Service
::get_properties( )
58 return mlt_service_properties( get_service( ) );
63 mlt_service_lock( get_service( ) );
66 void Service
::unlock( )
68 mlt_service_unlock( get_service( ) );
71 int Service
::connect_producer( Service
&producer
, int index
)
73 return mlt_service_connect_producer( get_service( ), producer
.get_service( ), index
);
76 Service
*Service
::producer( )
78 return new Service( mlt_service_producer( get_service( ) ) );
81 Service
*Service
::consumer( )
83 return new Service( mlt_service_consumer( get_service( ) ) );
86 Frame
*Service
::get_frame( int index
)
88 mlt_frame frame
= NULL
;
89 mlt_service_get_frame( get_service( ), &frame
, index
);
90 Frame
*result
= new Frame( frame
);
91 mlt_frame_close( frame
);
95 mlt_service_type Service
::type( )
97 return mlt_service_identify( get_service( ) );
100 int Service
::attach( Filter
&filter
)
102 return mlt_service_attach( get_service( ), filter
.get_filter( ) );
105 int Service
::detach( Filter
&filter
)
107 return mlt_service_detach( get_service( ), filter
.get_filter( ) );
110 Filter
*Service
::filter( int index
)
112 return new Filter( mlt_service_filter( get_service( ), index
) );