| /* |
| * 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_ |