+ Whoops - had forgotten these OS/X patches...
[melted] / mlt++ / src / MltProperties.h
1 /**
2 * MltProperties.h - MLT Wrapper
3 * Copyright (C) 2004-2005 Charles Yates
4 * Author: Charles Yates <charles.yates@pandora.be>
5 *
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.
10 *
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.
15 *
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.
19 */
20
21 #ifndef _MLTPP_PROPERTIES_H_
22 #define _MLTPP_PROPERTIES_H_
23
24 #include <stdio.h>
25 #include <framework/mlt.h>
26
27 namespace Mlt
28 {
29 class Event;
30
31 /** Abstract Properties class.
32 */
33
34 class Properties
35 {
36 private:
37 mlt_properties instance;
38 protected:
39 virtual mlt_properties get_properties( );
40 public:
41 Properties( );
42 Properties( bool dummy );
43 Properties( Properties &properties );
44 Properties( mlt_properties properties );
45 Properties( const char *file );
46 virtual ~Properties( );
47 int inc_ref( );
48 int dec_ref( );
49 int ref_count( );
50 void block( void *object = NULL );
51 void unblock( void *object = NULL );
52 void fire_event( const char *event );
53 bool is_valid( );
54 int count( );
55 char *get( const char *name );
56 int get_int( const char *name );
57 double get_double( const char *name );
58 void *get_data( const char *name, int &size );
59 void *get_data( const char *name );
60 int set( const char *name, const char *value );
61 int set( const char *name, int value );
62 int set( const char *name, double value );
63 int set( const char *name, void *value, int size, mlt_destructor destroy = NULL, mlt_serialiser serial = NULL );
64 int pass_values( Properties &that, const char *prefix );
65 int parse( const char *namevalue );
66 char *get_name( int index );
67 char *get( int index );
68 void *get_data( int index, int &size );
69 void mirror( Properties &that );
70 int inherit( Properties &that );
71 int rename( const char *source, const char *dest );
72 void dump( FILE *output = stderr );
73 void debug( const char *title = "Object", FILE *output = stderr );
74 void load( const char *file );
75 int save( const char *file );
76 #ifdef __DARWIN__
77 Event *listen( char *id, void *object, void (*)(...) );
78 #else
79 Event *listen( char *id, void *object, mlt_listener );
80 #endif
81 Event *setup_wait_for( char *id );
82 void wait_for( Event *, bool destroy = true );
83 };
84 }
85
86 #endif