Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(87)

Unified Diff: media/audio/audio_input_controller.h

Issue 2390153006: Audio input debug recording refactoring to reduce thread hops and simplify object ownership (Closed)
Patch Set: Rebase Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: media/audio/audio_input_controller.h
diff --git a/media/audio/audio_input_controller.h b/media/audio/audio_input_controller.h
index 3a9ed7b6490195b38add9b74adf06d4885c1d14b..86f7cb3d8af4150e775f24cd1a46102308985868 100644
--- a/media/audio/audio_input_controller.h
+++ b/media/audio/audio_input_controller.h
@@ -185,6 +185,7 @@ class MEDIA_EXPORT AudioInputController
const std::string& device_id,
// External synchronous writer for audio controller.
SyncWriter* sync_writer,
+ std::unique_ptr<AudioInputWriter> debug_writer,
UserInputMonitor* user_input_monitor,
const bool agc_is_enabled);
@@ -199,6 +200,7 @@ class MEDIA_EXPORT AudioInputController
AudioInputStream* stream,
// External synchronous writer for audio controller.
SyncWriter* sync_writer,
+ std::unique_ptr<AudioInputWriter> debug_writer,
UserInputMonitor* user_input_monitor);
// Starts recording using the created audio input stream.
@@ -230,11 +232,10 @@ class MEDIA_EXPORT AudioInputController
bool SharedMemoryAndSyncSocketMode() const { return sync_writer_ != NULL; }
// Enable debug recording of audio input.
- void EnableDebugRecording(AudioInputWriter* input_writer);
+ void EnableDebugRecording(const base::FilePath& file_name);
- // Disbale debug recording of audio input. Must be called before owner of
- // |input_writer| deletes it.
- void DisableDebugRecording(const base::Closure& callback);
+ // Disable debug recording of audio input.
+ void DisableDebugRecording();
protected:
friend class base::RefCountedThreadSafe<AudioInputController>;
@@ -288,6 +289,7 @@ class MEDIA_EXPORT AudioInputController
AudioInputController(EventHandler* handler,
SyncWriter* sync_writer,
+ std::unique_ptr<AudioInputWriter> debug_writer,
UserInputMonitor* user_input_monitor,
const bool agc_is_enabled);
~AudioInputController() override;
@@ -325,7 +327,7 @@ class MEDIA_EXPORT AudioInputController
// Enable and disable debug recording of audio input. Called on the audio
// thread.
- void DoEnableDebugRecording(AudioInputWriter* input_writer);
+ void DoEnableDebugRecording(const base::FilePath& file_name);
void DoDisableDebugRecording();
// Called on the audio thread.
@@ -390,7 +392,7 @@ class MEDIA_EXPORT AudioInputController
base::TimeTicks low_latency_create_time_;
// Used for audio debug recordings. Accessed on audio thread.
- AudioInputWriter* input_writer_;
+ const std::unique_ptr<AudioInputWriter> debug_writer_;
private:
DISALLOW_COPY_AND_ASSIGN(AudioInputController);
« no previous file with comments | « content/browser/renderer_host/media/audio_input_renderer_host.cc ('k') | media/audio/audio_input_controller.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698