diff options
author | hclam@chromium.org <hclam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-08-11 19:09:28 +0000 |
---|---|---|
committer | hclam@chromium.org <hclam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-08-11 19:09:28 +0000 |
commit | 3ab20f3c57298ee24e15ec802b7e4b2e33598ca0 (patch) | |
tree | a10aa65bd80c00b2422f2ed94576677f1b5d2909 | |
parent | 5e6aacc34dd3f8e9b6483e897fb7da1cf582edcd (diff) | |
download | chromium_src-3ab20f3c57298ee24e15ec802b7e4b2e33598ca0.zip chromium_src-3ab20f3c57298ee24e15ec802b7e4b2e33598ca0.tar.gz chromium_src-3ab20f3c57298ee24e15ec802b7e4b2e33598ca0.tar.bz2 |
AudioRendererHost send ViewMsg_AudioStreamState
AudioRendererHost should use ViewMsg_AudioStreamState to
notify renderer of its state instead of AudioOutputStream::State.
The enum of AudioOutputStream::State is not used anywhere, thus
removed.
TEST=unit_tests --gtest_filter=Audio*
Review URL: http://codereview.chromium.org/165255
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@23061 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/renderer_host/audio_renderer_host.cc | 60 | ||||
-rw-r--r-- | chrome/browser/renderer_host/audio_renderer_host.h | 27 | ||||
-rw-r--r-- | chrome/browser/renderer_host/audio_renderer_host_unittest.cc | 20 | ||||
-rw-r--r-- | chrome/common/render_messages.h | 46 | ||||
-rw-r--r-- | chrome/common/render_messages_internal.h | 8 | ||||
-rw-r--r-- | chrome/renderer/audio_message_filter.cc | 5 | ||||
-rw-r--r-- | chrome/renderer/audio_message_filter.h | 7 | ||||
-rw-r--r-- | chrome/renderer/audio_message_filter_unittest.cc | 24 | ||||
-rw-r--r-- | chrome/renderer/media/audio_renderer_impl.cc | 15 | ||||
-rw-r--r-- | chrome/renderer/media/audio_renderer_impl.h | 2 | ||||
-rw-r--r-- | media/audio/audio_output.h | 9 |
11 files changed, 108 insertions, 115 deletions
diff --git a/chrome/browser/renderer_host/audio_renderer_host.cc b/chrome/browser/renderer_host/audio_renderer_host.cc index 495a8ea..962b570 100644 --- a/chrome/browser/renderer_host/audio_renderer_host.cc +++ b/chrome/browser/renderer_host/audio_renderer_host.cc @@ -68,15 +68,14 @@ AudioRendererHost::IPCAudioSource::IPCAudioSource( hardware_packet_size_(hardware_packet_size), decoded_packet_size_(decoded_packet_size), buffer_capacity_(buffer_capacity), - state_(AudioOutputStream::STATE_CREATED), + state_(kCreated), push_source_(hardware_packet_size), outstanding_request_(false), last_copied_bytes_(0) { } AudioRendererHost::IPCAudioSource::~IPCAudioSource() { - DCHECK(AudioOutputStream::STATE_STOPPED == state_ || - AudioOutputStream::STATE_CREATED == state_); + DCHECK(kClosed == state_ || kCreated == state_); } // static @@ -158,29 +157,29 @@ AudioRendererHost::IPCAudioSource* delete source; } - host->SendErrorMessage(route_id, stream_id, 0); + host->SendErrorMessage(route_id, stream_id); return NULL; } -void AudioRendererHost::IPCAudioSource::Start() { +void AudioRendererHost::IPCAudioSource::Play() { // We can start from created or paused state. - if (!stream_ || - (state_ != AudioOutputStream::STATE_CREATED && - state_ != AudioOutputStream::STATE_PAUSED)) + if (!stream_ || (state_ != kCreated && state_ != kPaused)) return; stream_->Start(this); // Update the state and notify renderer. - state_ = AudioOutputStream::STATE_STARTED; + state_ = kPaused; + + ViewMsg_AudioStreamState state; + state.state = ViewMsg_AudioStreamState::kPlaying; host_->Send(new ViewMsg_NotifyAudioStreamStateChanged( - route_id_, stream_id_, state_, 0)); + route_id_, stream_id_, state)); } void AudioRendererHost::IPCAudioSource::Pause() { // We can pause from started state. - if (!stream_ || - state_ != AudioOutputStream::STATE_STARTED) + if (!stream_ || state_ != kPlaying) return; // TODO(hclam): use stop to simulate pause, make sure the AudioOutpusStream @@ -188,9 +187,12 @@ void AudioRendererHost::IPCAudioSource::Pause() { stream_->Stop(); // Update the state and notify renderer. - state_ = AudioOutputStream::STATE_PAUSED; + state_ = kPaused; + + ViewMsg_AudioStreamState state; + state.state = ViewMsg_AudioStreamState::kPaused; host_->Send(new ViewMsg_NotifyAudioStreamStateChanged( - route_id_, stream_id_, state_, 0)); + route_id_, stream_id_, state)); } void AudioRendererHost::IPCAudioSource::Close() { @@ -203,7 +205,7 @@ void AudioRendererHost::IPCAudioSource::Close() { stream_ = NULL; // Update the current state. - state_ = AudioOutputStream::STATE_STOPPED; + state_ = kClosed; } void AudioRendererHost::IPCAudioSource::SetVolume(double left, double right) { @@ -243,7 +245,7 @@ void AudioRendererHost::IPCAudioSource::OnClose(AudioOutputStream* stream) { void AudioRendererHost::IPCAudioSource::OnError(AudioOutputStream* stream, int code) { - host_->SendErrorMessage(route_id_, stream_id_, code); + host_->SendErrorMessage(route_id_, stream_id_); // The following method call would cause this object to be destroyed on IO // thread. host_->DestroySource(this); @@ -379,7 +381,7 @@ bool AudioRendererHost::OnMessageReceived(const IPC::Message& message, IPC_BEGIN_MESSAGE_MAP_EX(AudioRendererHost, message, *message_was_ok) IPC_MESSAGE_HANDLER(ViewHostMsg_CreateAudioStream, OnCreateStream) - IPC_MESSAGE_HANDLER(ViewHostMsg_StartAudioStream, OnStartStream) + IPC_MESSAGE_HANDLER(ViewHostMsg_PlayAudioStream, OnPlayStream) IPC_MESSAGE_HANDLER(ViewHostMsg_PauseAudioStream, OnPauseStream) IPC_MESSAGE_HANDLER(ViewHostMsg_CloseAudioStream, OnCloseStream) IPC_MESSAGE_HANDLER(ViewHostMsg_NotifyAudioPacketReady, OnNotifyPacketReady) @@ -394,7 +396,7 @@ bool AudioRendererHost::IsAudioRendererHostMessage( const IPC::Message& message) { switch (message.type()) { case ViewHostMsg_CreateAudioStream::ID: - case ViewHostMsg_StartAudioStream::ID: + case ViewHostMsg_PlayAudioStream::ID: case ViewHostMsg_PauseAudioStream::ID: case ViewHostMsg_CloseAudioStream::ID: case ViewHostMsg_NotifyAudioPacketReady::ID: @@ -432,17 +434,17 @@ void AudioRendererHost::OnCreateStream( std::make_pair( SourceID(source->route_id(), source->stream_id()), source)); } else { - SendErrorMessage(msg.routing_id(), stream_id, 0); + SendErrorMessage(msg.routing_id(), stream_id); } } -void AudioRendererHost::OnStartStream(const IPC::Message& msg, int stream_id) { +void AudioRendererHost::OnPlayStream(const IPC::Message& msg, int stream_id) { DCHECK(MessageLoop::current() == io_loop_); IPCAudioSource* source = Lookup(msg.routing_id(), stream_id); if (source) { - source->Start(); + source->Play(); } else { - SendErrorMessage(msg.routing_id(), stream_id, 0); + SendErrorMessage(msg.routing_id(), stream_id); } } @@ -452,7 +454,7 @@ void AudioRendererHost::OnPauseStream(const IPC::Message& msg, int stream_id) { if (source) { source->Pause(); } else { - SendErrorMessage(msg.routing_id(), stream_id, 0); + SendErrorMessage(msg.routing_id(), stream_id); } } @@ -471,7 +473,7 @@ void AudioRendererHost::OnSetVolume(const IPC::Message& msg, int stream_id, if (source) { source->SetVolume(left_channel, right_channel); } else { - SendErrorMessage(msg.routing_id(), stream_id, 0); + SendErrorMessage(msg.routing_id(), stream_id); } } @@ -481,7 +483,7 @@ void AudioRendererHost::OnGetVolume(const IPC::Message& msg, int stream_id) { if (source) { source->GetVolume(); } else { - SendErrorMessage(msg.routing_id(), stream_id, 0); + SendErrorMessage(msg.routing_id(), stream_id); } } @@ -492,7 +494,7 @@ void AudioRendererHost::OnNotifyPacketReady(const IPC::Message& msg, if (source) { source->NotifyPacketReady(packet_size); } else { - SendErrorMessage(msg.routing_id(), stream_id, 0); + SendErrorMessage(msg.routing_id(), stream_id); } #ifdef IPC_MESSAGE_LOG_ENABLED if (IPC::Logging::current() && IPC::Logging::current()->Enabled()) { @@ -571,9 +573,11 @@ void AudioRendererHost::Send(IPC::Message* message) { } void AudioRendererHost::SendErrorMessage(int32 render_view_id, - int32 stream_id, int info) { + int32 stream_id) { + ViewMsg_AudioStreamState state; + state.state = ViewMsg_AudioStreamState::kError; Send(new ViewMsg_NotifyAudioStreamStateChanged( - render_view_id, stream_id, AudioOutputStream::STATE_ERROR, info)); + render_view_id, stream_id, state)); } void AudioRendererHost::DestroySource(IPCAudioSource* source) { diff --git a/chrome/browser/renderer_host/audio_renderer_host.h b/chrome/browser/renderer_host/audio_renderer_host.h index 9326cf7..de193519 100644 --- a/chrome/browser/renderer_host/audio_renderer_host.h +++ b/chrome/browser/renderer_host/audio_renderer_host.h @@ -31,7 +31,7 @@ // .---------> [ Stopped ] <--------. // | ^ | // | | | -// *[ Created ] --> [ Started ] --> [ Paused ] +// *[ Created ] --> [ Playing ] --> [ Paused ] // ^ | // | | // `-----------------` @@ -48,8 +48,8 @@ // | <<<<<< RequestAudioPacket <<<<<<<< | // | >>>>>>> AudioPacketReady >>>>>>>>> | // | | -// | >>>>>>>>>>>>> Start >>>>>>>>>>>>>> | -// | <<<<<<<<<<<< Started <<<<<<<<<<<<< | time +// | >>>>>>>>>>>>> Play >>>>>>>>>>>>>>> | +// | <<<<<<<<<<<< Playing <<<<<<<<<<<<< | time // | ... | // | <<<<<< RequestAudioPacket <<<<<<<< | // | >>>>>>> AudioPacketReady >>>>>>>>> | @@ -126,9 +126,7 @@ class AudioRendererHost : public base::RefCountedThreadSafe<AudioRendererHost> { virtual void Send(IPC::Message* message); // A helper method for sending error IPC messages. - virtual void SendErrorMessage(int32 render_view_id, - int32 stream_id, - int info); + virtual void SendErrorMessage(int32 render_view_id, int32 stream_id); // A helper method for calling OnDestroySource on IO thread. virtual void DestroySource(IPCAudioSource* source); @@ -143,6 +141,15 @@ class AudioRendererHost : public base::RefCountedThreadSafe<AudioRendererHost> { // via IPC. class IPCAudioSource : public AudioOutputStream::AudioSourceCallback { public: + // Internal state of the source. + enum State { + kCreated, + kPlaying, + kPaused, + kClosed, + kError, + }; + // Factory method for creating an IPCAudioSource, returns NULL if failed. // The IPCAudioSource object will have an internal state of // AudioOutputStream::STATE_CREATED after creation. @@ -170,7 +177,7 @@ class AudioRendererHost : public base::RefCountedThreadSafe<AudioRendererHost> { // Starts the playback of this audio output stream. The internal state will // be updated to AudioOutputStream::STATE_STARTED and the state update is // sent to the renderer. - void Start(); + void Play(); // Pause this audio output stream. The audio output stream will stop // reading from the |push_source_|. The internal state will be updated @@ -236,7 +243,7 @@ class AudioRendererHost : public base::RefCountedThreadSafe<AudioRendererHost> { size_t decoded_packet_size_; size_t buffer_capacity_; - AudioOutputStream::State state_; + State state_; base::SharedMemory shared_memory_; PushSource push_source_; @@ -269,11 +276,11 @@ class AudioRendererHost : public base::RefCountedThreadSafe<AudioRendererHost> { const ViewHostMsg_Audio_CreateStream& params); // Starts buffering for the audio output stream. Delegates the start method - // call to the corresponding IPCAudioSource::Start(). + // call to the corresponding IPCAudioSource::Play(). // ViewMsg_NotifyAudioStreamStateChanged with // AudioOutputStream::AUDIO_STREAM_ERROR is sent back to renderer if the // required IPCAudioSource is not found. - void OnStartStream(const IPC::Message& msg, int stream_id); + void OnPlayStream(const IPC::Message& msg, int stream_id); // Pauses the audio output stream. Delegates the pause method call to the // corresponding IPCAudioSource::Pause(), diff --git a/chrome/browser/renderer_host/audio_renderer_host_unittest.cc b/chrome/browser/renderer_host/audio_renderer_host_unittest.cc index 4a3f103..5418331 100644 --- a/chrome/browser/renderer_host/audio_renderer_host_unittest.cc +++ b/chrome/browser/renderer_host/audio_renderer_host_unittest.cc @@ -14,6 +14,7 @@ using ::testing::_; using ::testing::DoAll; using ::testing::InSequence; using ::testing::Return; +using ::testing::SaveArg; using ::testing::SetArgumentPointee; namespace { @@ -43,9 +44,9 @@ class MockAudioRendererHost : public AudioRendererHost { MOCK_METHOD3(OnStreamCreated, void(int routing_id, int stream_id, int length)); - MOCK_METHOD4(OnStreamStateChanged, + MOCK_METHOD3(OnStreamStateChanged, void(int routing_id, int stream_id, - AudioOutputStream::State state, int info)); + ViewMsg_AudioStreamState state)); MOCK_METHOD4(OnStreamVolume, void(int routing_id, int stream_id, double left, double right)); @@ -95,8 +96,8 @@ class MockAudioRendererHost : public AudioRendererHost { } void OnStreamStateChanged(const IPC::Message& msg, int stream_id, - AudioOutputStream::State state, int info) { - OnStreamStateChanged(msg.routing_id(), stream_id, state, info); + ViewMsg_AudioStreamState state) { + OnStreamStateChanged(msg.routing_id(), stream_id, state); } void OnStreamVolume(const IPC::Message& msg, int stream_id, @@ -206,10 +207,9 @@ TEST_F(AudioRendererHostTest, MockStreamDataConversation) { 2 * kPacketSize + 3 * kStep, _)); EXPECT_CALL(*host_, OnRequestPacket(kRouteId, current_stream_id_, 3 * kPacketSize, _)); - EXPECT_CALL(*host_, OnStreamStateChanged(kRouteId, - current_stream_id_, - AudioOutputStream::STATE_STARTED, - 0)); + ViewMsg_AudioStreamState state; + EXPECT_CALL(*host_, OnStreamStateChanged(kRouteId, current_stream_id_, _)) + .WillOnce(SaveArg<2>(&state)); source->NotifyPacketReady(kPacketSize); source->NotifyPacketReady(kPacketSize); @@ -217,7 +217,7 @@ TEST_F(AudioRendererHostTest, MockStreamDataConversation) { source->NotifyPacketReady(kStep); source->NotifyPacketReady(kStep); source->NotifyPacketReady(kStep); - source->Start(); + source->Play(); + EXPECT_EQ(ViewMsg_AudioStreamState::kPlaying, state.state); source->Close(); } - diff --git a/chrome/common/render_messages.h b/chrome/common/render_messages.h index af9ded8..63d91c0 100644 --- a/chrome/common/render_messages.h +++ b/chrome/common/render_messages.h @@ -82,6 +82,20 @@ struct ViewMsg_Navigate_Params { base::Time request_time; }; +// Current status of the audio output stream in the browser process. Browser +// sends information about the current playback state and error to the +// renderer process using this type. +struct ViewMsg_AudioStreamState { + enum State { + kPlaying, + kPaused, + kError + }; + + // Carries the current playback state. + State state; +}; + // Parameters structure for ViewHostMsg_FrameNavigate, which has too many data // parameters to be reasonably put in a predefined IPC message. struct ViewHostMsg_FrameNavigate_Params { @@ -1805,44 +1819,34 @@ struct ParamTraits<gfx::NativeView> { #endif // defined(OS_POSIX) template <> -struct ParamTraits<AudioOutputStream::State> { - typedef AudioOutputStream::State param_type; +struct ParamTraits<ViewMsg_AudioStreamState> { + typedef ViewMsg_AudioStreamState param_type; static void Write(Message* m, const param_type& p) { - m->WriteInt(p); + m->WriteInt(p.state); } static bool Read(const Message* m, void** iter, param_type* p) { int type; if (!m->ReadInt(iter, &type)) return false; - *p = static_cast<AudioOutputStream::State>(type); + p->state = static_cast<ViewMsg_AudioStreamState::State>(type); return true; } static void Log(const param_type& p, std::wstring* l) { std::wstring state; - switch (p) { - case AudioOutputStream::STATE_CREATED: - state = L"AudioOutputStream::STATE_CREATED"; - break; - case AudioOutputStream::STATE_STARTED: - state = L"AudioOutputStream::STATE_STARTED"; - break; - case AudioOutputStream::STATE_PAUSED: - state = L"AudioOutputStream::STATE_PAUSED"; + switch (p.state) { + case ViewMsg_AudioStreamState::kPlaying: + state = L"ViewMsg_AudioStreamState::kPlaying"; break; - case AudioOutputStream::STATE_STOPPED: - state = L"AudioOutputStream::STATE_STOPPED"; + case ViewMsg_AudioStreamState::kPaused: + state = L"ViewMsg_AudioStreamState::kPaused"; break; - case AudioOutputStream::STATE_CLOSED: - state = L"AudioOutputStream::STATE_CLOSED"; - break; - case AudioOutputStream::STATE_ERROR: - state = L"AudioOutputStream::STATE_ERROR"; + case ViewMsg_AudioStreamState::kError: + state = L"ViewMsg_AudioStreamState::kError"; break; default: state = L"UNKNOWN"; break; } - LogParam(state, l); } }; diff --git a/chrome/common/render_messages_internal.h b/chrome/common/render_messages_internal.h index d831654..3d27fb5 100644 --- a/chrome/common/render_messages_internal.h +++ b/chrome/common/render_messages_internal.h @@ -554,11 +554,9 @@ IPC_BEGIN_MESSAGES(View) // Notification message sent from AudioRendererHost to renderer for state // update after the renderer has requested a Create/Start/Close. - IPC_MESSAGE_ROUTED3(ViewMsg_NotifyAudioStreamStateChanged, + IPC_MESSAGE_ROUTED2(ViewMsg_NotifyAudioStreamStateChanged, int /* stream id */, - AudioOutputStream::State /* new state */, - int /* additional information (e.g. platform specific - error code*/) + ViewMsg_AudioStreamState /* new state */) IPC_MESSAGE_ROUTED3(ViewMsg_NotifyAudioStreamVolume, int /* stream id */, @@ -1413,7 +1411,7 @@ IPC_BEGIN_MESSAGES(ViewHost) size_t /* packet size */) // Start buffering the audio stream specified by (render_view_id, stream_id). - IPC_MESSAGE_ROUTED1(ViewHostMsg_StartAudioStream, + IPC_MESSAGE_ROUTED1(ViewHostMsg_PlayAudioStream, int /* stream_id */) // Pause the audio stream specified by (render_view_id, stream_id). diff --git a/chrome/renderer/audio_message_filter.cc b/chrome/renderer/audio_message_filter.cc index b875f92..9bd1b9a 100644 --- a/chrome/renderer/audio_message_filter.cc +++ b/chrome/renderer/audio_message_filter.cc @@ -116,15 +116,14 @@ void AudioMessageFilter::OnStreamCreated(int stream_id, } void AudioMessageFilter::OnStreamStateChanged(int stream_id, - AudioOutputStream::State state, - int info) { + ViewMsg_AudioStreamState state) { Delegate* delegate = delegates_.Lookup(stream_id); if (!delegate) { DLOG(WARNING) << "Got audio stream event for a non-existent or removed" " audio renderer."; return; } - delegate->OnStateChanged(state, info); + delegate->OnStateChanged(state); } void AudioMessageFilter::OnStreamVolume(int stream_id, diff --git a/chrome/renderer/audio_message_filter.h b/chrome/renderer/audio_message_filter.h index 7fa17cb..f714e1b 100644 --- a/chrome/renderer/audio_message_filter.h +++ b/chrome/renderer/audio_message_filter.h @@ -12,8 +12,8 @@ #include "base/id_map.h" #include "base/shared_memory.h" +#include "chrome/common/render_messages.h" #include "ipc/ipc_channel_proxy.h" -#include "media/audio/audio_output.h" #include "testing/gtest/include/gtest/gtest_prod.h" class AudioMessageFilter : public IPC::ChannelProxy::MessageFilter { @@ -25,7 +25,7 @@ class AudioMessageFilter : public IPC::ChannelProxy::MessageFilter { const base::Time& message_timestamp) = 0; // Called when state of an audio stream has changed in the browser process. - virtual void OnStateChanged(AudioOutputStream::State state, int info) = 0; + virtual void OnStateChanged(ViewMsg_AudioStreamState state) = 0; // Called when an audio stream has been created in the browser process. virtual void OnCreated(base::SharedMemoryHandle handle, size_t length) = 0; @@ -69,8 +69,7 @@ class AudioMessageFilter : public IPC::ChannelProxy::MessageFilter { // Received when internal state of browser process' audio output device has // changed. - void OnStreamStateChanged(int stream_id, AudioOutputStream::State state, - int info); + void OnStreamStateChanged(int stream_id, ViewMsg_AudioStreamState state); // Notification of volume property of an audio output stream. void OnStreamVolume(int stream_id, double left, double right); diff --git a/chrome/renderer/audio_message_filter_unittest.cc b/chrome/renderer/audio_message_filter_unittest.cc index d09a406..ee60ffa 100644 --- a/chrome/renderer/audio_message_filter_unittest.cc +++ b/chrome/renderer/audio_message_filter_unittest.cc @@ -23,10 +23,9 @@ class MockAudioDelegate : public AudioMessageFilter::Delegate { message_timestamp_ = message_timestamp; } - virtual void OnStateChanged(AudioOutputStream::State state, int info) { + virtual void OnStateChanged(ViewMsg_AudioStreamState state) { state_changed_received_ = true; state_ = state; - info_ = info; } virtual void OnCreated(base::SharedMemoryHandle handle, size_t length) { @@ -47,8 +46,7 @@ class MockAudioDelegate : public AudioMessageFilter::Delegate { message_timestamp_ = base::Time(); state_changed_received_ = false; - state_ = AudioOutputStream::STATE_ERROR; - info_ = 0; + state_.state = ViewMsg_AudioStreamState::kError; created_received_ = false; handle_ = base::SharedMemory::NULLHandle(); @@ -64,8 +62,7 @@ class MockAudioDelegate : public AudioMessageFilter::Delegate { const base::Time& message_timestamp() { return message_timestamp_; } bool state_changed_received() { return state_changed_received_; } - AudioOutputStream::State state() { return state_; } - int info() { return info_; } + ViewMsg_AudioStreamState state() { return state_; } bool created_received() { return created_received_; } base::SharedMemoryHandle handle() { return handle_; } @@ -81,8 +78,7 @@ class MockAudioDelegate : public AudioMessageFilter::Delegate { base::Time message_timestamp_; bool state_changed_received_; - AudioOutputStream::State state_; - int info_; + ViewMsg_AudioStreamState state_; bool created_received_; base::SharedMemoryHandle handle_; @@ -120,17 +116,13 @@ TEST(AudioMessageFilterTest, Basic) { delegate.Reset(); // ViewMsg_NotifyAudioStreamStateChanged - const AudioOutputStream::State kState = AudioOutputStream::STATE_STARTED; - const int kStateInfo = 100; + const ViewMsg_AudioStreamState kState = + { ViewMsg_AudioStreamState::kPlaying }; EXPECT_FALSE(delegate.state_changed_received()); filter->OnMessageReceived( - ViewMsg_NotifyAudioStreamStateChanged(kRouteId, - stream_id, - kState, - kStateInfo)); + ViewMsg_NotifyAudioStreamStateChanged(kRouteId, stream_id, kState)); EXPECT_TRUE(delegate.state_changed_received()); - EXPECT_TRUE(kState == delegate.state()); - EXPECT_EQ(kStateInfo, delegate.info()); + EXPECT_TRUE(kState.state == delegate.state().state); delegate.Reset(); // ViewMsg_NotifyAudioStreamCreated diff --git a/chrome/renderer/media/audio_renderer_impl.cc b/chrome/renderer/media/audio_renderer_impl.cc index c00d9c7..783acf3 100644 --- a/chrome/renderer/media/audio_renderer_impl.cc +++ b/chrome/renderer/media/audio_renderer_impl.cc @@ -183,16 +183,15 @@ void AudioRendererImpl::OnRequestPacket(size_t bytes_in_buffer, OnNotifyPacketReady(); } -void AudioRendererImpl::OnStateChanged(AudioOutputStream::State state, - int info) { +void AudioRendererImpl::OnStateChanged(ViewMsg_AudioStreamState state) { DCHECK(MessageLoop::current() == io_loop_); AutoLock auto_lock(lock_); if (stopped_) return; - switch (state) { - case AudioOutputStream::STATE_ERROR: + switch (state.state) { + case ViewMsg_AudioStreamState::kError: // We receive this error if we counter an hardware error on the browser // side. We can proceed with ignoring the audio stream. // TODO(hclam): We need more handling of these kind of error. For example @@ -201,8 +200,8 @@ void AudioRendererImpl::OnStateChanged(AudioOutputStream::State state, host()->BroadcastMessage(media::kMsgDisableAudio); break; // TODO(hclam): handle these events. - case AudioOutputStream::STATE_STARTED: - case AudioOutputStream::STATE_PAUSED: + case ViewMsg_AudioStreamState::kPlaying: + case ViewMsg_AudioStreamState::kPaused: break; default: NOTREACHED(); @@ -242,7 +241,7 @@ void AudioRendererImpl::OnCreateStream( void AudioRendererImpl::OnPlay() { DCHECK(MessageLoop::current() == io_loop_); - filter_->Send(new ViewHostMsg_StartAudioStream(0, stream_id_)); + filter_->Send(new ViewHostMsg_PlayAudioStream(0, stream_id_)); } void AudioRendererImpl::OnPause() { @@ -309,7 +308,7 @@ void AudioRendererImpl::OnNotifyPacketReady() { if (filled > preroll_bytes_) { prerolling_ = false; preroll_bytes_ = 0; - filter_->Send(new ViewHostMsg_StartAudioStream(0, stream_id_)); + filter_->Send(new ViewHostMsg_PlayAudioStream(0, stream_id_)); } else { preroll_bytes_ -= filled; } diff --git a/chrome/renderer/media/audio_renderer_impl.h b/chrome/renderer/media/audio_renderer_impl.h index a087402..489bc60 100644 --- a/chrome/renderer/media/audio_renderer_impl.h +++ b/chrome/renderer/media/audio_renderer_impl.h @@ -118,7 +118,7 @@ class AudioRendererImpl : public media::AudioRendererBase, // AudioMessageFilter::Delegate methods, called by AudioMessageFilter. void OnRequestPacket(size_t bytes_in_buffer, const base::Time& message_timestamp); - void OnStateChanged(AudioOutputStream::State state, int info); + void OnStateChanged(ViewMsg_AudioStreamState state); void OnCreated(base::SharedMemoryHandle handle, size_t length); void OnVolume(double left, double right); diff --git a/media/audio/audio_output.h b/media/audio/audio_output.h index 14c0828..f27858b 100644 --- a/media/audio/audio_output.h +++ b/media/audio/audio_output.h @@ -41,15 +41,6 @@ // a given AudioOutputStream might or might not talk directly to hardware. class AudioOutputStream { public: - enum State { - STATE_CREATED = 0, // The output stream is created. - STATE_STARTED, // The output stream is started. - STATE_PAUSED, // The output stream is paused. - STATE_STOPPED, // The output stream is stopped. - STATE_CLOSED, // The output stream is closed. - STATE_ERROR, // The output stream is in error state. - }; - // Audio sources must implement AudioSourceCallback. This interface will be // called in a random thread which very likely is a high priority thread. Do // not rely on using this thread TLS or make calls that alter the thread |