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

Side by Side Diff: media/audio/pulse/audio_manager_pulse.h

Issue 23453022: Add AudioManager::GetAudioOutputDeviceNames and implement for pulseaudio. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@mediaCleanups
Patch Set: Add missing override. Created 7 years, 3 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 unified diff | Download patch
« no previous file with comments | « media/audio/mock_audio_manager.cc ('k') | media/audio/pulse/audio_manager_pulse.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef MEDIA_AUDIO_PULSE_AUDIO_MANAGER_PULSE_H_ 5 #ifndef MEDIA_AUDIO_PULSE_AUDIO_MANAGER_PULSE_H_
6 #define MEDIA_AUDIO_PULSE_AUDIO_MANAGER_PULSE_H_ 6 #define MEDIA_AUDIO_PULSE_AUDIO_MANAGER_PULSE_H_
7 7
8 #include <pulse/pulseaudio.h> 8 #include <pulse/pulseaudio.h>
9 #include <string> 9 #include <string>
10 10
11 #include "base/compiler_specific.h" 11 #include "base/compiler_specific.h"
12 #include "base/memory/ref_counted.h" 12 #include "base/memory/ref_counted.h"
13 #include "media/audio/audio_manager_base.h" 13 #include "media/audio/audio_manager_base.h"
14 14
15 namespace media { 15 namespace media {
16 16
17 class MEDIA_EXPORT AudioManagerPulse : public AudioManagerBase { 17 class MEDIA_EXPORT AudioManagerPulse : public AudioManagerBase {
18 public: 18 public:
19 AudioManagerPulse(); 19 AudioManagerPulse();
20 virtual ~AudioManagerPulse(); 20 virtual ~AudioManagerPulse();
21 21
22 static AudioManager* Create(); 22 static AudioManager* Create();
23 23
24 // Implementation of AudioManager. 24 // Implementation of AudioManager.
25 virtual bool HasAudioOutputDevices() OVERRIDE; 25 virtual bool HasAudioOutputDevices() OVERRIDE;
26 virtual bool HasAudioInputDevices() OVERRIDE; 26 virtual bool HasAudioInputDevices() OVERRIDE;
27 virtual void ShowAudioInputSettings() OVERRIDE; 27 virtual void ShowAudioInputSettings() OVERRIDE;
28 virtual void GetAudioInputDeviceNames(media::AudioDeviceNames* device_names) 28 virtual void GetAudioInputDeviceNames(media::AudioDeviceNames* device_names)
29 OVERRIDE; 29 OVERRIDE;
30 virtual void GetAudioOutputDeviceNames(media::AudioDeviceNames* device_names)
31 OVERRIDE;
30 virtual AudioParameters GetInputStreamParameters( 32 virtual AudioParameters GetInputStreamParameters(
31 const std::string& device_id) OVERRIDE; 33 const std::string& device_id) OVERRIDE;
32 34
33 // Implementation of AudioManagerBase. 35 // Implementation of AudioManagerBase.
34 virtual AudioOutputStream* MakeLinearOutputStream( 36 virtual AudioOutputStream* MakeLinearOutputStream(
35 const AudioParameters& params) OVERRIDE; 37 const AudioParameters& params) OVERRIDE;
36 virtual AudioOutputStream* MakeLowLatencyOutputStream( 38 virtual AudioOutputStream* MakeLowLatencyOutputStream(
37 const AudioParameters& params, 39 const AudioParameters& params,
38 const std::string& device_id, 40 const std::string& device_id,
39 const std::string& input_device_id) OVERRIDE; 41 const std::string& input_device_id) OVERRIDE;
40 virtual AudioInputStream* MakeLinearInputStream( 42 virtual AudioInputStream* MakeLinearInputStream(
41 const AudioParameters& params, const std::string& device_id) OVERRIDE; 43 const AudioParameters& params, const std::string& device_id) OVERRIDE;
42 virtual AudioInputStream* MakeLowLatencyInputStream( 44 virtual AudioInputStream* MakeLowLatencyInputStream(
43 const AudioParameters& params, const std::string& device_id) OVERRIDE; 45 const AudioParameters& params, const std::string& device_id) OVERRIDE;
44 46
45 protected: 47 protected:
46 virtual AudioParameters GetPreferredOutputStreamParameters( 48 virtual AudioParameters GetPreferredOutputStreamParameters(
47 const std::string& output_device_id, 49 const std::string& output_device_id,
48 const AudioParameters& input_params) OVERRIDE; 50 const AudioParameters& input_params) OVERRIDE;
49 51
50 private: 52 private:
51 bool Init(); 53 bool Init();
52 void DestroyPulse(); 54 void DestroyPulse();
53 55
56 void GetAudioDeviceNames(bool input, media::AudioDeviceNames* device_names);
57
54 // Callback to get the devices' info like names, used by GetInputDevices(). 58 // Callback to get the devices' info like names, used by GetInputDevices().
55 static void InputDevicesInfoCallback(pa_context* context, 59 static void InputDevicesInfoCallback(pa_context* context,
56 const pa_source_info* info, 60 const pa_source_info* info,
57 int error, void* user_data); 61 int error, void* user_data);
58 static void OutputDevicesInfoCallback(pa_context* context, 62 static void OutputDevicesInfoCallback(pa_context* context,
59 const pa_sink_info* info, 63 const pa_sink_info* info,
60 int error, void* user_data); 64 int error, void* user_data);
61 65
62 // Callback to get the native sample rate of PulseAudio, used by 66 // Callback to get the native sample rate of PulseAudio, used by
63 // GetNativeSampleRate(). 67 // GetNativeSampleRate().
(...skipping 16 matching lines...) Expand all
80 pa_context* input_context_; 84 pa_context* input_context_;
81 AudioDeviceNames* devices_; 85 AudioDeviceNames* devices_;
82 int native_input_sample_rate_; 86 int native_input_sample_rate_;
83 87
84 DISALLOW_COPY_AND_ASSIGN(AudioManagerPulse); 88 DISALLOW_COPY_AND_ASSIGN(AudioManagerPulse);
85 }; 89 };
86 90
87 } // namespace media 91 } // namespace media
88 92
89 #endif // MEDIA_AUDIO_PULSE_AUDIO_MANAGER_PULSE_H_ 93 #endif // MEDIA_AUDIO_PULSE_AUDIO_MANAGER_PULSE_H_
OLDNEW
« no previous file with comments | « media/audio/mock_audio_manager.cc ('k') | media/audio/pulse/audio_manager_pulse.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698