gecko/dom/media/eme/DetailedPromise.h
Birunthan Mohanathas e52329c788 Bug 1182996 - Fix and add missing namespace comments. rs=ehsan
The bulk of this commit was generated by running:

  run-clang-tidy.py \
    -checks='-*,llvm-namespace-comment' \
    -header-filter=^/.../mozilla-central/.* \
    -fix
2015-07-13 08:25:42 -07:00

50 lines
1.3 KiB
C++

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=2 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/. */
#ifndef __DetailedPromise_h__
#define __DetailedPromise_h__
#include "mozilla/dom/Promise.h"
namespace mozilla {
namespace dom {
/*
* This is pretty horrible; bug 1160445.
* Extend Promise to add custom DOMException messages on rejection.
* Get rid of this once we've ironed out EME errors in the wild.
*/
class DetailedPromise : public Promise
{
public:
static already_AddRefed<DetailedPromise>
Create(nsIGlobalObject* aGlobal, ErrorResult& aRv);
template <typename T>
void MaybeResolve(const T& aArg)
{
mResponded = true;
Promise::MaybeResolve<T>(aArg);
}
void MaybeReject(nsresult aArg) = delete;
void MaybeReject(nsresult aArg, const nsACString& aReason);
void MaybeReject(ErrorResult& aArg) = delete;
void MaybeReject(ErrorResult&, const nsACString& aReason);
private:
explicit DetailedPromise(nsIGlobalObject* aGlobal);
virtual ~DetailedPromise();
bool mResponded;
};
} // namespace dom
} // namespace mozilla
#endif // __DetailedPromise_h__