webrtc/api/neteq/delay_manager_interface.h
Diep Bui 1542bb1859 Create delay manager API in NetEq
Bug: webrtc:428147754
Change-Id: Idf6d7534add0b1b096a9997d0c1a3cec00e31768
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/398280
Commit-Queue: Diep Bui <diepbp@webrtc.org>
Reviewed-by: Jakob Ivarsson‎ <jakobi@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#45037}
2025-06-27 06:46:43 -07:00

41 lines
1.3 KiB
C++

/*
* Copyright (c) 2019 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 API_NETEQ_DELAY_MANAGER_INTERFACE_H_
#define API_NETEQ_DELAY_MANAGER_INTERFACE_H_
#include "api/neteq/neteq_controller.h"
namespace webrtc {
// Interface for the delay manager.
class DelayManagerInterface {
public:
virtual ~DelayManagerInterface() = default;
// Updates the delay manager that a new packet arrived with delay
// `arrival_delay_ms`. This updates the statistics and a new target buffer
// level is calculated. The `reordered` flag indicates if the packet was
// reordered. The `info` argument contains information about the packet.
virtual void Update(int arrival_delay_ms,
bool reordered,
NetEqController::PacketArrivedInfo info) = 0;
// Resets all state.
virtual void Reset() = 0;
// Gets the target buffer level in milliseconds.
virtual int TargetDelayMs() const = 0;
};
} // namespace webrtc
#endif // API_NETEQ_DELAY_MANAGER_INTERFACE_H_