gecko-dev/dom/clients/manager/ClientOpenWindowOpChild.cpp
Jean-Yves Avenard dc9ee1f6ee Bug 1512456 - P6. Tidy up some MozPromise usage. r=gerald
Make consistent use of MozPromise chaining where possible and remove unnecessary refcount.

Differential Revision: https://phabricator.services.mozilla.com/D14029

--HG--
extra : moz-landing-system : lando
2018-12-11 10:54:48 +00:00

39 lines
1.3 KiB
C++

/* -*- 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 "ClientOpenWindowOpChild.h"
#include "ClientOpenWindowUtils.h"
#include "mozilla/SystemGroup.h"
namespace mozilla {
namespace dom {
RefPtr<ClientOpPromise> ClientOpenWindowOpChild::DoOpenWindow(
const ClientOpenWindowArgs& aArgs) {
return ClientOpenWindowInCurrentProcess(aArgs);
}
void ClientOpenWindowOpChild::ActorDestroy(ActorDestroyReason aReason) {
mPromiseRequestHolder.DisconnectIfExists();
}
void ClientOpenWindowOpChild::Init(const ClientOpenWindowArgs& aArgs) {
DoOpenWindow(aArgs)
->Then(SystemGroup::EventTargetFor(TaskCategory::Other), __func__,
[this](const ClientOpResult& aResult) {
mPromiseRequestHolder.Complete();
PClientOpenWindowOpChild::Send__delete__(this, aResult);
},
[this](nsresult aResult) {
mPromiseRequestHolder.Complete();
PClientOpenWindowOpChild::Send__delete__(this, aResult);
})
->Track(mPromiseRequestHolder);
}
} // namespace dom
} // namespace mozilla