2017-02-22 03:53:16 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2017 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SkExecutor_DEFINED
|
|
|
|
#define SkExecutor_DEFINED
|
|
|
|
|
|
|
|
#include <functional>
|
|
|
|
#include <memory>
|
2019-04-23 17:05:21 +00:00
|
|
|
#include "include/core/SkTypes.h"
|
2017-02-22 03:53:16 +00:00
|
|
|
|
2019-02-21 16:26:33 +00:00
|
|
|
class SK_API SkExecutor {
|
2017-02-22 03:53:16 +00:00
|
|
|
public:
|
|
|
|
virtual ~SkExecutor();
|
|
|
|
|
|
|
|
// Create a thread pool SkExecutor with a fixed thread count, by default the number of cores.
|
2020-04-22 12:28:58 +00:00
|
|
|
static std::unique_ptr<SkExecutor> MakeFIFOThreadPool(int threads = 0,
|
|
|
|
bool allowBorrowing = true);
|
|
|
|
static std::unique_ptr<SkExecutor> MakeLIFOThreadPool(int threads = 0,
|
|
|
|
bool allowBorrowing = true);
|
2017-02-22 03:53:16 +00:00
|
|
|
|
|
|
|
// There is always a default SkExecutor available by calling SkExecutor::GetDefault().
|
|
|
|
static SkExecutor& GetDefault();
|
|
|
|
static void SetDefault(SkExecutor*); // Does not take ownership. Not thread safe.
|
|
|
|
|
|
|
|
// Add work to execute.
|
|
|
|
virtual void add(std::function<void(void)>) = 0;
|
|
|
|
|
|
|
|
// If it makes sense for this executor, use this thread to execute work for a little while.
|
|
|
|
virtual void borrow() {}
|
2021-01-26 19:29:06 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
SkExecutor() = default;
|
|
|
|
SkExecutor(const SkExecutor&) = delete;
|
|
|
|
SkExecutor& operator=(const SkExecutor&) = delete;
|
2017-02-22 03:53:16 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif//SkExecutor_DEFINED
|