OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #include "base/basictypes.h" | 5 #include "base/basictypes.h" |
6 #include "base/environment.h" | 6 #include "base/environment.h" |
7 #include "base/file_util.h" | 7 #include "base/file_util.h" |
8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
9 #include "base/message_loop.h" | 9 #include "base/message_loop.h" |
10 #include "base/path_service.h" | 10 #include "base/path_service.h" |
11 #include "base/synchronization/lock.h" | 11 #include "base/synchronization/lock.h" |
12 #include "base/test/test_timeouts.h" | 12 #include "base/test/test_timeouts.h" |
13 #include "base/time.h" | 13 #include "base/time.h" |
14 #include "base/win/scoped_com_initializer.h" | |
15 #include "build/build_config.h" | 14 #include "build/build_config.h" |
16 #include "media/audio/audio_io.h" | 15 #include "media/audio/audio_io.h" |
17 #include "media/audio/audio_manager_base.h" | 16 #include "media/audio/audio_manager_base.h" |
18 #include "media/audio/audio_util.h" | 17 #include "media/audio/audio_util.h" |
| 18 #include "media/base/seekable_buffer.h" |
| 19 #include "testing/gmock/include/gmock/gmock.h" |
| 20 #include "testing/gtest/include/gtest/gtest.h" |
| 21 |
19 #if defined(OS_LINUX) || defined(OS_OPENBSD) | 22 #if defined(OS_LINUX) || defined(OS_OPENBSD) |
20 #include "media/audio/linux/audio_manager_linux.h" | 23 #include "media/audio/linux/audio_manager_linux.h" |
21 #elif defined(OS_MACOSX) | 24 #elif defined(OS_MACOSX) |
22 #include "media/audio/mac/audio_manager_mac.h" | 25 #include "media/audio/mac/audio_manager_mac.h" |
23 #elif defined(OS_WIN) | 26 #elif defined(OS_WIN) |
| 27 #include "base/win/scoped_com_initializer.h" |
24 #include "media/audio/win/audio_manager_win.h" | 28 #include "media/audio/win/audio_manager_win.h" |
25 #elif defined(OS_ANDROID) | 29 #elif defined(OS_ANDROID) |
26 #include "media/audio/android/audio_manager_android.h" | 30 #include "media/audio/android/audio_manager_android.h" |
27 #endif | 31 #endif |
28 #include "media/base/seekable_buffer.h" | |
29 #include "testing/gmock/include/gmock/gmock.h" | |
30 #include "testing/gtest/include/gtest/gtest.h" | |
31 | |
32 using base::win::ScopedCOMInitializer; | |
33 | 32 |
34 namespace media { | 33 namespace media { |
35 | 34 |
36 #if defined(OS_LINUX) || defined(OS_OPENBSD) | 35 #if defined(OS_LINUX) || defined(OS_OPENBSD) |
37 typedef AudioManagerLinux AudioManagerAnyPlatform; | 36 typedef AudioManagerLinux AudioManagerAnyPlatform; |
38 #elif defined(OS_MACOSX) | 37 #elif defined(OS_MACOSX) |
39 typedef AudioManagerMac AudioManagerAnyPlatform; | 38 typedef AudioManagerMac AudioManagerAnyPlatform; |
40 #elif defined(OS_WIN) | 39 #elif defined(OS_WIN) |
41 typedef AudioManagerWin AudioManagerAnyPlatform; | 40 typedef AudioManagerWin AudioManagerAnyPlatform; |
42 #elif defined(OS_ANDROID) | 41 #elif defined(OS_ANDROID) |
(...skipping 275 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
318 }; | 317 }; |
319 | 318 |
320 // Traits template holding a trait of StreamType. It encapsulates | 319 // Traits template holding a trait of StreamType. It encapsulates |
321 // AudioInputStream and AudioOutputStream stream types. | 320 // AudioInputStream and AudioOutputStream stream types. |
322 template <typename StreamTraits> | 321 template <typename StreamTraits> |
323 class StreamWrapper { | 322 class StreamWrapper { |
324 public: | 323 public: |
325 typedef typename StreamTraits::StreamType StreamType; | 324 typedef typename StreamTraits::StreamType StreamType; |
326 | 325 |
327 explicit StreamWrapper(AudioManager* audio_manager) | 326 explicit StreamWrapper(AudioManager* audio_manager) |
328 : com_init_(ScopedCOMInitializer::kMTA), | 327 : |
| 328 #if defined(OS_WIN) |
| 329 com_init_(base::win::ScopedCOMInitializer::kMTA), |
| 330 #endif |
329 audio_manager_(audio_manager), | 331 audio_manager_(audio_manager), |
330 format_(AudioParameters::AUDIO_PCM_LOW_LATENCY), | 332 format_(AudioParameters::AUDIO_PCM_LOW_LATENCY), |
331 #if defined(OS_ANDROID) | 333 #if defined(OS_ANDROID) |
332 channel_layout_(CHANNEL_LAYOUT_MONO), | 334 channel_layout_(CHANNEL_LAYOUT_MONO), |
333 #else | 335 #else |
334 channel_layout_(CHANNEL_LAYOUT_STEREO), | 336 channel_layout_(CHANNEL_LAYOUT_STEREO), |
335 #endif | 337 #endif |
336 bits_per_sample_(16) { | 338 bits_per_sample_(16) { |
337 // Use native/mixing sample rate and N*10ms frame size as default, | 339 // Use native/mixing sample rate and N*10ms frame size as default, |
338 // where N is platform dependent. | 340 // where N is platform dependent. |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
382 | 384 |
383 private: | 385 private: |
384 StreamType* CreateStream() { | 386 StreamType* CreateStream() { |
385 StreamType* stream = StreamTraits::CreateStream(audio_manager_, | 387 StreamType* stream = StreamTraits::CreateStream(audio_manager_, |
386 AudioParameters(format_, channel_layout_, sample_rate_, | 388 AudioParameters(format_, channel_layout_, sample_rate_, |
387 bits_per_sample_, samples_per_packet_)); | 389 bits_per_sample_, samples_per_packet_)); |
388 EXPECT_TRUE(stream); | 390 EXPECT_TRUE(stream); |
389 return stream; | 391 return stream; |
390 } | 392 } |
391 | 393 |
392 ScopedCOMInitializer com_init_; | 394 #if defined(OS_WIN) |
| 395 base::win::ScopedCOMInitializer com_init_; |
| 396 #endif |
| 397 |
393 AudioManager* audio_manager_; | 398 AudioManager* audio_manager_; |
394 AudioParameters::Format format_; | 399 AudioParameters::Format format_; |
395 ChannelLayout channel_layout_; | 400 ChannelLayout channel_layout_; |
396 int bits_per_sample_; | 401 int bits_per_sample_; |
397 int sample_rate_; | 402 int sample_rate_; |
398 int samples_per_packet_; | 403 int samples_per_packet_; |
399 }; | 404 }; |
400 | 405 |
401 typedef StreamWrapper<AudioInputStreamTraits> AudioInputStreamWrapper; | 406 typedef StreamWrapper<AudioInputStreamTraits> AudioInputStreamWrapper; |
402 typedef StreamWrapper<AudioOutputStreamTraits> AudioOutputStreamWrapper; | 407 typedef StreamWrapper<AudioOutputStreamTraits> AudioOutputStreamWrapper; |
(...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
467 | 472 |
468 // All Close() operations that run on the mocked audio thread, | 473 // All Close() operations that run on the mocked audio thread, |
469 // should be synchronous and not post additional close tasks to | 474 // should be synchronous and not post additional close tasks to |
470 // mocked the audio thread. Hence, there is no need to call | 475 // mocked the audio thread. Hence, there is no need to call |
471 // message_loop()->RunAllPending() after the Close() methods. | 476 // message_loop()->RunAllPending() after the Close() methods. |
472 aos->Close(); | 477 aos->Close(); |
473 ais->Close(); | 478 ais->Close(); |
474 } | 479 } |
475 | 480 |
476 } // namespace media | 481 } // namespace media |
OLD | NEW |