| /* |
| * Copyright (c) 2017 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_PROCESSING_AEC_DUMP_AEC_DUMP_FACTORY_H_ |
| #define MODULES_AUDIO_PROCESSING_AEC_DUMP_AEC_DUMP_FACTORY_H_ |
| |
| #include <memory> |
| #include <string> |
| |
| #include "modules/audio_processing/include/aec_dump.h" |
| #include "rtc_base/system/file_wrapper.h" |
| #include "rtc_base/system/rtc_export.h" |
| |
| namespace rtc { |
| class TaskQueue; |
| } // namespace rtc |
| |
| namespace webrtc { |
| |
| class RTC_EXPORT AecDumpFactory { |
| public: |
| // The |worker_queue| may not be null and must outlive the created |
| // AecDump instance. |max_log_size_bytes == -1| means the log size |
| // will be unlimited. |handle| may not be null. The AecDump takes |
| // responsibility for |handle| and closes it in the destructor. A |
| // non-null return value indicates that the file has been |
| // sucessfully opened. |
| static std::unique_ptr<AecDump> Create(webrtc::FileWrapper file, |
| int64_t max_log_size_bytes, |
| rtc::TaskQueue* worker_queue); |
| static std::unique_ptr<AecDump> Create(std::string file_name, |
| int64_t max_log_size_bytes, |
| rtc::TaskQueue* worker_queue); |
| static std::unique_ptr<AecDump> Create(FILE* handle, |
| int64_t max_log_size_bytes, |
| rtc::TaskQueue* worker_queue); |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // MODULES_AUDIO_PROCESSING_AEC_DUMP_AEC_DUMP_FACTORY_H_ |