summaryrefslogtreecommitdiffstats
path: root/dom/presentation/PresentationConnectionList.cpp
diff options
context:
space:
mode:
authorwolfbeast <mcwerewolf@wolfbeast.com>2020-04-14 21:49:04 +0200
committerwolfbeast <mcwerewolf@wolfbeast.com>2020-04-14 21:49:04 +0200
commit39dac57259cff8b61db0b22cb2ad0a8adb02692e (patch)
tree52a026cc8c22793eb17fd0f5e22adce1ae08a1dd /dom/presentation/PresentationConnectionList.cpp
parenta1cce3b2b00bbd9f4983013ddd8934a7bccb9e99 (diff)
parentc2d9ab62f3d097c9e0e00184cab1f546554f5eaa (diff)
downloadUXP-39dac57259cff8b61db0b22cb2ad0a8adb02692e.tar
UXP-39dac57259cff8b61db0b22cb2ad0a8adb02692e.tar.gz
UXP-39dac57259cff8b61db0b22cb2ad0a8adb02692e.tar.lz
UXP-39dac57259cff8b61db0b22cb2ad0a8adb02692e.tar.xz
UXP-39dac57259cff8b61db0b22cb2ad0a8adb02692e.zip
Merge branch 'redwood' into 28.9-platform
Diffstat (limited to 'dom/presentation/PresentationConnectionList.cpp')
-rw-r--r--dom/presentation/PresentationConnectionList.cpp125
1 files changed, 0 insertions, 125 deletions
diff --git a/dom/presentation/PresentationConnectionList.cpp b/dom/presentation/PresentationConnectionList.cpp
deleted file mode 100644
index 0e0e7696c..000000000
--- a/dom/presentation/PresentationConnectionList.cpp
+++ /dev/null
@@ -1,125 +0,0 @@
-/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* vim:set ts=2 sw=2 sts=2 et cindent: */
-/* 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 "PresentationConnectionList.h"
-
-#include "mozilla/AsyncEventDispatcher.h"
-#include "mozilla/dom/PresentationConnectionAvailableEvent.h"
-#include "mozilla/dom/PresentationConnectionListBinding.h"
-#include "mozilla/dom/Promise.h"
-#include "PresentationConnection.h"
-
-namespace mozilla {
-namespace dom {
-
-NS_IMPL_CYCLE_COLLECTION_INHERITED(PresentationConnectionList, DOMEventTargetHelper,
- mGetConnectionListPromise,
- mConnections)
-
-NS_IMPL_ADDREF_INHERITED(PresentationConnectionList, DOMEventTargetHelper)
-NS_IMPL_RELEASE_INHERITED(PresentationConnectionList, DOMEventTargetHelper)
-
-NS_INTERFACE_MAP_BEGIN_CYCLE_COLLECTION_INHERITED(PresentationConnectionList)
-NS_INTERFACE_MAP_END_INHERITING(DOMEventTargetHelper)
-
-PresentationConnectionList::PresentationConnectionList(nsPIDOMWindowInner* aWindow,
- Promise* aPromise)
- : DOMEventTargetHelper(aWindow)
- , mGetConnectionListPromise(aPromise)
-{
- MOZ_ASSERT(aWindow);
- MOZ_ASSERT(aPromise);
-}
-
-/* virtual */ JSObject*
-PresentationConnectionList::WrapObject(JSContext* aCx,
- JS::Handle<JSObject*> aGivenProto)
-{
- return PresentationConnectionListBinding::Wrap(aCx, this, aGivenProto);
-}
-
-void
-PresentationConnectionList::GetConnections(
- nsTArray<RefPtr<PresentationConnection>>& aConnections) const
-{
- aConnections = mConnections;
-}
-
-nsresult
-PresentationConnectionList::DispatchConnectionAvailableEvent(
- PresentationConnection* aConnection)
-{
- PresentationConnectionAvailableEventInit init;
- init.mConnection = aConnection;
-
- RefPtr<PresentationConnectionAvailableEvent> event =
- PresentationConnectionAvailableEvent::Constructor(
- this,
- NS_LITERAL_STRING("connectionavailable"),
- init);
-
- if (NS_WARN_IF(!event)) {
- return NS_ERROR_FAILURE;
- }
- event->SetTrusted(true);
-
- RefPtr<AsyncEventDispatcher> asyncDispatcher =
- new AsyncEventDispatcher(this, event);
- return asyncDispatcher->PostDOMEvent();
-}
-
-PresentationConnectionList::ConnectionArrayIndex
-PresentationConnectionList::FindConnectionById(
- const nsAString& aId)
-{
- for (ConnectionArrayIndex i = 0; i < mConnections.Length(); i++) {
- nsAutoString id;
- mConnections[i]->GetId(id);
- if (id == nsAutoString(aId)) {
- return i;
- }
- }
-
- return mConnections.NoIndex;
-}
-
-void
-PresentationConnectionList::NotifyStateChange(const nsAString& aSessionId,
- PresentationConnection* aConnection)
-{
- if (!aConnection) {
- MOZ_ASSERT(false, "PresentationConnection can not be null.");
- return;
- }
-
- bool connectionFound =
- FindConnectionById(aSessionId) != mConnections.NoIndex ? true : false;
-
- PresentationConnectionListBinding::ClearCachedConnectionsValue(this);
- switch (aConnection->State()) {
- case PresentationConnectionState::Connected:
- if (!connectionFound) {
- mConnections.AppendElement(aConnection);
- if (mGetConnectionListPromise) {
- mGetConnectionListPromise->MaybeResolve(this);
- mGetConnectionListPromise = nullptr;
- return;
- }
- }
- DispatchConnectionAvailableEvent(aConnection);
- break;
- case PresentationConnectionState::Terminated:
- if (connectionFound) {
- mConnections.RemoveElement(aConnection);
- }
- break;
- default:
- break;
- }
-}
-
-} // namespace dom
-} // namespace mozilla