diff options
Diffstat (limited to 'media/audio/mac')
-rw-r--r-- | media/audio/mac/audio_input_mac.cc | 6 | ||||
-rw-r--r-- | media/audio/mac/audio_input_mac.h | 11 | ||||
-rw-r--r-- | media/audio/mac/audio_manager_mac.h | 18 |
3 files changed, 22 insertions, 13 deletions
diff --git a/media/audio/mac/audio_input_mac.cc b/media/audio/mac/audio_input_mac.cc index e96277f..c59eb61 100644 --- a/media/audio/mac/audio_input_mac.cc +++ b/media/audio/mac/audio_input_mac.cc @@ -70,11 +70,17 @@ void PCMQueueInAudioInputStream::Start(AudioInputCallback* callback) { OSStatus err = AudioQueueStart(audio_queue_, NULL); if (err != noErr) HandleError(err); + else + manager_->IncreaseActiveInputStreamCount(); } void PCMQueueInAudioInputStream::Stop() { if (!audio_queue_) return; + // Stop is always called before Close. In case of error, this will be + // also called when closing the input controller. + manager_->DecreaseActiveInputStreamCount(); + // We request a synchronous stop, so the next call can take some time. In // the windows implementation we block here as well. OSStatus err = AudioQueueStop(audio_queue_, true); diff --git a/media/audio/mac/audio_input_mac.h b/media/audio/mac/audio_input_mac.h index 1796d82..7569c36 100644 --- a/media/audio/mac/audio_input_mac.h +++ b/media/audio/mac/audio_input_mac.h @@ -1,4 +1,4 @@ -// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. @@ -8,6 +8,7 @@ #include <AudioToolbox/AudioQueue.h> #include <AudioToolbox/AudioFormat.h> +#include "base/compiler_specific.h" #include "media/audio/audio_io.h" #include "media/audio/audio_parameters.h" @@ -23,10 +24,10 @@ class PCMQueueInAudioInputStream : public AudioInputStream { virtual ~PCMQueueInAudioInputStream(); // Implementation of AudioInputStream. - virtual bool Open(); - virtual void Start(AudioInputCallback* callback); - virtual void Stop(); - virtual void Close(); + virtual bool Open() OVERRIDE; + virtual void Start(AudioInputCallback* callback) OVERRIDE; + virtual void Stop() OVERRIDE; + virtual void Close() OVERRIDE; private: // Issue the OnError to |callback_|; diff --git a/media/audio/mac/audio_manager_mac.h b/media/audio/mac/audio_manager_mac.h index a8ffced..b7c29bc 100644 --- a/media/audio/mac/audio_manager_mac.h +++ b/media/audio/mac/audio_manager_mac.h @@ -1,4 +1,4 @@ -// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. @@ -6,6 +6,7 @@ #define MEDIA_AUDIO_MAC_AUDIO_MANAGER_MAC_H_ #include "base/basictypes.h" +#include "base/compiler_specific.h" #include "media/audio/audio_manager_base.h" class PCMQueueInAudioInputStream; @@ -19,15 +20,16 @@ class AudioManagerMac : public AudioManagerBase { AudioManagerMac(); // Implementation of AudioManager. - virtual bool HasAudioOutputDevices(); - virtual bool HasAudioInputDevices(); - virtual void GetAudioInputDeviceNames(media::AudioDeviceNames* device_names); + virtual bool HasAudioOutputDevices() OVERRIDE; + virtual bool HasAudioInputDevices() OVERRIDE; + virtual void GetAudioInputDeviceNames(media::AudioDeviceNames* device_names) + OVERRIDE; virtual AudioOutputStream* MakeAudioOutputStream( - const AudioParameters& params); + const AudioParameters& params) OVERRIDE; virtual AudioInputStream* MakeAudioInputStream( - const AudioParameters& params); - virtual void MuteAll(); - virtual void UnMuteAll(); + const AudioParameters& params) OVERRIDE; + virtual void MuteAll() OVERRIDE; + virtual void UnMuteAll() OVERRIDE; // Mac-only method to free the streams created by above facoty methods. // They are called internally by the respective audio stream when it has |