diff options
Diffstat (limited to 'linden/indra/llmedia/llmediaimplgstreamer.cpp')
-rw-r--r-- | linden/indra/llmedia/llmediaimplgstreamer.cpp | 122 |
1 files changed, 79 insertions, 43 deletions
diff --git a/linden/indra/llmedia/llmediaimplgstreamer.cpp b/linden/indra/llmedia/llmediaimplgstreamer.cpp index 532ec00..271bb5e 100644 --- a/linden/indra/llmedia/llmediaimplgstreamer.cpp +++ b/linden/indra/llmedia/llmediaimplgstreamer.cpp | |||
@@ -30,15 +30,28 @@ | |||
30 | * $/LicenseInfo$ | 30 | * $/LicenseInfo$ |
31 | */ | 31 | */ |
32 | 32 | ||
33 | #include "llmediaimplgstreamer.h" | ||
34 | |||
35 | ///#if LL_GSTREAMER_ENABLED | 33 | ///#if LL_GSTREAMER_ENABLED |
36 | 34 | ||
35 | #if LL_WINDOWS | ||
36 | // GStreamer 0.10.22 - gstutils.h - conversion from 'guint64' to 'guint8'. | ||
37 | // This was an intentional change to make GStreamer more threadsafe, and | ||
38 | // is okay. Delete this bit if GStreamer ever gets more VS-friendly -- McCabe | ||
39 | #pragma warning(disable : 4244) | ||
40 | #endif | ||
41 | |||
42 | #include "llmediaimplgstreamer.h" | ||
43 | |||
37 | extern "C" { | 44 | extern "C" { |
38 | #include <gst/gst.h> | 45 | #include <gst/gst.h> |
39 | #include <gst/gstelement.h> | 46 | #include <gst/gstelement.h> |
40 | } | 47 | } |
41 | 48 | ||
49 | #if LL_WINDOWS | ||
50 | #pragma warning(default : 4244) | ||
51 | #include <direct.h> | ||
52 | #include <stdlib.h> | ||
53 | #endif | ||
54 | |||
42 | #include "llmediamanager.h" | 55 | #include "llmediamanager.h" |
43 | #include "llmediaimplregister.h" | 56 | #include "llmediaimplregister.h" |
44 | 57 | ||
@@ -189,12 +202,14 @@ bool LLMediaImplGStreamer::startup (LLMediaManagerData* init_data) | |||
189 | LL_DEBUGS("MediaImpl") << "Found GStreamer plugins:" << LL_ENDL; | 202 | LL_DEBUGS("MediaImpl") << "Found GStreamer plugins:" << LL_ENDL; |
190 | GList *list; | 203 | GList *list; |
191 | GstRegistry *registry = gst_registry_get_default(); | 204 | GstRegistry *registry = gst_registry_get_default(); |
205 | std::string loaded = ""; | ||
192 | for (list = gst_registry_get_plugin_list(registry); | 206 | for (list = gst_registry_get_plugin_list(registry); |
193 | list != NULL; | 207 | list != NULL; |
194 | list = g_list_next(list)) | 208 | list = g_list_next(list)) |
195 | { | 209 | { |
196 | GstPlugin *list_plugin = (GstPlugin *)list->data; | 210 | GstPlugin *list_plugin = (GstPlugin *)list->data; |
197 | LL_DEBUGS("MediaImpl") << gst_plugin_get_name(list_plugin) << LL_ENDL; | 211 | (bool)gst_plugin_is_loaded(list_plugin) ? loaded = "Yes" : loaded = "No"; |
212 | LL_DEBUGS("MediaImpl") << gst_plugin_get_name(list_plugin) << ", loaded? " << loaded << LL_ENDL; | ||
198 | } | 213 | } |
199 | gst_plugin_list_free(list); | 214 | gst_plugin_list_free(list); |
200 | 215 | ||
@@ -218,12 +233,12 @@ void LLMediaImplGStreamer::set_gst_plugin_path() | |||
218 | 233 | ||
219 | if(imp_cwd == NULL) | 234 | if(imp_cwd == NULL) |
220 | { | 235 | { |
221 | LL_DEBUGS("LLMediaImpl") << "_getcwd failed, not setting GST_PLUGIN_PATH." | 236 | LL_DEBUGS("MediaImpl") << "_getcwd failed, not setting GST_PLUGIN_PATH." |
222 | << LL_ENDL; | 237 | << LL_ENDL; |
223 | } | 238 | } |
224 | else | 239 | else |
225 | { | 240 | { |
226 | LL_DEBUGS("LLMediaImpl") << "Imprudence is installed at " | 241 | LL_DEBUGS("MediaImpl") << "Imprudence is installed at " |
227 | << imp_cwd << LL_ENDL; | 242 | << imp_cwd << LL_ENDL; |
228 | 243 | ||
229 | // Grab the current path, if it's set. | 244 | // Grab the current path, if it's set. |
@@ -231,28 +246,34 @@ void LLMediaImplGStreamer::set_gst_plugin_path() | |||
231 | char *old_path = getenv("GST_PLUGIN_PATH"); | 246 | char *old_path = getenv("GST_PLUGIN_PATH"); |
232 | if(old_path == NULL) | 247 | if(old_path == NULL) |
233 | { | 248 | { |
234 | LL_DEBUGS("LLMediaImpl") << "Did not find user-set GST_PLUGIN_PATH." | 249 | LL_DEBUGS("MediaImpl") << "Did not find user-set GST_PLUGIN_PATH." |
235 | << LL_ENDL; | 250 | << LL_ENDL; |
236 | } | 251 | } |
237 | else | 252 | else |
238 | { | 253 | { |
239 | old_plugin_path = std::string( old_path ) + ":"; | 254 | old_plugin_path = ";" + std::string( old_path ); |
240 | } | 255 | } |
241 | 256 | ||
242 | 257 | ||
243 | // Search both Imprudence and Imprudence\lib\gstreamer-plugins. | 258 | // Search both Imprudence and Imprudence\lib\gstreamer-plugins. |
244 | // But we also want to first search the path the user has set, if any. | 259 | // If those fail, search the path the user has set, if any. |
245 | std::string plugin_path = | 260 | std::string plugin_path = |
246 | "GST_PLUGIN_PATH=" + | 261 | "GST_PLUGIN_PATH=" + |
247 | old_plugin_path + | 262 | std::string(imp_cwd) + "\\lib\\gstreamer-plugins;" + |
248 | std::string(imp_cwd) + ":" + | 263 | std::string(imp_cwd) + |
249 | std::string(imp_cwd) + "\\lib\\gstreamer-plugins"; | 264 | old_plugin_path; |
250 | 265 | ||
251 | // Place GST_PLUGIN_PATH in the environment settings for imprudence.exe | 266 | // Place GST_PLUGIN_PATH in the environment settings for imprudence.exe |
252 | putenv( (char*)plugin_path.c_str() ); | 267 | // Returns 0 on success |
253 | 268 | if(_putenv( (char*)plugin_path.c_str() )) | |
254 | LL_DEBUGS("LLMediaImpl") << "GST_PLUGIN_PATH set to " | 269 | { |
255 | << getenv("GST_PLUGIN_PATH") << LL_ENDL; | 270 | LL_WARNS("MediaImpl") << "Setting environment variable failed!" << LL_ENDL; |
271 | } | ||
272 | else | ||
273 | { | ||
274 | LL_DEBUGS("MediaImpl") << "GST_PLUGIN_PATH set to " | ||
275 | << getenv("GST_PLUGIN_PATH") << LL_ENDL; | ||
276 | } | ||
256 | } | 277 | } |
257 | 278 | ||
258 | #endif //LL_WINDOWS | 279 | #endif //LL_WINDOWS |
@@ -688,20 +709,23 @@ bool LLMediaImplGStreamer::stop() | |||
688 | if (!mPlaybin || mState == GST_STATE_NULL) | 709 | if (!mPlaybin || mState == GST_STATE_NULL) |
689 | return true; | 710 | return true; |
690 | 711 | ||
691 | GstElement *pipeline = (GstElement *)gst_object_ref(GST_OBJECT(mPlaybin)); | 712 | GstStateChangeReturn state_change; |
692 | gst_object_unref(pipeline); | ||
693 | |||
694 | gst_element_set_state(pipeline, GST_STATE_READY); | ||
695 | 713 | ||
696 | if (mState == GST_STATE_PLAYING) | 714 | state_change = gst_element_set_state(mPlaybin, GST_STATE_READY); |
697 | mState = GST_STATE_VOID_PENDING; | ||
698 | else | ||
699 | mState = GST_STATE_READY; | ||
700 | 715 | ||
701 | GstStateChangeReturn state_change = gst_element_get_state(mPlaybin, NULL, NULL, GST_CLOCK_TIME_NONE); | 716 | LL_DEBUGS("MediaImpl") << gst_element_state_change_return_get_name(state_change) << LL_ENDL; |
702 | LL_DEBUGS("MediaImpl") << "get_state: " << gst_element_state_change_return_get_name(state_change) << LL_ENDL; | ||
703 | 717 | ||
704 | return true; | 718 | if (state_change == GST_STATE_CHANGE_FAILURE) |
719 | { | ||
720 | LL_WARNS("MediaImpl") << "could not stop stream!" << LL_ENDL; | ||
721 | return false; | ||
722 | } | ||
723 | else | ||
724 | { | ||
725 | // Going into pending after play keeps dead streams from looping | ||
726 | (mState == GST_STATE_PLAYING) ? (mState = GST_STATE_VOID_PENDING) : (mState = GST_STATE_READY); | ||
727 | return true; | ||
728 | } | ||
705 | } | 729 | } |
706 | 730 | ||
707 | /////////////////////////////////////////////////////////////////////////////// | 731 | /////////////////////////////////////////////////////////////////////////////// |
@@ -713,25 +737,28 @@ bool LLMediaImplGStreamer::play() | |||
713 | if (!mPlaybin || mState == GST_STATE_NULL) | 737 | if (!mPlaybin || mState == GST_STATE_NULL) |
714 | return true; | 738 | return true; |
715 | 739 | ||
716 | GstElement *pipeline = (GstElement *)gst_object_ref(GST_OBJECT(mPlaybin)); | 740 | GstStateChangeReturn state_change; |
717 | gst_object_unref(pipeline); | 741 | |
718 | 742 | state_change = gst_element_set_state(mPlaybin, GST_STATE_PLAYING); | |
719 | gst_element_set_state(pipeline, GST_STATE_PLAYING); | ||
720 | mState = GST_STATE_PLAYING; | 743 | mState = GST_STATE_PLAYING; |
721 | /*gst_element_set_state(mPlaybin, GST_STATE_PLAYING); | ||
722 | mState = GST_STATE_PLAYING;*/ | ||
723 | 744 | ||
724 | GstStateChangeReturn state_change = gst_element_get_state(mPlaybin, NULL, NULL, GST_CLOCK_TIME_NONE); | 745 | LL_DEBUGS("MediaImpl") << gst_element_state_change_return_get_name(state_change) << LL_ENDL; |
725 | LL_DEBUGS("MediaImpl") << "get_state: " << gst_element_state_change_return_get_name(state_change) << LL_ENDL; | ||
726 | 746 | ||
727 | // Check to make sure playing was successful. If not, stop. | 747 | // Check to make sure playing was successful. If not, stop. |
748 | // NOTE: state_change is almost always GST_STATE_CHANGE_ASYNC | ||
728 | if (state_change == GST_STATE_CHANGE_FAILURE) | 749 | if (state_change == GST_STATE_CHANGE_FAILURE) |
729 | { | 750 | { |
730 | setStatus(LLMediaBase::STATUS_STOPPED); | 751 | // If failing from a bad stream, go into an unknown |
752 | // state to stop bus_callback from looping back. | ||
753 | // We also force a stop in case the operations don't sync | ||
754 | setStatus(LLMediaBase::STATUS_UNKNOWN); | ||
731 | stop(); | 755 | stop(); |
756 | return false; | ||
757 | } | ||
758 | else | ||
759 | { | ||
760 | return true; | ||
732 | } | 761 | } |
733 | |||
734 | return true; | ||
735 | } | 762 | } |
736 | 763 | ||
737 | /////////////////////////////////////////////////////////////////////////////// | 764 | /////////////////////////////////////////////////////////////////////////////// |
@@ -743,13 +770,22 @@ bool LLMediaImplGStreamer::pause() | |||
743 | if (!mPlaybin || mState == GST_STATE_NULL) | 770 | if (!mPlaybin || mState == GST_STATE_NULL) |
744 | return true; | 771 | return true; |
745 | 772 | ||
746 | gst_element_set_state(mPlaybin, GST_STATE_PAUSED); | 773 | GstStateChangeReturn state_change; |
747 | mState = GST_STATE_PAUSED; | ||
748 | |||
749 | GstStateChangeReturn state_change = gst_element_get_state(mPlaybin, NULL, NULL, GST_CLOCK_TIME_NONE); | ||
750 | LL_DEBUGS("MediaImpl") << "get_state: " << gst_element_state_change_return_get_name(state_change) << LL_ENDL; | ||
751 | 774 | ||
752 | return true; | 775 | state_change = gst_element_set_state(mPlaybin, GST_STATE_PAUSED); |
776 | |||
777 | LL_DEBUGS("MediaImpl") << gst_element_state_change_return_get_name(state_change) << LL_ENDL; | ||
778 | |||
779 | if (state_change == GST_STATE_CHANGE_FAILURE) | ||
780 | { | ||
781 | LL_WARNS("MediaImpl") << "could not pause stream!" << LL_ENDL; | ||
782 | return false; | ||
783 | } | ||
784 | else | ||
785 | { | ||
786 | mState = GST_STATE_PAUSED; | ||
787 | return true; | ||
788 | } | ||
753 | }; | 789 | }; |
754 | 790 | ||
755 | 791 | ||