aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llmedia/llmediaimplgstreamer.cpp
diff options
context:
space:
mode:
authorAnders Arnholm2008-12-19 10:12:25 +0100
committerAnders Arnholm2008-12-19 10:12:25 +0100
commit324dfa1561efba6492b72ad4d9306e69b9124776 (patch)
treeec203e765d20e7e042bbb042cd520f00b3185f43 /linden/indra/llmedia/llmediaimplgstreamer.cpp
parentMake openal-1 version info (diff)
downloadmeta-impy-324dfa1561efba6492b72ad4d9306e69b9124776.zip
meta-impy-324dfa1561efba6492b72ad4d9306e69b9124776.tar.gz
meta-impy-324dfa1561efba6492b72ad4d9306e69b9124776.tar.bz2
meta-impy-324dfa1561efba6492b72ad4d9306e69b9124776.tar.xz
Clean up logging to used standard LL metods.
Diffstat (limited to '')
-rw-r--r--linden/indra/llmedia/llmediaimplgstreamer.cpp119
1 files changed, 70 insertions, 49 deletions
diff --git a/linden/indra/llmedia/llmediaimplgstreamer.cpp b/linden/indra/llmedia/llmediaimplgstreamer.cpp
index 5d6a648..5a8a8e0 100644
--- a/linden/indra/llmedia/llmediaimplgstreamer.cpp
+++ b/linden/indra/llmedia/llmediaimplgstreamer.cpp
@@ -49,6 +49,7 @@ extern "C" {
49 49
50#include "llmediaimplgstreamer_syms.h" 50#include "llmediaimplgstreamer_syms.h"
51 51
52#include "llerror.h"
52// register this impl with media manager factory 53// register this impl with media manager factory
53static LLMediaImplRegister sLLMediaImplGStreamerReg( "LLMediaImplGStreamer", new LLMediaImplGStreamerMaker() ); 54static LLMediaImplRegister sLLMediaImplGStreamerReg( "LLMediaImplGStreamer", new LLMediaImplGStreamerMaker() );
54 55
@@ -73,12 +74,13 @@ LLMediaImplGStreamer () :
73 mTextureFormatType ( LL_MEDIA_UNSIGNED_INT_8_8_8_8_REV ), 74 mTextureFormatType ( LL_MEDIA_UNSIGNED_INT_8_8_8_8_REV ),
74 mPump ( NULL ), 75 mPump ( NULL ),
75 mPlaybin ( NULL ), 76 mPlaybin ( NULL ),
76 mVideoSink ( NULL ) 77 mVideoSink ( NULL ),
78 mState( GST_STATE_NULL )
77#ifdef LL_GST_SOUNDSINK 79#ifdef LL_GST_SOUNDSINK
78 ,mAudioSink ( NULL ) 80 ,mAudioSink ( NULL )
79#endif // LL_GST_SOUNDSINK 81#endif // LL_GST_SOUNDSINK
80{ 82{
81 DEBUGMSG("constructing media..."); 83 LL_DEBUGS("MediaManager") << "constructing media..." << LL_ENDL;
82 84
83 setMediaDepth(4); 85 setMediaDepth(4);
84 86
@@ -99,11 +101,12 @@ LLMediaImplGStreamer () :
99 101
100 if (NULL == getenv("LL_GSTREAMER_EXTERNAL")) { 102 if (NULL == getenv("LL_GSTREAMER_EXTERNAL")) {
101 // instantiate and connect a custom video sink 103 // instantiate and connect a custom video sink
104 LL_DEBUGS("MediaManager") << "extrenal video sink..." << LL_ENDL;
102 mVideoSink = 105 mVideoSink =
103 GST_SLVIDEO(llgst_element_factory_make ("private-slvideo", "slvideo")); 106 GST_SLVIDEO(llgst_element_factory_make ("private-slvideo", "slvideo"));
104 if (!mVideoSink) 107 if (!mVideoSink)
105 { 108 {
106 WARNMSG("Could not instantiate private-slvideo element."); 109 LL_WARNS("MediaImpl") << "Could not instantiate private-slvideo element." << LL_ENDL;
107 // todo: cleanup. 110 // todo: cleanup.
108 return; // error 111 return; // error
109 } 112 }
@@ -111,12 +114,13 @@ LLMediaImplGStreamer () :
111 g_object_set(mPlaybin, "video-sink", mVideoSink, NULL); 114 g_object_set(mPlaybin, "video-sink", mVideoSink, NULL);
112 115
113#ifdef LL_GST_SOUNDSINK 116#ifdef LL_GST_SOUNDSINK
117 LL_DEBUGS("MediaManager") << "extrenal audio sink..." << LL_ENDL;
114 // instantiate and connect a custom audio sink 118 // instantiate and connect a custom audio sink
115 mAudioSink = 119 mAudioSink =
116 GST_SLSOUND(llgst_element_factory_make ("private-slsound", "slsound")); 120 GST_SLSOUND(llgst_element_factory_make ("private-slsound", "slsound"));
117 if (!mAudioSink) 121 if (!mAudioSink)
118 { 122 {
119 WARNMSG("Could not instantiate private-slsound element."); 123 LL_WARN("MediaImpl") << "Could not instantiate private-slsound element." << LL_ENDL;
120 // todo: cleanup. 124 // todo: cleanup.
121 return; // error 125 return; // error
122 } 126 }
@@ -149,7 +153,7 @@ int LLMediaImplGStreamer::getTextureFormatInternal() const
149LLMediaImplGStreamer:: 153LLMediaImplGStreamer::
150~LLMediaImplGStreamer () 154~LLMediaImplGStreamer ()
151{ 155{
152 DEBUGMSG("dtor of media..."); 156 LL_DEBUGS("MediaImpl") << ("dtor of media...") << LL_ENDL;
153 unload(); 157 unload();
154} 158}
155 159
@@ -176,21 +180,23 @@ startup ( LLMediaManagerData* init_data )
176 "libgstvideo-0.10.so.0", 180 "libgstvideo-0.10.so.0",
177 "libgstaudio-0.10.so.0") ) 181 "libgstaudio-0.10.so.0") )
178 { 182 {
179 WARNMSG("Couldn't find suitable GStreamer 0.10 support on this system - video playback disabled."); 183 LL_WARNS("MediaImpl") << "Couldn't find suitable GStreamer 0.10 support on this system - video playback disabled." << LL_ENDL;
180 return false; 184 return false;
181 } 185 }
182 186
183 if (llgst_segtrap_set_enabled) 187 if (llgst_segtrap_set_enabled)
184 llgst_segtrap_set_enabled(FALSE); 188 llgst_segtrap_set_enabled(FALSE);
185 else 189 else
186 WARNMSG("gst_segtrap_set_enabled() is not available; Automated crash-reporter may cease to function until next restart."); 190 {
191 LL_WARNS("MediaImpl") << "gst_segtrap_set_enabled() is not available; Automated crash-reporter may cease to function until next restart." << LL_ENDL;
192 }
187 193
188 // Protect against GStreamer resetting the locale, yuck. 194 // Protect against GStreamer resetting the locale, yuck.
189 static std::string saved_locale; 195 static std::string saved_locale;
190 saved_locale = setlocale(LC_ALL, NULL); 196 saved_locale = setlocale(LC_ALL, NULL);
191 if (0 == llgst_init_check(NULL, NULL, NULL)) 197 if (0 == llgst_init_check(NULL, NULL, NULL))
192 { 198 {
193 WARNMSG("GST init failed for unspecified reason."); 199 LL_WARNS("MediaImpl") << "GST init failed for unspecified reason." << LL_ENDL;
194 setlocale(LC_ALL, saved_locale.c_str() ); 200 setlocale(LC_ALL, saved_locale.c_str() );
195 return false; 201 return false;
196 } 202 }
@@ -222,7 +228,7 @@ closedown()
222// 228//
223//#define LL_GST_REPORT_STATE_CHANGES 229//#define LL_GST_REPORT_STATE_CHANGES
224#ifdef LL_GST_REPORT_STATE_CHANGES 230#ifdef LL_GST_REPORT_STATE_CHANGES
225static char* get_gst_state_name(GstState state) 231static const char* get_gst_state_name(GstState state)
226{ 232{
227 switch (state) { 233 switch (state) {
228 case GST_STATE_VOID_PENDING: return "VOID_PENDING"; 234 case GST_STATE_VOID_PENDING: return "VOID_PENDING";
@@ -241,17 +247,7 @@ LLMediaImplGStreamer::bus_callback (GstBus *bus,
241 GstMessage *message, 247 GstMessage *message,
242 gpointer data) 248 gpointer data)
243{ 249{
244 if (GST_MESSAGE_TYPE(message) != GST_MESSAGE_STATE_CHANGED && 250 LL_DEBUGS("MediaCallback") << "Got GST message type: " << LLGST_MESSAGE_TYPE_NAME (message) << LL_ENDL;
245 GST_MESSAGE_TYPE(message) != GST_MESSAGE_BUFFERING)
246 {
247 DEBUGMSG("Got GST message type: %s",
248 LLGST_MESSAGE_TYPE_NAME (message));
249 }
250 else
251 {
252 DEBUGMSG("Got GST message type: %s",
253 LLGST_MESSAGE_TYPE_NAME (message));
254 }
255 251
256 LLMediaImplGStreamer *impl = (LLMediaImplGStreamer*)data; 252 LLMediaImplGStreamer *impl = (LLMediaImplGStreamer*)data;
257 253
@@ -262,7 +258,7 @@ LLMediaImplGStreamer::bus_callback (GstBus *bus,
262 { 258 {
263 gint percent = 0; 259 gint percent = 0;
264 llgst_message_parse_buffering(message, &percent); 260 llgst_message_parse_buffering(message, &percent);
265 DEBUGMSG("GST buffering: %d%%", percent); 261 LL_DEBUGS("MediaBuffering") << "GST buffering: " << percent << "%%" << LL_ENDL;
266 LLMediaEvent event( impl, percent ); 262 LLMediaEvent event( impl, percent );
267 impl->getEventEmitter().update( &LLMediaObserver::onUpdateProgress, event ); 263 impl->getEventEmitter().update( &LLMediaObserver::onUpdateProgress, event );
268 264
@@ -279,16 +275,18 @@ LLMediaImplGStreamer::bus_callback (GstBus *bus,
279 &pending_state); 275 &pending_state);
280#ifdef LL_GST_REPORT_STATE_CHANGES 276#ifdef LL_GST_REPORT_STATE_CHANGES
281 // not generally very useful, and rather spammy. 277 // not generally very useful, and rather spammy.
282 DEBUGMSG("state change (old,<new>,pending): %s,<%s>,%s", 278 LL_DEBUGS("MediaState") << "GST state change (old,<new>,pending): "<< get_gst_state_name(old_state) << ",<" << get_gst_state_name(new_state) << ">," << get_gst_state_name(pending_state) << LL_ENDL;
283 get_gst_state_name(old_state),
284 get_gst_state_name(new_state),
285 get_gst_state_name(pending_state));
286#endif // LL_GST_REPORT_STATE_CHANGES 279#endif // LL_GST_REPORT_STATE_CHANGES
287 280
288 switch (new_state) { 281 switch (new_state) {
289 case GST_STATE_VOID_PENDING: 282 case GST_STATE_VOID_PENDING:
290 break; 283 break;
291 case GST_STATE_NULL: 284 case GST_STATE_NULL:
285 LL_DEBUGS("MediaImpl") << "State changed to NULL" << LL_ENDL;
286 if (impl->getState() == GST_STATE_PLAYING) { // We got stoped by gstremer...
287 impl->play();
288 LL_DEBUGS("MediaImpl") << "Trying to restart." << LL_ENDL;
289 }
292 break; 290 break;
293 case GST_STATE_READY: 291 case GST_STATE_READY:
294 break; 292 break;
@@ -309,11 +307,12 @@ LLMediaImplGStreamer::bus_callback (GstBus *bus,
309 gchar *debug = NULL; 307 gchar *debug = NULL;
310 308
311 llgst_message_parse_error (message, &err, &debug); 309 llgst_message_parse_error (message, &err, &debug);
312 WARNMSG("GST error: %s", err->message); 310 LL_WARNS("MediaImpl") << "GST Error: " << err->message << LL_ENDL;
313 g_error_free (err); 311 g_error_free (err);
314 g_free (debug); 312 g_free (debug);
315 313
316 impl->addCommand(LLMediaBase::COMMAND_STOP); 314 impl->addCommand(LLMediaBase::COMMAND_STOP);
315 //impl->addCommand(LLMediaBase::COMMAND_START);
317 316
318 break; 317 break;
319 } 318 }
@@ -324,7 +323,8 @@ LLMediaImplGStreamer::bus_callback (GstBus *bus,
324 gchar *debug = NULL; 323 gchar *debug = NULL;
325 324
326 llgst_message_parse_info (message, &err, &debug); 325 llgst_message_parse_info (message, &err, &debug);
327 INFOMSG("GST info: %s", err->message); 326 LL_INFOS("MediaImpl") << "GST info: " << err->message
327 << LL_ENDL;
328 g_error_free (err); 328 g_error_free (err);
329 g_free (debug); 329 g_free (debug);
330 } 330 }
@@ -335,18 +335,36 @@ LLMediaImplGStreamer::bus_callback (GstBus *bus,
335 gchar *debug = NULL; 335 gchar *debug = NULL;
336 336
337 llgst_message_parse_warning (message, &err, &debug); 337 llgst_message_parse_warning (message, &err, &debug);
338 WARNMSG("GST warning: %s", err->message); 338 LL_WARNS("MediaImpl") << "GST warning: " << err->message
339 << LL_ENDL;
339 g_error_free (err); 340 g_error_free (err);
340 g_free (debug); 341 g_free (debug);
341 342
342 break; 343 break;
343 } 344 }
345 case GST_MESSAGE_TAG: {
346#if 0
347 GstTagList *tag_list;
348 gchar *title;
349 gchar *artist;
350 llgst_message_parse_tag(message, &tag_list);
351 gboolean hazTitle = llgst_tag_list_get_string(tag_list,
352 GST_TAG_TITLE, &title);
353 gboolean hazArtist = llgst_tag_list_get_string(tag_list,
354 GST_TAG_ARTIST, &artist);
355 if(hazTitle)
356 LL_INFOS("MediaInfo") << "Title is " << title << LL_ENDL;
357 if(hazArtist)
358 LL_INFOS("MediaInfo") << "Artist is " << artist << LL_ENDL;
359#endif
360 break;
361 }
344 case GST_MESSAGE_EOS: 362 case GST_MESSAGE_EOS:
345 /* end-of-stream */ 363 /* end-of-stream */
346 DEBUGMSG("GST end-of-stream."); 364 LL_DEBUGS("MediaImpl") << "GST end-of-stream." << LL_ENDL;
347 if (impl->isLooping()) 365 if (impl->isLooping())
348 { 366 {
349 DEBUGMSG("looping media..."); 367 LL_DEBUGS("MediaImpl") << "looping media..." << LL_ENDL;
350 impl->stop(); 368 impl->stop();
351 impl->play(); 369 impl->play();
352 } 370 }
@@ -374,7 +392,8 @@ bool
374LLMediaImplGStreamer:: 392LLMediaImplGStreamer::
375navigateTo ( const std::string urlIn ) 393navigateTo ( const std::string urlIn )
376{ 394{
377 DEBUGMSG("Setting media URI: %s", urlIn.c_str()); 395 LL_DEBUGS("MediaImpl") << "Setting media URI: " << urlIn.c_str()
396 << LL_ENDL;
378 397
379 if (NULL == mPump 398 if (NULL == mPump
380#ifdef LL_GST_SOUNDSINK 399#ifdef LL_GST_SOUNDSINK
@@ -412,10 +431,11 @@ bool
412LLMediaImplGStreamer:: 431LLMediaImplGStreamer::
413unload () 432unload ()
414{ 433{
415 DEBUGMSG("unloading media..."); 434 LL_DEBUGS("MediaImpl") << "unloading media..." << LL_ENDL;
416 if (mPlaybin) 435 if (mPlaybin)
417 { 436 {
418 llgst_element_set_state (mPlaybin, GST_STATE_NULL); 437 llgst_element_set_state (mPlaybin, GST_STATE_NULL);
438 mState = GST_STATE_NULL;
419 llgst_object_unref (GST_OBJECT (mPlaybin)); 439 llgst_object_unref (GST_OBJECT (mPlaybin));
420 mPlaybin = NULL; 440 mPlaybin = NULL;
421 } 441 }
@@ -443,7 +463,7 @@ bool
443LLMediaImplGStreamer:: 463LLMediaImplGStreamer::
444updateMedia () 464updateMedia ()
445{ 465{
446 DEBUGMSG("updating media..."); 466 //LL_DEBUGS("MediaImpl") << "updating media..." << LL_ENDL;
447 467
448 // sanity check 468 // sanity check
449 if (NULL == mPump 469 if (NULL == mPump
@@ -452,7 +472,7 @@ updateMedia ()
452#endif 472#endif
453 || NULL == mPlaybin) 473 || NULL == mPlaybin)
454 { 474 {
455 DEBUGMSG("dead media..."); 475 LL_DEBUGS("MediaImpl") << "dead media..." << LL_ENDL;
456 return false; 476 return false;
457 } 477 }
458 478
@@ -460,36 +480,33 @@ updateMedia ()
460 switch (nextCommand()) 480 switch (nextCommand())
461 { 481 {
462 case LLMediaBase::COMMAND_START: 482 case LLMediaBase::COMMAND_START:
463 DEBUGMSG("COMMAND_START"); 483 LL_DEBUGS("MediaImpl") << "COMMAND_START" << LL_ENDL;
464 if (getStatus() == LLMediaBase::STATUS_PAUSED || 484 if (getStatus() == LLMediaBase::STATUS_PAUSED ||
465 getStatus() == LLMediaBase::STATUS_NAVIGATING || 485 getStatus() == LLMediaBase::STATUS_NAVIGATING ||
466 getStatus() == LLMediaBase::STATUS_STOPPED) 486 getStatus() == LLMediaBase::STATUS_STOPPED)
467 { 487 {
468 DEBUGMSG("doing COMMAND_START");
469 play(); 488 play();
470 setStatus(LLMediaBase::STATUS_STARTED); 489 setStatus(LLMediaBase::STATUS_STARTED);
471 clearCommand(); 490 clearCommand();
472 } 491 }
473 break; 492 break;
474 case LLMediaBase::COMMAND_STOP: 493 case LLMediaBase::COMMAND_STOP:
475 DEBUGMSG("COMMAND_STOP"); 494 LL_DEBUGS("MediaImpl") << "COMMAND_STOP" << LL_ENDL;
476 DEBUGMSG("doing COMMAND_STOP");
477 stop(); 495 stop();
478 setStatus(LLMediaBase::STATUS_STOPPED); 496 setStatus(LLMediaBase::STATUS_STOPPED);
479 clearCommand(); 497 clearCommand();
480 break; 498 break;
481 case LLMediaBase::COMMAND_PAUSE: 499 case LLMediaBase::COMMAND_PAUSE:
482 DEBUGMSG("COMMAND_PAUSE"); 500 LL_DEBUGS("MediaImpl") << "COMMAND_PAUSE" << LL_ENDL;
483 if (getStatus() == LLMediaBase::STATUS_STARTED) 501 if (getStatus() == LLMediaBase::STATUS_STARTED)
484 { 502 {
485 DEBUGMSG("doing COMMAND_PAUSE");
486 pause(); 503 pause();
487 setStatus(LLMediaBase::STATUS_PAUSED); 504 setStatus(LLMediaBase::STATUS_PAUSED);
488 clearCommand(); 505 clearCommand();
489 } 506 }
490 break; 507 break;
491 default: 508 default:
492 DEBUGMSG("COMMAND_?"); 509 LL_INFOS("MediaImpl") << "Unknown command" << LL_ENDL;
493 clearCommand(); 510 clearCommand();
494 break; 511 break;
495 case LLMediaBase::COMMAND_NONE: 512 case LLMediaBase::COMMAND_NONE:
@@ -507,7 +524,7 @@ updateMedia ()
507 GST_OBJECT_LOCK(mVideoSink); 524 GST_OBJECT_LOCK(mVideoSink);
508 if (mVideoSink->retained_frame_ready) 525 if (mVideoSink->retained_frame_ready)
509 { 526 {
510 DEBUGMSG("NEW FRAME "); 527 LL_DEBUGS("MediaImpl") <<"NEW FRAME " << LL_ENDL;
511 if (mVideoSink->retained_frame_width != getMediaWidth() || 528 if (mVideoSink->retained_frame_width != getMediaWidth() ||
512 mVideoSink->retained_frame_height != getMediaHeight()) 529 mVideoSink->retained_frame_height != getMediaHeight())
513 // *TODO: also check for change in format 530 // *TODO: also check for change in format
@@ -527,8 +544,9 @@ updateMedia ()
527 mTextureFormatType = LL_MEDIA_UNSIGNED_INT_8_8_8_8_REV; 544 mTextureFormatType = LL_MEDIA_UNSIGNED_INT_8_8_8_8_REV;
528 } 545 }
529 mMediaRowbytes = neww * newd; 546 mMediaRowbytes = neww * newd;
530 DEBUGMSG("video container resized to %dx%d", 547 LL_DEBUGS("MediaImpl")
531 neww, newh); 548 << "video container resized to " <<
549 neww <<"x"<< newh << LL_ENDL;
532 550
533 delete[] mediaData; 551 delete[] mediaData;
534 mediaData = new unsigned char[mMediaRowbytes * 552 mediaData = new unsigned char[mMediaRowbytes *
@@ -568,9 +586,10 @@ bool
568LLMediaImplGStreamer:: 586LLMediaImplGStreamer::
569stop () 587stop ()
570{ 588{
571 DEBUGMSG("stopping media..."); 589 LL_DEBUGS("MediaImpl") << "stopping media..." << LL_ENDL;
572 // todo: error-check this? 590 // todo: error-check this?
573 llgst_element_set_state(mPlaybin, GST_STATE_READY); 591 llgst_element_set_state(mPlaybin, GST_STATE_READY);
592 mState = GST_STATE_READY;
574 return true; 593 return true;
575} 594}
576 595
@@ -580,9 +599,10 @@ bool
580LLMediaImplGStreamer:: 599LLMediaImplGStreamer::
581play () 600play ()
582{ 601{
583 DEBUGMSG("playing media..."); 602 LL_DEBUGS("MediaImpl") << "playing media..." << LL_ENDL;
584 // todo: error-check this? 603 // todo: error-check this?
585 llgst_element_set_state(mPlaybin, GST_STATE_PLAYING); 604 llgst_element_set_state(mPlaybin, GST_STATE_PLAYING);
605 mState = GST_STATE_PLAYING;
586 return true; 606 return true;
587} 607}
588 608
@@ -592,9 +612,10 @@ bool
592LLMediaImplGStreamer:: 612LLMediaImplGStreamer::
593pause () 613pause ()
594{ 614{
595 DEBUGMSG("pausing media..."); 615 LL_DEBUGS("MediaImpl") <<"pausing media..." << LL_ENDL;
596 // todo: error-check this? 616 // todo: error-check this?
597 llgst_element_set_state(mPlaybin, GST_STATE_PAUSED); 617 llgst_element_set_state(mPlaybin, GST_STATE_PAUSED);
618 mState = GST_STATE_PAUSED;
598 return true; 619 return true;
599}; 620};
600 621
@@ -624,8 +645,8 @@ seek( double time )
624 GST_SEEK_TYPE_SET, gint64(time*1000000000.0F), 645 GST_SEEK_TYPE_SET, gint64(time*1000000000.0F),
625 GST_SEEK_TYPE_NONE, GST_CLOCK_TIME_NONE); 646 GST_SEEK_TYPE_NONE, GST_CLOCK_TIME_NONE);
626 } 647 }
627 DEBUGMSG("MEDIA SEEK REQUEST to %fsec result was %d", 648 LL_DEBUGS("MediaImpl") << "MEDIA SEEK REQUEST to " << float(time)
628 float(time), int(success)); 649 << "sec result was " << int(success) << LL_ENDL;
629 return success; 650 return success;
630} 651}
631 652