|  | /* | 
|  | *  Copyright (c) 2013 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 MODULES_AUDIO_CODING_NETEQ_TOOLS_INPUT_AUDIO_FILE_H_ | 
|  | #define MODULES_AUDIO_CODING_NETEQ_TOOLS_INPUT_AUDIO_FILE_H_ | 
|  |  | 
|  | #include <stdio.h> | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | #include "absl/strings/string_view.h" | 
|  |  | 
|  | namespace webrtc { | 
|  | namespace test { | 
|  |  | 
|  | // Class for handling a looping input audio file. | 
|  | class InputAudioFile { | 
|  | public: | 
|  | explicit InputAudioFile(absl::string_view file_name, bool loop_at_end = true); | 
|  |  | 
|  | virtual ~InputAudioFile(); | 
|  |  | 
|  | InputAudioFile(const InputAudioFile&) = delete; | 
|  | InputAudioFile& operator=(const InputAudioFile&) = delete; | 
|  |  | 
|  | // Reads `samples` elements from source file to `destination`. Returns true | 
|  | // if the read was successful, otherwise false. If the file end is reached, | 
|  | // the file is rewound and reading continues from the beginning. | 
|  | // The output `destination` must have the capacity to hold `samples` elements. | 
|  | virtual bool Read(size_t samples, int16_t* destination); | 
|  |  | 
|  | // Fast-forwards (`samples` > 0) or -backwards (`samples` < 0) the file by the | 
|  | // indicated number of samples. Just like Read(), Seek() starts over at the | 
|  | // beginning of the file if the end is reached. However, seeking backwards | 
|  | // past the beginning of the file is not possible. | 
|  | virtual bool Seek(int samples); | 
|  |  | 
|  | // Creates a multi-channel signal from a mono signal. Each sample is repeated | 
|  | // `channels` times to create an interleaved multi-channel signal where all | 
|  | // channels are identical. The output `destination` must have the capacity to | 
|  | // hold samples * channels elements. Note that `source` and `destination` can | 
|  | // be the same array (i.e., point to the same address). | 
|  | static void DuplicateInterleaved(const int16_t* source, | 
|  | size_t samples, | 
|  | size_t channels, | 
|  | int16_t* destination); | 
|  |  | 
|  | private: | 
|  | FILE* fp_; | 
|  | const bool loop_at_end_; | 
|  | }; | 
|  |  | 
|  | }  // namespace test | 
|  | }  // namespace webrtc | 
|  | #endif  // MODULES_AUDIO_CODING_NETEQ_TOOLS_INPUT_AUDIO_FILE_H_ |