You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
mltpp/src/MltProperties.cpp

262 lines
5.9 KiB

/**
* MltProperties.cpp - MLT Wrapper
* Copyright (C) 2004-2005 Charles Yates
* Author: Charles Yates <charles.yates@pandora.be>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published
* by the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#include "MltProperties.h"
#include "MltEvent.h"
using namespace Mlt;
Properties::Properties( ) :
instance( NULL )
{
instance = mlt_properties_new( );
}
Properties::Properties( bool dummy ) :
instance( NULL )
{
}
Properties::Properties( Properties &properties ) :
instance( properties.get_properties( ) )
{
inc_ref( );
}
Properties::Properties( mlt_properties properties ) :
instance( properties )
{
inc_ref( );
}
Properties::Properties( const char *file ) :
instance( NULL )
{
instance = mlt_properties_load( file );
}
Properties::~Properties( )
{
mlt_properties_close( instance );
}
mlt_properties Properties::get_properties( )
{
return instance;
}
int Properties::inc_ref( )
{
return mlt_properties_inc_ref( get_properties( ) );
}
int Properties::dec_ref( )
{
return mlt_properties_dec_ref( get_properties( ) );
}
int Properties::ref_count( )
{
return mlt_properties_ref_count( get_properties( ) );
}
void Properties::block( void *object )
{
mlt_events_block( get_properties( ), object != NULL ? object : get_properties( ) );
}
void Properties::unblock( void *object )
{
mlt_events_unblock( get_properties( ), object != NULL ? object : get_properties( ) );
}
void Properties::fire_event( const char *event )
{
mlt_events_fire( get_properties( ), ( char * )event, NULL );
}
bool Properties::is_valid( )
{
return get_properties( ) != NULL;
}
int Properties::count( )
{
return mlt_properties_count( get_properties( ) );
}
char *Properties::get( const char *name )
{
return mlt_properties_get( get_properties( ), name );
}
int Properties::get_int( const char *name )
{
return mlt_properties_get_int( get_properties( ), name );
}
double Properties::get_double( const char *name )
{
return mlt_properties_get_double( get_properties( ), name );
}
void *Properties::get_data( const char *name, int &size )
{
return mlt_properties_get_data( get_properties( ), name, &size );
}
void *Properties::get_data( const char *name )
{
return mlt_properties_get_data( get_properties( ), name, NULL );
}
int Properties::set( const char *name, const char *value )
{
return mlt_properties_set( get_properties( ), name, value );
}
int Properties::set( const char *name, int value )
{
return mlt_properties_set_int( get_properties( ), name, value );
}
int Properties::set( const char *name, double value )
{
return mlt_properties_set_double( get_properties( ), name, value );
}
int Properties::set( const char *name, void *value, int size, mlt_destructor destructor, mlt_serialiser serialiser )
{
return mlt_properties_set_data( get_properties( ), name, value, size, destructor, serialiser );
}
int Properties::pass_values( Properties &that, const char *prefix )
{
return mlt_properties_pass( get_properties( ), that.get_properties( ), prefix );
}
int Properties::parse( const char *namevalue )
{
return mlt_properties_parse( get_properties( ), namevalue );
}
char *Properties::get_name( int index )
{
return mlt_properties_get_name( get_properties( ), index );
}
char *Properties::get( int index )
{
return mlt_properties_get_value( get_properties( ), index );
}
void *Properties::get_data( int index, int &size )
{
return mlt_properties_get_data_at( get_properties( ), index, &size );
}
void Properties::mirror( Properties &that )
{
mlt_properties_mirror( get_properties( ), that.get_properties( ) );
}
int Properties::inherit( Properties &that )
{
return mlt_properties_inherit( get_properties( ), that.get_properties( ) );
}
int Properties::rename( const char *source, const char *dest )
{
return mlt_properties_rename( get_properties( ), source, dest );
}
void Properties::dump( FILE *output )
{
mlt_properties_dump( get_properties( ), output );
}
void Properties::debug( const char *title, FILE *output )
{
mlt_properties_debug( get_properties( ), title, output );
}
void Properties::load( const char *file )
{
mlt_properties properties = mlt_properties_load( file );
if ( properties != NULL )
mlt_properties_pass( get_properties( ), properties, "" );
mlt_properties_close( properties );
}
int Properties::save( const char *file )
{
#ifdef WIN32
return mlt_properties_save( get_properties( ), file );
#else
int error = 0;
FILE *f = fopen( file, "w" );
if ( f != NULL )
{
dump( f );
fclose( f );
}
else
{
error = 1;
}
return error;
#endif
}
#if defined( __DARWIN__ ) && GCC_VERSION < 40000
Event *Properties::listen( char *id, void *object, void (*listener)( ... ) )
{
mlt_event event = mlt_events_listen( get_properties( ), object, id, ( mlt_listener )listener );
return new Event( event );
}
#else
Event *Properties::listen( char *id, void *object, mlt_listener listener )
{
mlt_event event = mlt_events_listen( get_properties( ), object, id, listener );
return new Event( event );
}
#endif
Event *Properties::setup_wait_for( char *id )
{
return new Event( mlt_events_setup_wait_for( get_properties( ), id ) );
}
void Properties::delete_event( Event *event )
{
delete event;
}
void Properties::wait_for( Event *event, bool destroy )
{
mlt_events_wait_for( get_properties( ), event->get_event( ) );
if ( destroy )
mlt_events_close_wait_for( get_properties( ), event->get_event( ) );
}