/* * 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 #include #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; using FinalizerTask = absl::AnyInvocable; using BatchTaskWithFinalizer = absl::AnyInvocable() &&>; 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; RTC_NO_UNIQUE_ADDRESS SequenceChecker sequence_checker_; Thread* const target_thread_; std::vector tasks_; }; } // namespace webrtc #endif // PC_SCOPED_OPERATIONS_BATCHER_H_