X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Flibvlc-common.c;h=15e789e59359205d4f671832eac88e455f4c99cb;hb=be50cf5ba79d4e1203b87d9b32e7b921d1bc4854;hp=2c03b2ccaf42210a4c8fd37e1094e544999b5fed;hpb=2eeecb47c846664e466677e9a592091e841290e4;p=vlc diff --git a/src/libvlc-common.c b/src/libvlc-common.c index 2c03b2ccaf..15e789e593 100644 --- a/src/libvlc-common.c +++ b/src/libvlc-common.c @@ -94,7 +94,7 @@ * The evil global variable. We handle it with care, don't worry. *****************************************************************************/ static libvlc_global_data_t libvlc_global; -static libvlc_global_data_t * p_libvlc_global = NULL; +#define p_libvlc_global (&libvlc_global) static libvlc_int_t * p_static_vlc = NULL; static volatile unsigned int i_instances = 0; @@ -122,8 +122,10 @@ static int VerboseCallback( vlc_object_t *, char const *, static void InitDeviceValues( libvlc_int_t * ); -/* Refs misc/cpu.c */ -uint32_t CPUCapabilities( void ); +libvlc_global_data_t *vlc_global( void ) +{ + return &libvlc_global; +} /***************************************************************************** * vlc_current_object: return the current object. @@ -153,9 +155,11 @@ libvlc_int_t * libvlc_InternalCreate( void ) vlc_value_t lockval; char *psz_env = NULL; +#if 0 /* &libvlc_global never changes, * so we can safely call this multiple times. */ p_libvlc_global = &libvlc_global; +#endif /* vlc_threads_init *must* be the first internal call! No other call is * allowed before the thread system has been initialized. */ @@ -173,7 +177,7 @@ libvlc_int_t * libvlc_InternalCreate( void ) if( !libvlc_global.b_ready ) { /* Guess what CPU we have */ - libvlc_global.i_cpu = CPUCapabilities(); + cpu_flags = CPUCapabilities(); /* The module bank will be initialized later */ libvlc_global.p_module_bank = NULL; @@ -189,7 +193,6 @@ libvlc_int_t * libvlc_InternalCreate( void ) i_instances--; return NULL; } - p_libvlc->thread_id = 0; p_libvlc->p_playlist = NULL; p_libvlc->psz_object_name = "libvlc"; @@ -287,7 +290,7 @@ int libvlc_InternalInit( libvlc_int_t *p_libvlc, int i_argc, char *ppsz_argv[] ) module_InitBank( p_libvlc ); /* Hack: insert the help module here */ - p_help_module = vlc_object_create( p_libvlc, VLC_OBJECT_MODULE ); + p_help_module = vlc_module_create( VLC_OBJECT(p_libvlc) ); if( p_help_module == NULL ) { module_EndBank( p_libvlc ); @@ -369,7 +372,7 @@ int libvlc_InternalInit( libvlc_int_t *p_libvlc, int i_argc, char *ppsz_argv[] ) msg_Err( p_libvlc, "Unable to fork vlc to daemon mode" ); b_exit = VLC_TRUE; } - p_libvlc->p_libvlc_global->b_daemon = VLC_TRUE; + libvlc_global.b_daemon = VLC_TRUE; /* lets check if we need to write the pidfile */ psz_pidfile = config_GetPsz( p_libvlc, "pidfile" ); @@ -416,7 +419,7 @@ int libvlc_InternalInit( libvlc_int_t *p_libvlc, int i_argc, char *ppsz_argv[] ) close( STDOUT_FILENO ); close( STDERR_FILENO ); - p_libvlc->p_libvlc_global->b_daemon = VLC_TRUE; + libvlc_global.b_daemon = VLC_TRUE; } #endif } @@ -606,13 +609,13 @@ int libvlc_InternalInit( libvlc_int_t *p_libvlc, int i_argc, char *ppsz_argv[] ) } else { - /* check if a Media Player is available + /* check if VLC is available on the bus * if not: D-Bus control is not enabled on the other * instance and we can't pass MRLs to it */ DBusMessage *p_test_msg = NULL; DBusMessage *p_test_reply = NULL; p_test_msg = dbus_message_new_method_call( - "org.freedesktop.MediaPlayer", "/", + "org.mpris.vlc", "/", "org.freedesktop.MediaPlayer", "Identity" ); /* block until a reply arrives */ p_test_reply = dbus_connection_send_with_reply_and_block( @@ -641,7 +644,7 @@ int libvlc_InternalInit( libvlc_int_t *p_libvlc, int i_argc, char *ppsz_argv[] ) ppsz_argv[i_input] ); p_dbus_msg = dbus_message_new_method_call( - "org.freedesktop.MediaPlayer", "/TrackList", + "org.mpris.vlc", "/TrackList", "org.freedesktop.MediaPlayer", "AddTrack" ); if ( NULL == p_dbus_msg ) @@ -728,27 +731,27 @@ int libvlc_InternalInit( libvlc_int_t *p_libvlc, int i_argc, char *ppsz_argv[] ) msg_Flush( p_libvlc ); if( !config_GetInt( p_libvlc, "fpu" ) ) - libvlc_global.i_cpu &= ~CPU_CAPABILITY_FPU; + cpu_flags &= ~CPU_CAPABILITY_FPU; #if defined( __i386__ ) || defined( __x86_64__ ) if( !config_GetInt( p_libvlc, "mmx" ) ) - libvlc_global.i_cpu &= ~CPU_CAPABILITY_MMX; + cpu_flags &= ~CPU_CAPABILITY_MMX; if( !config_GetInt( p_libvlc, "3dn" ) ) - libvlc_global.i_cpu &= ~CPU_CAPABILITY_3DNOW; + cpu_flags &= ~CPU_CAPABILITY_3DNOW; if( !config_GetInt( p_libvlc, "mmxext" ) ) - libvlc_global.i_cpu &= ~CPU_CAPABILITY_MMXEXT; + cpu_flags &= ~CPU_CAPABILITY_MMXEXT; if( !config_GetInt( p_libvlc, "sse" ) ) - libvlc_global.i_cpu &= ~CPU_CAPABILITY_SSE; + cpu_flags &= ~CPU_CAPABILITY_SSE; if( !config_GetInt( p_libvlc, "sse2" ) ) - libvlc_global.i_cpu &= ~CPU_CAPABILITY_SSE2; + cpu_flags &= ~CPU_CAPABILITY_SSE2; #endif #if defined( __powerpc__ ) || defined( __ppc__ ) || defined( __ppc64__ ) if( !config_GetInt( p_libvlc, "altivec" ) ) - libvlc_global.i_cpu &= ~CPU_CAPABILITY_ALTIVEC; + cpu_flags &= ~CPU_CAPABILITY_ALTIVEC; #endif #define PRINT_CAPABILITY( capability, string ) \ - if( libvlc_global.i_cpu & capability ) \ + if( vlc_CPU() & capability ) \ { \ strncat( p_capabilities, string " ", \ sizeof(p_capabilities) - strlen(p_capabilities) ); \ @@ -906,6 +909,26 @@ int libvlc_InternalInit( libvlc_int_t *p_libvlc, int i_argc, char *ppsz_argv[] ) VLC_AddIntf( 0, "netsync,none", VLC_FALSE, VLC_FALSE ); } +#ifdef WIN32 + if( config_GetInt( p_libvlc, "prefer-system-codecs") == 1 ) + { + char *psz_codecs = config_GetPsz( p_playlist, "codec" ); + if( psz_codecs ) + { + char *psz_morecodecs; + asprintf(&psz_morecodecs, "%s,dmo,quicktime", psz_codecs); + if( psz_morecodecs ) + { + config_PutPsz( p_libvlc, "codec", psz_morecodecs); + free(psz_morecodecs); + } + } + else + config_PutPsz( p_libvlc, "codec", "dmo,quicktime"); + free(psz_codecs); + } +#endif + /* * FIXME: kludge to use a p_libvlc-local variable for the Mozilla plugin */ @@ -1019,7 +1042,7 @@ int libvlc_InternalDestroy( libvlc_int_t *p_libvlc, vlc_bool_t b_release ) #ifndef WIN32 char* psz_pidfile = NULL; - if( p_libvlc->p_libvlc_global->p_module_bank ) + if( libvlc_global.p_module_bank ) if( config_GetInt( p_libvlc, "daemon" ) ) { psz_pidfile = config_GetPsz( p_libvlc, "pidfile" ); @@ -1097,7 +1120,7 @@ int libvlc_InternalAddIntf( libvlc_int_t *p_libvlc, return VLC_EGENERIC; #ifndef WIN32 - if( p_libvlc->p_libvlc_global->b_daemon && b_block && !psz_module ) + if( libvlc_global.b_daemon && b_block && !psz_module ) { /* Daemon mode hack. * We prefer the dummy interface if none is specified. */ @@ -1357,15 +1380,13 @@ static void Usage( libvlc_int_t *p_this, char const *psz_module_name ) if( psz_module_name && strcmp( psz_module_name, p_parser->psz_object_name ) ) { - const char **pp_shortcut = p_parser->pp_shortcuts; + const char *const *pp_shortcut = p_parser->pp_shortcuts; while( *pp_shortcut ) { if( !strcmp( psz_module_name, *pp_shortcut ) ) break; pp_shortcut ++; } - if( !*pp_shortcut ) - continue; } /* Ignore modules without config options */ @@ -1751,7 +1772,7 @@ static void ListModules( libvlc_int_t *p_this, vlc_bool_t b_verbose ) if( b_verbose ) { const char **pp_shortcut = p_parser->pp_shortcuts; - while( pp_shortcut && *pp_shortcut ) + while( *pp_shortcut ) { if( strcmp( *pp_shortcut, p_parser->psz_object_name ) ) { @@ -1810,11 +1831,9 @@ static void Version( void ) utf8_fprintf( stdout, _("Compiled by %s@%s.%s\n"), VLC_CompileBy(), VLC_CompileHost(), VLC_CompileDomain() ); utf8_fprintf( stdout, _("Compiler: %s\n"), VLC_Compiler() ); -#ifndef HAVE_SHARED_LIBVLC if( strcmp( VLC_Changeset(), "exported" ) ) utf8_fprintf( stdout, _("Based upon svn changeset [%s]\n"), VLC_Changeset() ); -#endif utf8_fprintf( stdout, LICENSE_MSG ); #ifdef WIN32 /* Pause the console because it's destroyed when we exit */ @@ -1952,7 +1971,6 @@ static void InitDeviceValues( libvlc_int_t *p_vlc ) p_connection = dbus_bus_get ( DBUS_BUS_SYSTEM, &error ); if( dbus_error_is_set( &error ) || !p_connection ) { - libhal_ctx_shutdown( ctx, NULL ); dbus_error_free( &error ); return; }