Index: remoting/client/audio_decode_scheduler.cc |
diff --git a/remoting/client/audio_decode_scheduler.cc b/remoting/client/audio_decode_scheduler.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..10e71a7d7f700d67a4c64cdaf3394f041e3dd5a8 |
--- /dev/null |
+++ b/remoting/client/audio_decode_scheduler.cc |
@@ -0,0 +1,58 @@ |
+// Copyright (c) 2012 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. |
+ |
+#include "remoting/client/audio_decode_scheduler.h" |
+ |
+#include "base/bind.h" |
+#include "base/location.h" |
+#include "base/single_thread_task_runner.h" |
+#include "remoting/client/audio_player.h" |
+#include "remoting/codec/audio_decoder.h" |
+#include "remoting/proto/audio.pb.h" |
+ |
+namespace remoting { |
+ |
+AudioDecodeScheduler::AudioDecodeScheduler( |
+ scoped_refptr<base::SingleThreadTaskRunner> main_task_runner, |
+ scoped_refptr<base::SingleThreadTaskRunner> audio_decode_task_runner, |
+ scoped_ptr<AudioPlayer> audio_player) |
+ : main_task_runner_(main_task_runner), |
+ audio_decode_task_runner_(audio_decode_task_runner), |
+ audio_player_(audio_player.Pass()) { |
+} |
+ |
+AudioDecodeScheduler::~AudioDecodeScheduler() { |
+} |
+ |
+void AudioDecodeScheduler::Initialize(const protocol::SessionConfig& config) { |
+ DCHECK(main_task_runner_->BelongsToCurrentThread()); |
+ decoder_.reset(AudioDecoder::CreateAudioDecoder(config).release()); |
+} |
+ |
+void AudioDecodeScheduler::ProcessAudioPacket(scoped_ptr<AudioPacket> packet, |
+ const base::Closure& done) { |
+ DCHECK(main_task_runner_->BelongsToCurrentThread()); |
+ audio_decode_task_runner_->PostTask(FROM_HERE, base::Bind( |
+ &AudioDecodeScheduler::DecodePacket, base::Unretained(this), |
+ base::Passed(&packet), done)); |
+} |
+ |
+void AudioDecodeScheduler::DecodePacket(scoped_ptr<AudioPacket> packet, |
+ const base::Closure& done) { |
+ DCHECK(audio_decode_task_runner_->BelongsToCurrentThread()); |
+ scoped_ptr<AudioPacket> decoded_packet = decoder_->Decode(packet.Pass()); |
+ |
+ main_task_runner_->PostTask(FROM_HERE, base::Bind( |
+ &AudioDecodeScheduler::ProcessDecodedPacket, base::Unretained(this), |
+ base::Passed(decoded_packet.Pass()))); |
+ done.Run(); |
Sergey Ulanov
2012/08/03 17:59:55
MessageReader will need to jump to the main thread
kxing
2012/08/03 20:55:13
Done.
|
+} |
+ |
+void AudioDecodeScheduler::ProcessDecodedPacket( |
+ scoped_ptr<AudioPacket> packet) { |
+ DCHECK(main_task_runner_->BelongsToCurrentThread()); |
+ audio_player_->ProcessAudioPacket(packet.Pass()); |
+} |
+ |
+} // namespace remoting |