зеркало из https://github.com/mozilla/gecko-dev.git
Backed out changeset 3764e2fac765 (bug 1213517)
This commit is contained in:
Родитель
3366ed3525
Коммит
0d054175d7
|
@ -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 += [
|
||||
|
|
Загрузка…
Ссылка в новой задаче