X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=src%2Fframework%2Fmlt_repository.c;h=4241331a369fda4fa8d6b87a325de20c1001e8c2;hb=bf3264b9e340ba5c11cbf59835a8af3db94e0cc2;hp=cdda3db33407042f10972e62f51065b389691382;hpb=51de85d7a61e44bde5395629af348d9ca96ee13b;p=melted diff --git a/src/framework/mlt_repository.c b/src/framework/mlt_repository.c index cdda3db..4241331 100644 --- a/src/framework/mlt_repository.c +++ b/src/framework/mlt_repository.c @@ -3,19 +3,19 @@ * Copyright (C) 2003-2004 Ushodaya Enterprises Limited * Author: Charles Yates * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. + * This library 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.1 of the License, or (at your option) any later version. * - * This program is distributed in the hope that it will be useful, + * This library 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. + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include "mlt_repository.h" @@ -31,7 +31,7 @@ struct mlt_repository_s struct mlt_properties_s parent; }; -static char *construct_full_file( char *output, char *prefix, char *file ) +static char *construct_full_file( char *output, const char *prefix, const char *file ) { strcpy( output, prefix ); if ( prefix[ strlen( prefix ) - 1 ] != '/' ) @@ -47,7 +47,7 @@ static char *chomp( char *input ) return input; } -static mlt_properties construct_object( char *prefix, char *id ) +static mlt_properties construct_object( const char *prefix, const char *id ) { mlt_properties output = mlt_properties_new( ); mlt_properties_set( output, "prefix", prefix ); @@ -55,7 +55,7 @@ static mlt_properties construct_object( char *prefix, char *id ) return output; } -static mlt_properties construct_service( mlt_properties object, char *id ) +static mlt_properties construct_service( mlt_properties object, const char *id ) { mlt_properties output = mlt_properties_new( ); mlt_properties_set_data( output, "object", object, 0, NULL, NULL ); @@ -63,7 +63,7 @@ static mlt_properties construct_service( mlt_properties object, char *id ) return output; } -static void *construct_instance( mlt_properties service_properties, char *symbol, void *input ) +static void *construct_instance( mlt_properties service_properties, const char *symbol, void *input ) { // Extract the service char *service = mlt_properties_get( service_properties, "id" ); @@ -75,7 +75,7 @@ static void *construct_instance( mlt_properties service_properties, char *symbol void *object = mlt_properties_get_data( object_properties, "dlopen", NULL ); // Get the dlsym'd symbol - void *( *symbol_ptr )( char *, void * ) = mlt_properties_get_data( object_properties, symbol, NULL ); + void *( *symbol_ptr )( const char *, void * ) = mlt_properties_get_data( object_properties, symbol, NULL ); // Check that we have object and open if we don't if ( object == NULL ) @@ -85,12 +85,18 @@ static void *construct_instance( mlt_properties service_properties, char *symbol // Get the prefix and id of the shared object char *prefix = mlt_properties_get( object_properties, "prefix" ); char *file = mlt_properties_get( object_properties, "id" ); + int flags = RTLD_NOW; + + // Very temporary hack to allow the quicktime plugins to work + // TODO: extend repository to allow this to be used on a case by case basis + if ( !strcmp( service, "kino" ) ) + flags |= RTLD_GLOBAL; // Construct the full file construct_full_file( full_file, prefix, file ); // Open the shared object - object = dlopen( full_file, RTLD_NOW ); + object = dlopen( full_file, flags ); if ( object != NULL ) { // Set it on the properties @@ -116,7 +122,7 @@ static void *construct_instance( mlt_properties service_properties, char *symbol return symbol_ptr != NULL ? symbol_ptr( service, input ) : NULL; } -mlt_repository mlt_repository_init( mlt_properties object_list, char *prefix, char *data, char *symbol ) +mlt_repository mlt_repository_init( mlt_properties object_list, const char *prefix, const char *data, const char *symbol ) { char full_file[ 512 ]; FILE *file; @@ -176,7 +182,7 @@ mlt_repository mlt_repository_init( mlt_properties object_list, char *prefix, ch return this; } -void *mlt_repository_fetch( mlt_repository this, char *service, void *input ) +void *mlt_repository_fetch( mlt_repository this, const char *service, void *input ) { // Get the service properties mlt_properties service_properties = mlt_properties_get_data( &this->parent, service, NULL );