aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--ChangeLog.txt42
-rw-r--r--linden/indra/llmedia/llmediabase.h15
-rw-r--r--linden/indra/llmedia/llmediaimplcommon.cpp12
-rw-r--r--linden/indra/llmedia/llmediaimplcommon.h2
-rw-r--r--linden/indra/llmedia/llmediaimplgstreamer.cpp58
-rw-r--r--linden/indra/llmedia/llmediaimplgstreamer.h17
-rw-r--r--linden/indra/newview/app_settings/settings.xml11
-rw-r--r--linden/indra/newview/llviewercontrol.cpp18
-rw-r--r--linden/indra/newview/llviewermedia.cpp7
9 files changed, 180 insertions, 2 deletions
diff --git a/ChangeLog.txt b/ChangeLog.txt
index 9d293fb..a4c3415 100644
--- a/ChangeLog.txt
+++ b/ChangeLog.txt
@@ -1,3 +1,45 @@
12009-04-02 Jacek Antonelli <jacek.antonelli@gmail.com>
2
3 * linden/indra/newview/llviewermedia.cpp:
4 Apply saved MediaDebugLevel at media init time.
5
6
7 * linden/indra/llmedia/llmediaimplgstreamer.cpp:
8 Plugged in LLMediaImplGStreamer::gstreamer_log().
9
10
11 * linden/indra/llmedia/llmediaimplgstreamer.cpp:
12 Implemented LLMediaImplGStreamer::gstreamer_log().
13 * linden/indra/llmedia/llmediaimplgstreamer.h:
14 Ditto.
15
16
17 * linden/indra/newview/llviewercontrol.cpp:
18 Implemented handleMediaDebugLevelChanged hook.
19
20
212009-04-01 Jacek Antonelli <jacek.antonelli@gmail.com>
22
23 * linden/indra/newview/app_settings/settings.xml:
24 Added MediaDebugLevel setting in XML (does nothing yet).
25
26
27 * linden/indra/llmedia/llmediaimplgstreamer.cpp:
28 Implemented LLMediaImplGstreamer::setDebugLevel().
29 * linden/indra/llmedia/llmediaimplgstreamer.h:
30 Ditto.
31
32
33 * linden/indra/llmedia/llmediaimplcommon.cpp:
34 Added LLMediaImplCommon::setDebugLevel().
35 * linden/indra/llmedia/llmediaimplcommon.h:
36 Ditto.
37
38
39 * linden/indra/llmedia/llmediabase.h:
40 Added LLMediaBase::EDebugLevel and setDebugLevel prototype.
41
42
12009-03-30 McCabe Maxsted <hakushakukun@gmail.com> 432009-03-30 McCabe Maxsted <hakushakukun@gmail.com>
2 44
3 * linden/indra/llmedia/llmediaimplgstreamer.cpp: 45 * linden/indra/llmedia/llmediaimplgstreamer.cpp:
diff --git a/linden/indra/llmedia/llmediabase.h b/linden/indra/llmedia/llmediabase.h
index b5b9420..bf54a22 100644
--- a/linden/indra/llmedia/llmediabase.h
+++ b/linden/indra/llmedia/llmediabase.h
@@ -61,6 +61,21 @@ class LLMediaBase
61 // undoes everything init() didm called by the media manager when destroying a source 61 // undoes everything init() didm called by the media manager when destroying a source
62 virtual bool reset() = 0; 62 virtual bool reset() = 0;
63 63
64
65 /* Mirrors GStreamer debug levels. */
66 enum EDebugLevel {
67 DEBUG_LEVEL_NONE = 0,
68 DEBUG_LEVEL_ERROR,
69 DEBUG_LEVEL_WARNING,
70 DEBUG_LEVEL_INFO,
71 DEBUG_LEVEL_DEBUG,
72 DEBUG_LEVEL_LOG,
73 DEBUG_LEVEL_COUNT,
74 };
75
76 /* Set the debug verbosity level. Only implemented for GStreamer. */
77 virtual bool setDebugLevel( EDebugLevel level ) = 0;
78
64 // accessor for MIME type 79 // accessor for MIME type
65 virtual bool setMimeType( const std::string mime_type ) = 0; 80 virtual bool setMimeType( const std::string mime_type ) = 0;
66 virtual std::string getMimeType() const = 0; 81 virtual std::string getMimeType() const = 0;
diff --git a/linden/indra/llmedia/llmediaimplcommon.cpp b/linden/indra/llmedia/llmediaimplcommon.cpp
index abb61e1..48b3973 100644
--- a/linden/indra/llmedia/llmediaimplcommon.cpp
+++ b/linden/indra/llmedia/llmediaimplcommon.cpp
@@ -66,7 +66,8 @@ LLMediaImplCommon::LLMediaImplCommon() :
66 mCommand( LLMediaBase::COMMAND_NONE ), 66 mCommand( LLMediaBase::COMMAND_NONE ),
67 mStatus( LLMediaBase::STATUS_UNKNOWN ), 67 mStatus( LLMediaBase::STATUS_UNKNOWN ),
68 mVolume( 0 ), 68 mVolume( 0 ),
69 mLooping( false ) 69 mLooping( false ),
70 mDebugLevel( LLMediaBase::DEBUG_LEVEL_NONE )
70{ 71{
71} 72}
72 73
@@ -92,6 +93,15 @@ bool LLMediaImplCommon::reset()
92 93
93//////////////////////////////////////////////////////////////////////////////// 94////////////////////////////////////////////////////////////////////////////////
94// virtual (derives from LLMediaBase) 95// virtual (derives from LLMediaBase)
96bool LLMediaImplCommon::setDebugLevel( LLMediaBase::EDebugLevel level )
97{
98 mDebugLevel = level;
99
100 return true;
101}
102
103////////////////////////////////////////////////////////////////////////////////
104// virtual (derives from LLMediaBase)
95bool LLMediaImplCommon::setMimeType( const std::string mime_type ) 105bool LLMediaImplCommon::setMimeType( const std::string mime_type )
96{ 106{
97 mMimeType = mime_type; 107 mMimeType = mime_type;
diff --git a/linden/indra/llmedia/llmediaimplcommon.h b/linden/indra/llmedia/llmediaimplcommon.h
index aa6c4d5..8a726f1 100644
--- a/linden/indra/llmedia/llmediaimplcommon.h
+++ b/linden/indra/llmedia/llmediaimplcommon.h
@@ -54,6 +54,7 @@ class LLMediaImplCommon :
54 // housekeeping 54 // housekeeping
55 virtual bool init(); 55 virtual bool init();
56 virtual bool reset(); 56 virtual bool reset();
57 virtual bool setDebugLevel( LLMediaBase::EDebugLevel level );
57 virtual bool setMimeType( const std::string url ); 58 virtual bool setMimeType( const std::string url );
58 virtual std::string getMimeType() const; 59 virtual std::string getMimeType() const;
59 virtual std::string getMediaURL() const; 60 virtual std::string getMediaURL() const;
@@ -156,6 +157,7 @@ class LLMediaImplCommon :
156 LLMediaBase::ECommand mCommand; 157 LLMediaBase::ECommand mCommand;
157 LLMediaBase::EStatus mStatus; 158 LLMediaBase::EStatus mStatus;
158 bool mLooping; 159 bool mLooping;
160 LLMediaBase::EDebugLevel mDebugLevel;
159}; 161};
160 162
161#endif // LLMEDIAIMPLCOMMON_H 163#endif // LLMEDIAIMPLCOMMON_H
diff --git a/linden/indra/llmedia/llmediaimplgstreamer.cpp b/linden/indra/llmedia/llmediaimplgstreamer.cpp
index 8ffb7c8..271bb5e 100644
--- a/linden/indra/llmedia/llmediaimplgstreamer.cpp
+++ b/linden/indra/llmedia/llmediaimplgstreamer.cpp
@@ -189,7 +189,11 @@ bool LLMediaImplGStreamer::startup (LLMediaManagerData* init_data)
189 return false; 189 return false;
190 } 190 }
191 setlocale(LC_ALL, saved_locale.c_str() ); 191 setlocale(LC_ALL, saved_locale.c_str() );
192 192
193 // Set up logging facilities
194 gst_debug_remove_log_function( gst_debug_log_default );
195 gst_debug_add_log_function( gstreamer_log, NULL );
196
193 // Init our custom plugins - only really need do this once. 197 // Init our custom plugins - only really need do this once.
194 gst_slvideo_init_class(); 198 gst_slvideo_init_class();
195 199
@@ -276,12 +280,64 @@ void LLMediaImplGStreamer::set_gst_plugin_path()
276} 280}
277 281
278 282
283void LLMediaImplGStreamer::gstreamer_log(GstDebugCategory *category,
284 GstDebugLevel level,
285 const gchar *file,
286 const gchar *function,
287 gint line,
288 GObject *object,
289 GstDebugMessage *message,
290 gpointer data)
291{
292 std::stringstream log(std::stringstream::out);
293
294 // Log format example:
295 //
296 // GST_ELEMENT_PADS: removing pad 'sink' (in gstelement.c:757:gst_element_remove_pad)
297 //
298 log << gst_debug_category_get_name( category ) << ": "
299 << gst_debug_message_get(message) << " "
300 << "(in " << file << ":" << line << ":" << function << ")";
301
302 switch( level )
303 {
304 case GST_LEVEL_ERROR:
305 LL_ERRS("MediaImpl") << log.str() << LL_ENDL;
306 break;
307 case GST_LEVEL_WARNING:
308 LL_WARNS("MediaImpl") << log.str() << LL_ENDL;
309 break;
310 case GST_LEVEL_DEBUG:
311 LL_DEBUGS("MediaImpl") << log.str() << LL_ENDL;
312 break;
313 case GST_LEVEL_INFO:
314 LL_INFOS("MediaImpl") << log.str() << LL_ENDL;
315 break;
316 default:
317 // Do nothing.
318 break;
319 }
320}
321
322
279bool LLMediaImplGStreamer::closedown() 323bool LLMediaImplGStreamer::closedown()
280{ 324{
281 return true; 325 return true;
282} 326}
283 327
284 328
329bool LLMediaImplGStreamer::setDebugLevel( LLMediaBase::EDebugLevel level )
330{
331 // Do parent class stuff.
332 LLMediaImplCommon::setDebugLevel(level);
333
334 // Set GStreamer verbosity.
335 gst_debug_set_default_threshold( (GstDebugLevel)level );
336
337 return true;
338}
339
340
285/////////////////////////////////////////////////////////////////////////////// 341///////////////////////////////////////////////////////////////////////////////
286// 342//
287// Uncomment the line below to enable spammy debug data. 343// Uncomment the line below to enable spammy debug data.
diff --git a/linden/indra/llmedia/llmediaimplgstreamer.h b/linden/indra/llmedia/llmediaimplgstreamer.h
index 2918416..37eaf53 100644
--- a/linden/indra/llmedia/llmediaimplgstreamer.h
+++ b/linden/indra/llmedia/llmediaimplgstreamer.h
@@ -69,6 +69,23 @@ class LLMediaImplGStreamer:
69 // Sets GST_PLUGIN_PATH env var for GStreamer. 69 // Sets GST_PLUGIN_PATH env var for GStreamer.
70 static void set_gst_plugin_path(); 70 static void set_gst_plugin_path();
71 71
72 /* virtual */ bool setDebugLevel( LLMediaBase::EDebugLevel level );
73
74 // Function given to GStreamer for handling debug messages
75 static void gstreamer_log(GstDebugCategory *category,
76 GstDebugLevel level,
77 const gchar *file,
78 const gchar *function,
79 gint line,
80 GObject *object,
81 GstDebugMessage *message,
82 gpointer data)
83#if __GNUC__
84 // recommended by the gstreamer docs
85 G_GNUC_NO_INSTRUMENT
86#endif
87 ;
88
72 /* virtual */ std::string getVersion(); 89 /* virtual */ std::string getVersion();
73 /* virtual */ bool navigateTo( const std::string url ); 90 /* virtual */ bool navigateTo( const std::string url );
74 /* virtual */ bool updateMedia(); 91 /* virtual */ bool updateMedia();
diff --git a/linden/indra/newview/app_settings/settings.xml b/linden/indra/newview/app_settings/settings.xml
index 7405aad..1ecab2b 100644
--- a/linden/indra/newview/app_settings/settings.xml
+++ b/linden/indra/newview/app_settings/settings.xml
@@ -4659,6 +4659,17 @@
4659 <key>Value</key> 4659 <key>Value</key>
4660 <integer>0</integer> 4660 <integer>0</integer>
4661 </map> 4661 </map>
4662 <key>MediaDebugLevel</key>
4663 <map>
4664 <key>Comment</key>
4665 <string>How spammy media (GStreamer) debug output should be. (0-4)</string>
4666 <key>Persist</key>
4667 <integer>1</integer>
4668 <key>Type</key>
4669 <string>U32</string>
4670 <key>Value</key>
4671 <integer>0</integer>
4672 </map>
4662 <key>MemoryLogFrequency</key> 4673 <key>MemoryLogFrequency</key>
4663 <map> 4674 <map>
4664 <key>Comment</key> 4675 <key>Comment</key>
diff --git a/linden/indra/newview/llviewercontrol.cpp b/linden/indra/newview/llviewercontrol.cpp
index 7a30b22..a8a3b16 100644
--- a/linden/indra/newview/llviewercontrol.cpp
+++ b/linden/indra/newview/llviewercontrol.cpp
@@ -70,6 +70,7 @@
70#include "llvosurfacepatch.h" 70#include "llvosurfacepatch.h"
71#include "llvowlsky.h" 71#include "llvowlsky.h"
72#include "llrender.h" 72#include "llrender.h"
73#include "llmediamanager.h"
73 74
74#ifdef TOGGLE_HACKED_GODLIKE_VIEWER 75#ifdef TOGGLE_HACKED_GODLIKE_VIEWER
75BOOL gHackGodmode = FALSE; 76BOOL gHackGodmode = FALSE;
@@ -429,6 +430,22 @@ bool handleVoiceClientPrefsChanged(const LLSD& newvalue)
429 return true; 430 return true;
430} 431}
431 432
433bool handleMediaDebugLevelChanged(const LLSD& newvalue)
434{
435 LLMediaManager *mgr = LLMediaManager::getInstance();
436 if (mgr)
437 {
438 LLMediaBase *impl =
439 mgr->createSourceFromMimeType("http", "audio/mpeg");
440
441 if (impl)
442 {
443 impl->setDebugLevel( (LLMediaBase::EDebugLevel)newvalue.asInteger() );
444 }
445 }
446 return true;
447}
448
432//////////////////////////////////////////////////////////////////////////// 449////////////////////////////////////////////////////////////////////////////
433 450
434void settings_setup_listeners() 451void settings_setup_listeners()
@@ -556,6 +573,7 @@ void settings_setup_listeners()
556 gSavedSettings.getControl("VoiceInputAudioDevice")->getSignal()->connect(boost::bind(&handleVoiceClientPrefsChanged, _1)); 573 gSavedSettings.getControl("VoiceInputAudioDevice")->getSignal()->connect(boost::bind(&handleVoiceClientPrefsChanged, _1));
557 gSavedSettings.getControl("VoiceOutputAudioDevice")->getSignal()->connect(boost::bind(&handleVoiceClientPrefsChanged, _1)); 574 gSavedSettings.getControl("VoiceOutputAudioDevice")->getSignal()->connect(boost::bind(&handleVoiceClientPrefsChanged, _1));
558 gSavedSettings.getControl("LipSyncEnabled")->getSignal()->connect(boost::bind(&handleVoiceClientPrefsChanged, _1)); 575 gSavedSettings.getControl("LipSyncEnabled")->getSignal()->connect(boost::bind(&handleVoiceClientPrefsChanged, _1));
576 gSavedSettings.getControl("MediaDebugLevel")->getSignal()->connect(boost::bind(&handleMediaDebugLevelChanged, _1));
559} 577}
560 578
561template <> eControlType get_control_type<U32>(const U32& in, LLSD& out) 579template <> eControlType get_control_type<U32>(const U32& in, LLSD& out)
diff --git a/linden/indra/newview/llviewermedia.cpp b/linden/indra/newview/llviewermedia.cpp
index e99c838..d8fcdcb 100644
--- a/linden/indra/newview/llviewermedia.cpp
+++ b/linden/indra/newview/llviewermedia.cpp
@@ -496,6 +496,13 @@ void LLViewerMedia::initClass()
496 const LLMIMETypes::LLMIMEInfo& info = it->second; 496 const LLMIMETypes::LLMIMEInfo& info = it->second;
497 mm->addMimeTypeImplNameMap( mime_type, info.mImpl ); 497 mm->addMimeTypeImplNameMap( mime_type, info.mImpl );
498 } 498 }
499
500 LLMediaBase *impl = mm->createSourceFromMimeType("http", "audio/mpeg");
501 if (impl)
502 {
503 U32 level = gSavedSettings.getU32("MediaDebugLevel");
504 impl->setDebugLevel( (LLMediaBase::EDebugLevel)level );
505 }
499} 506}
500 507
501////////////////////////////////////////////////////////////////////////////////////////// 508//////////////////////////////////////////////////////////////////////////////////////////