summaryrefslogtreecommitdiffstats
path: root/dom/speakermanager/SpeakerManagerServiceChild.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'dom/speakermanager/SpeakerManagerServiceChild.cpp')
-rw-r--r--dom/speakermanager/SpeakerManagerServiceChild.cpp121
1 files changed, 121 insertions, 0 deletions
diff --git a/dom/speakermanager/SpeakerManagerServiceChild.cpp b/dom/speakermanager/SpeakerManagerServiceChild.cpp
new file mode 100644
index 000000000..6c1e30b78
--- /dev/null
+++ b/dom/speakermanager/SpeakerManagerServiceChild.cpp
@@ -0,0 +1,121 @@
+/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/* vim: set ts=8 sts=2 et sw=2 tw=80: */
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this file,
+ * You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+#include "SpeakerManagerServiceChild.h"
+#include "mozilla/Services.h"
+#include "mozilla/StaticPtr.h"
+#include "mozilla/Unused.h"
+#include "mozilla/dom/ContentChild.h"
+#include "mozilla/dom/ContentParent.h"
+#include "nsIObserverService.h"
+#include "nsThreadUtils.h"
+#include "AudioChannelService.h"
+#include <cutils/properties.h>
+
+using namespace mozilla;
+using namespace mozilla::dom;
+
+StaticRefPtr<SpeakerManagerServiceChild> gSpeakerManagerServiceChild;
+
+// static
+SpeakerManagerService*
+SpeakerManagerServiceChild::GetOrCreateSpeakerManagerService()
+{
+ MOZ_ASSERT(NS_IsMainThread());
+
+ // If we already exist, exit early
+ if (gSpeakerManagerServiceChild) {
+ return gSpeakerManagerServiceChild;
+ }
+
+ // Create new instance, register, return
+ RefPtr<SpeakerManagerServiceChild> service = new SpeakerManagerServiceChild();
+
+ gSpeakerManagerServiceChild = service;
+
+ return gSpeakerManagerServiceChild;
+}
+
+// static
+SpeakerManagerService*
+SpeakerManagerServiceChild::GetSpeakerManagerService()
+{
+ MOZ_ASSERT(NS_IsMainThread());
+
+ return gSpeakerManagerServiceChild;
+}
+
+void
+SpeakerManagerServiceChild::ForceSpeaker(bool aEnable, bool aVisible)
+{
+ mVisible = aVisible;
+ mOrgSpeakerStatus = aEnable;
+ ContentChild *cc = ContentChild::GetSingleton();
+ if (cc) {
+ cc->SendSpeakerManagerForceSpeaker(aEnable && aVisible);
+ }
+}
+
+bool
+SpeakerManagerServiceChild::GetSpeakerStatus()
+{
+ ContentChild *cc = ContentChild::GetSingleton();
+ bool status = false;
+ if (cc) {
+ cc->SendSpeakerManagerGetSpeakerStatus(&status);
+ }
+ char propQemu[PROPERTY_VALUE_MAX];
+ property_get("ro.kernel.qemu", propQemu, "");
+ if (!strncmp(propQemu, "1", 1)) {
+ return mOrgSpeakerStatus;
+ }
+ return status;
+}
+
+void
+SpeakerManagerServiceChild::Shutdown()
+{
+ if (gSpeakerManagerServiceChild) {
+ gSpeakerManagerServiceChild = nullptr;
+ }
+}
+
+void
+SpeakerManagerServiceChild::SetAudioChannelActive(bool aIsActive)
+{
+ // Content process and switch to background with no audio and speaker forced.
+ // Then disable speaker
+ for (uint32_t i = 0; i < mRegisteredSpeakerManagers.Length(); i++) {
+ mRegisteredSpeakerManagers[i]->SetAudioChannelActive(aIsActive);
+ }
+}
+
+SpeakerManagerServiceChild::SpeakerManagerServiceChild()
+{
+ MOZ_ASSERT(NS_IsMainThread());
+ RefPtr<AudioChannelService> audioChannelService = AudioChannelService::GetOrCreate();
+ if (audioChannelService) {
+ audioChannelService->RegisterSpeakerManager(this);
+ }
+ MOZ_COUNT_CTOR(SpeakerManagerServiceChild);
+}
+
+SpeakerManagerServiceChild::~SpeakerManagerServiceChild()
+{
+ RefPtr<AudioChannelService> audioChannelService = AudioChannelService::GetOrCreate();
+ if (audioChannelService) {
+ audioChannelService->UnregisterSpeakerManager(this);
+ }
+ MOZ_COUNT_DTOR(SpeakerManagerServiceChild);
+}
+
+void
+SpeakerManagerServiceChild::Notify()
+{
+ for (uint32_t i = 0; i < mRegisteredSpeakerManagers.Length(); i++) {
+ mRegisteredSpeakerManagers[i]->DispatchSimpleEvent(NS_LITERAL_STRING("speakerforcedchange"));
+ }
+}