From 1ca12fe0e8ddf29538d8c0462a337e99395db8d9 Mon Sep 17 00:00:00 2001 From: Jacek Antonelli Date: Sun, 8 Mar 2009 23:50:56 -0500 Subject: Load the proper gstreamer lib type (dylib) on Mac --- linden/indra/llmedia/llmediaimplgstreamer.cpp | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) (limited to 'linden/indra/llmedia/llmediaimplgstreamer.cpp') diff --git a/linden/indra/llmedia/llmediaimplgstreamer.cpp b/linden/indra/llmedia/llmediaimplgstreamer.cpp index 30706f1..cd6c91b 100644 --- a/linden/indra/llmedia/llmediaimplgstreamer.cpp +++ b/linden/indra/llmedia/llmediaimplgstreamer.cpp @@ -166,19 +166,26 @@ bool LLMediaImplGStreamer::startup (LLMediaManagerData* init_data) g_type_init(); // Get symbols! + if ( #if LL_WINDOWS - if (! grab_gst_syms("libgstreamer-0.10.dll", "libgstvideo-0.10.dll", "libgstaudio-0.10.dll") ) - { - LL_WARNS("MediaImpl") << "Couldn't find suitable GStreamer 0.10 support on this system - video playback disabled." << LL_ENDL; - return false; - } + ! grab_gst_syms("libgstreamer-0.10.dll", + "libgstvideo-0.10.dll", + "libgstaudio-0.10.dll") +#elif LL_DARWIN + ! grab_gst_syms("libgstreamer-0.10.dylib", + "libgstvideo-0.10.dylib", + "libgstaudio-0.10.dylib") #else - if (! grab_gst_syms("libgstreamer-0.10.so.0", "libgstvideo-0.10.so.0", "libgstaudio-0.10.so.0") ) + ! grab_gst_syms("libgstreamer-0.10.so.0", + "libgstvideo-0.10.so.0", + "libgstaudio-0.10.so.0") +#endif + ) { - LL_WARNS("MediaImpl") << "Couldn't find suitable GStreamer 0.10 support on this system - video playback disabled." << LL_ENDL; + LL_WARNS("MediaImpl") << "Couldn't find suitable GStreamer 0.10 support on this system - video playback disabled." << LL_ENDL; return false; } -#endif + if (llgst_segtrap_set_enabled) llgst_segtrap_set_enabled(FALSE); else -- cgit v1.1 From 26c2ddb4a16030d48a763325ff9c492c3618f39b Mon Sep 17 00:00:00 2001 From: Jacek Antonelli Date: Sun, 29 Mar 2009 22:24:30 -0500 Subject: Improved set_gst_plugin_path, now sets path on Mac too. --- linden/indra/llmedia/llmediaimplgstreamer.cpp | 103 +++++++++++++++++--------- 1 file changed, 67 insertions(+), 36 deletions(-) (limited to 'linden/indra/llmedia/llmediaimplgstreamer.cpp') diff --git a/linden/indra/llmedia/llmediaimplgstreamer.cpp b/linden/indra/llmedia/llmediaimplgstreamer.cpp index 9a51b7f..20b89f5 100644 --- a/linden/indra/llmedia/llmediaimplgstreamer.cpp +++ b/linden/indra/llmedia/llmediaimplgstreamer.cpp @@ -47,6 +47,10 @@ extern "C" { #include "llerror.h" #include "linden_common.h" +#if LL_DARWIN +#include // For CF functions used in set_gst_plugin_path +#endif + // register this impl with media manager factory static LLMediaImplRegister sLLMediaImplGStreamerReg( "LLMediaImplGStreamer", new LLMediaImplGStreamerMaker() ); @@ -203,55 +207,82 @@ bool LLMediaImplGStreamer::startup (LLMediaManagerData* init_data) void LLMediaImplGStreamer::set_gst_plugin_path() { - // Only needed for Windows. - // Linux sets in wrapper.sh, Mac sets in Info-Imprudence.plist -#ifdef LL_WINDOWS + // Linux sets GST_PLUGIN_PATH in wrapper.sh, not here. +#if LL_WINDOWS || LL_DARWIN - char* imp_cwd; + std::string imp_dir = ""; // Get the current working directory: - imp_cwd = _getcwd(NULL,0); - - if(imp_cwd == NULL) +#if LL_WINDOWS + char* raw_dir; + raw_dir = _getcwd(NULL,0); + if( raw_dir != NULL ) { - LL_DEBUGS("LLMediaImpl") << "_getcwd failed, not setting GST_PLUGIN_PATH." - << LL_ENDL; + imp_dir = std::string( raw_dir ); } - else +#elif LL_DARWIN + CFBundleRef main_bundle = CFBundleGetMainBundle(); + if( main_bundle != NULL ) { - LL_DEBUGS("LLMediaImpl") << "Imprudence is installed at " - << imp_cwd << LL_ENDL; - - // Grab the current path, if it's set. - std::string old_plugin_path = ""; - char *old_path = getenv("GST_PLUGIN_PATH"); - if(old_path == NULL) - { - LL_DEBUGS("LLMediaImpl") << "Did not find user-set GST_PLUGIN_PATH." - << LL_ENDL; - } - else + CFURLRef bundle_url = CFBundleCopyBundleURL( main_bundle ); + if( bundle_url != NULL ) { - old_plugin_path = std::string( old_path ) + ":"; + #ifndef MAXPATHLEN + #define MAXPATHLEN 1024 + #endif + char raw_dir[MAXPATHLEN]; + if( CFURLGetFileSystemRepresentation( bundle_url, true, (UInt8 *)raw_dir, MAXPATHLEN) ) + { + imp_dir = std::string( raw_dir ) + "/Contents/MacOS/"; + } + CFRelease(bundle_url); } + } +#endif + if( imp_dir == "" ) + { + LL_DEBUGS("MediaImpl") << "Could not get application directory, not setting GST_PLUGIN_PATH." + << LL_ENDL; + return; + } - // Search both Imprudence and Imprudence\lib\gstreamer-plugins. - // But we also want to first search the path the user has set, if any. - std::string plugin_path = - "GST_PLUGIN_PATH=" + - old_plugin_path + - std::string(imp_cwd) + ":" + - std::string(imp_cwd) + "\\lib\\gstreamer-plugins"; - - // Place GST_PLUGIN_PATH in the environment settings for imprudence.exe - putenv( (char*)plugin_path.c_str() ); + LL_DEBUGS("MediaImpl") << "Imprudence is installed at " + << imp_dir << LL_ENDL; - LL_DEBUGS("LLMediaImpl") << "GST_PLUGIN_PATH set to " - << getenv("GST_PLUGIN_PATH") << LL_ENDL; + // Grab the current path, if it's set. + std::string old_plugin_path = ""; + char *old_path = getenv("GST_PLUGIN_PATH"); + if(old_path == NULL) + { + LL_DEBUGS("MediaImpl") << "Did not find user-set GST_PLUGIN_PATH." + << LL_ENDL; + } + else + { + old_plugin_path = std::string( old_path ) + ":"; } -#endif //LL_WINDOWS + + // Search both Imprudence and Imprudence\lib\gstreamer-plugins. + // But we also want to first search the path the user has set, if any. + std::string plugin_path = + "GST_PLUGIN_PATH=" + + old_plugin_path + + imp_dir + ":" + +#if LL_WINDOWS + imp_dir + "\\lib\\gstreamer-plugins"; +#elif LL_DARWIN + imp_dir + "/../Resources/lib/gstreamer-plugins"; +#endif + + // Place GST_PLUGIN_PATH in the environment settings + putenv( (char*)plugin_path.c_str() ); + + LL_DEBUGS("MediaImpl") << "GST_PLUGIN_PATH set to " + << getenv("GST_PLUGIN_PATH") << LL_ENDL; + +#endif // LL_WINDOWS || LL_DARWIN } -- cgit v1.1 From b1412201b6e44c1a304acd70d9104d3a2034da52 Mon Sep 17 00:00:00 2001 From: Jacek Antonelli Date: Sun, 29 Mar 2009 22:28:41 -0500 Subject: set_gst_plugin_path now sets GST_PLUGIN_SYSTEM_PATH="". This prevents GStreamer from looking for system-installed plugins, which can have conflicts with our packaged ones. --- linden/indra/llmedia/llmediaimplgstreamer.cpp | 3 +++ 1 file changed, 3 insertions(+) (limited to 'linden/indra/llmedia/llmediaimplgstreamer.cpp') diff --git a/linden/indra/llmedia/llmediaimplgstreamer.cpp b/linden/indra/llmedia/llmediaimplgstreamer.cpp index 20b89f5..270b08b 100644 --- a/linden/indra/llmedia/llmediaimplgstreamer.cpp +++ b/linden/indra/llmedia/llmediaimplgstreamer.cpp @@ -282,6 +282,9 @@ void LLMediaImplGStreamer::set_gst_plugin_path() LL_DEBUGS("MediaImpl") << "GST_PLUGIN_PATH set to " << getenv("GST_PLUGIN_PATH") << LL_ENDL; + // Disable loading system plugins. We only want to use ours, to avoid conflicts. + putenv( "GST_PLUGIN_SYSTEM_PATH=\"\"" ); + #endif // LL_WINDOWS || LL_DARWIN } -- cgit v1.1