blob: 2c481d4407140596fe868457193f57a09dabafcc [file] [log] [blame]
/*
* Copyright 2026 The WebRTC project authors. All Rights Reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#ifndef PC_SCOPED_OPERATIONS_BATCHER_H_
#define PC_SCOPED_OPERATIONS_BATCHER_H_
#include <variant>
#include <vector>
#include "absl/functional/any_invocable.h"
#include "api/rtc_error.h"
#include "api/sequence_checker.h"
#include "rtc_base/system/no_unique_address.h"
#include "rtc_base/thread.h"
namespace webrtc {
// Batches operations to be executed synchronously on a target thread.
//
// ScopedOperationsBatcher must only be created on the signaling thread.
//
// When the batcher goes out of scope (or `Run()` is explicitly called), it
// executes all queued tasks in one or more `BlockingCall`s to the target
// thread. If the target thread requests a yield during batch execution, the
// batcher will cooperatively yield the thread and resume execution in a
// subsequent `BlockingCall`.
//
// Tasks can either have a `void` return type, or return a new task or return an
// error.
// Any tasks returned by the executed worker thread tasks are collected
// and subsequently executed on the calling thread (typically the signaling
// thread) after the worker thread operations have completed.
class ScopedOperationsBatcher {
public:
using SimpleBatchTask = absl::AnyInvocable<void() &&>;
using FinalizerTask = absl::AnyInvocable<void() &&>;
using BatchTaskWithFinalizer =
absl::AnyInvocable<RTCErrorOr<FinalizerTask>() &&>;
explicit ScopedOperationsBatcher(Thread* target_thread);
~ScopedOperationsBatcher();
RTCError Run();
// Queues non-nullptr tasks to be executed on the target thread when the
// ScopedOperationsBatcher goes out of scope.
void Add(SimpleBatchTask task);
void AddWithFinalizer(BatchTaskWithFinalizer task);
private:
using BatchedTask = std::variant<SimpleBatchTask, BatchTaskWithFinalizer>;
RTC_NO_UNIQUE_ADDRESS SequenceChecker sequence_checker_;
Thread* const target_thread_;
std::vector<BatchedTask> tasks_;
};
} // namespace webrtc
#endif // PC_SCOPED_OPERATIONS_BATCHER_H_