OLD | NEW |
| (Empty) |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #ifndef MEDIA_AUDIO_AUDIO_FILE_WRITER_H_ | |
6 #define MEDIA_AUDIO_AUDIO_FILE_WRITER_H_ | |
7 | |
8 #include <memory> | |
9 | |
10 namespace base { | |
11 class FilePath; | |
12 } | |
13 | |
14 namespace media { | |
15 | |
16 class AudioBus; | |
17 | |
18 // A writer interface used for writing audio data to file for debugging | |
19 // purposes. | |
20 class AudioFileWriter { | |
21 public: | |
22 virtual ~AudioFileWriter() {} | |
23 | |
24 // Must be called before calling Write() for the first time after creation or | |
25 // Stop() call. Can be called on any sequence; Write() and Stop() must be | |
26 // called on the same sequence as Start(). | |
27 virtual void Start(const base::FilePath& file) = 0; | |
28 | |
29 // Must be called to finish recording. Each call to Start() requires a call to | |
30 // Stop(). Will be automatically called on destruction. | |
31 virtual void Stop() = 0; | |
32 | |
33 // Write |data| to file. | |
34 virtual void Write(std::unique_ptr<AudioBus> data) = 0; | |
35 | |
36 // Returns true if Write() call scheduled at this point will most likely write | |
37 // data to the file, and false if it most likely will be a no-op. The result | |
38 // may be ambigulous if Start() or Stop() is executed at the moment. Can be | |
39 // called from any sequence. | |
40 virtual bool WillWrite() = 0; | |
41 }; | |
42 | |
43 } // namespace media | |
44 | |
45 #endif // MEDIA_AUDIO_AUDIO_FILE_WRITER_H_ | |
OLD | NEW |