Backed out changeset 3764e2fac765 (bug 1213517)

This commit is contained in:
Iris Hsiao 2016-07-18 15:42:06 +08:00
Родитель 3366ed3525
Коммит 0d054175d7
4 изменённых файлов: 26 добавлений и 52 удалений

Просмотреть файл

@ -47,7 +47,6 @@
#include "mozilla/Base64.h"
#include "mozilla/ipc/BackgroundChild.h"
#include "mozilla/media/MediaChild.h"
#include "mozilla/media/MediaTaskUtils.h"
#include "MediaTrackConstraints.h"
#include "VideoUtils.h"
#include "Latency.h"

Просмотреть файл

@ -1,50 +0,0 @@
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set sw=2 ts=8 et ft=cpp : */
/* 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 mozilla_MediaTaskUtils_h
#define mozilla_MediaTaskUtils_h
#include "nsThreadUtils.h"
// The main reason this file is separate from MediaUtils.h
#include "base/task.h"
namespace mozilla {
namespace media {
/* media::NewTaskFrom() - Create a Task from a lambda.
*
* Similar to media::NewRunnableFrom() - Create an nsRunnable from a lambda.
*/
template<typename OnRunType>
class LambdaTask : public Runnable
{
public:
explicit LambdaTask(OnRunType&& aOnRun) : mOnRun(Move(aOnRun)) {}
private:
NS_IMETHOD
Run() override
{
mOnRun();
return NS_OK;
}
OnRunType mOnRun;
};
template<typename OnRunType>
already_AddRefed<LambdaTask<OnRunType>>
NewTaskFrom(OnRunType&& aOnRun)
{
typedef LambdaTask<OnRunType> LambdaType;
RefPtr<LambdaType> lambda = new LambdaType(Forward<OnRunType>(aOnRun));
return lambda.forget();
}
} // namespace media
} // namespace mozilla
#endif // mozilla_MediaTaskUtils_h

Просмотреть файл

@ -10,6 +10,7 @@
#include "nsThreadUtils.h"
#include "nsIAsyncShutdown.h"
#include "mozilla/UniquePtr.h"
#include "base/task.h"
namespace mozilla {
namespace media {
@ -145,6 +146,7 @@ private:
};
/* media::NewRunnableFrom() - Create a Runnable from a lambda.
* media::NewTaskFrom() - Create a Task from a lambda.
*
* Passing variables (closures) to an async function is clunky with Runnable:
*
@ -205,6 +207,30 @@ NewRunnableFrom(OnRunType&& aOnRun)
return lambda.forget();
}
template<typename OnRunType>
class LambdaTask : public Runnable
{
public:
explicit LambdaTask(OnRunType&& aOnRun) : mOnRun(Move(aOnRun)) {}
private:
NS_IMETHOD
Run() override
{
mOnRun();
return NS_OK;
}
OnRunType mOnRun;
};
template<typename OnRunType>
already_AddRefed<LambdaTask<OnRunType>>
NewTaskFrom(OnRunType&& aOnRun)
{
typedef LambdaTask<OnRunType> LambdaType;
RefPtr<LambdaType> lambda = new LambdaType(Forward<OnRunType>(aOnRun));
return lambda.forget();
}
/* media::CoatCheck - There and back again. Park an object in exchange for an id.
*
* A common problem with calling asynchronous functions that do work on other

Просмотреть файл

@ -71,7 +71,6 @@ EXPORTS.mozilla.media += ['MediaChild.h',
'MediaSystemResourceMessageUtils.h',
'MediaSystemResourceService.h',
'MediaSystemResourceTypes.h',
'MediaTaskUtils.h',
'MediaUtils.h',
]
UNIFIED_SOURCES += [