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

Side by Side Diff: components/arc/audio/arc_audio_bridge.cc

Issue 2357053002: Always use arc::InstanceHolder<T>::GetInstanceForMethod (Closed)
Patch Set: rebase, no code change Created 4 years, 2 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
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "components/arc/audio/arc_audio_bridge.h" 5 #include "components/arc/audio/arc_audio_bridge.h"
6 6
7 #include "ash/common/system/tray/system_tray_notifier.h" 7 #include "ash/common/system/tray/system_tray_notifier.h"
8 #include "ash/common/wm_shell.h" 8 #include "ash/common/wm_shell.h"
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "chromeos/audio/audio_device.h" 10 #include "chromeos/audio/audio_device.h"
11 11
12 namespace arc { 12 namespace arc {
13 13
14 namespace {
15
16 // Note: unlike most of our mojom definitions, AudioInstance::Init's minimum
17 // version is not zero.
18 constexpr uint32_t kMinInstanceVersionForInit = 1;
19
20 } // namespace
21
14 ArcAudioBridge::ArcAudioBridge(ArcBridgeService* bridge_service) 22 ArcAudioBridge::ArcAudioBridge(ArcBridgeService* bridge_service)
15 : ArcService(bridge_service), binding_(this) { 23 : ArcService(bridge_service), binding_(this) {
16 arc_bridge_service()->audio()->AddObserver(this); 24 arc_bridge_service()->audio()->AddObserver(this);
17 if (chromeos::CrasAudioHandler::IsInitialized()) { 25 if (chromeos::CrasAudioHandler::IsInitialized()) {
18 cras_audio_handler_ = chromeos::CrasAudioHandler::Get(); 26 cras_audio_handler_ = chromeos::CrasAudioHandler::Get();
19 cras_audio_handler_->AddAudioObserver(this); 27 cras_audio_handler_->AddAudioObserver(this);
20 } 28 }
21 } 29 }
22 30
23 ArcAudioBridge::~ArcAudioBridge() { 31 ArcAudioBridge::~ArcAudioBridge() {
24 if (cras_audio_handler_ && chromeos::CrasAudioHandler::IsInitialized()) { 32 if (cras_audio_handler_ && chromeos::CrasAudioHandler::IsInitialized()) {
25 cras_audio_handler_->RemoveAudioObserver(this); 33 cras_audio_handler_->RemoveAudioObserver(this);
26 } 34 }
27 arc_bridge_service()->audio()->RemoveObserver(this); 35 arc_bridge_service()->audio()->RemoveObserver(this);
28 } 36 }
29 37
30 void ArcAudioBridge::OnInstanceReady() { 38 void ArcAudioBridge::OnInstanceReady() {
31 mojom::AudioInstance* audio_instance = 39 mojom::AudioInstance* audio_instance =
32 arc_bridge_service()->audio()->instance(); 40 arc_bridge_service()->audio()->GetInstanceForMethod(
33 if (!audio_instance) { 41 "Init", kMinInstanceVersionForInit);
34 LOG(ERROR) << "OnAudioInstanceReady called, " 42 DCHECK(audio_instance); // the instance on ARC side is too old.
35 << "but no audio instance found";
36 return;
37 }
38 if (arc_bridge_service()->audio()->version() < 1) {
39 LOG(WARNING) << "Audio instance is too old and does not support Init()";
40 return;
41 }
42 audio_instance->Init(binding_.CreateInterfacePtrAndBind()); 43 audio_instance->Init(binding_.CreateInterfacePtrAndBind());
43 } 44 }
44 45
45 void ArcAudioBridge::ShowVolumeControls() { 46 void ArcAudioBridge::ShowVolumeControls() {
46 VLOG(2) << "ArcAudioBridge::ShowVolumeControls"; 47 VLOG(2) << "ArcAudioBridge::ShowVolumeControls";
47 ash::WmShell::Get()->system_tray_notifier()->NotifyAudioOutputVolumeChanged( 48 ash::WmShell::Get()->system_tray_notifier()->NotifyAudioOutputVolumeChanged(
48 0, 0); 49 0, 0);
49 } 50 }
50 51
51 void ArcAudioBridge::OnAudioNodesChanged() { 52 void ArcAudioBridge::OnAudioNodesChanged() {
(...skipping 23 matching lines...) Expand all
75 switch_state |= 76 switch_state |=
76 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_HEADPHONE_INSERT)); 77 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_HEADPHONE_INSERT));
77 } 78 }
78 if (microphone_inserted) { 79 if (microphone_inserted) {
79 switch_state |= 80 switch_state |=
80 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_MICROPHONE_INSERT)); 81 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_MICROPHONE_INSERT));
81 } 82 }
82 83
83 VLOG(1) << "Send switch state " << switch_state; 84 VLOG(1) << "Send switch state " << switch_state;
84 mojom::AudioInstance* audio_instance = 85 mojom::AudioInstance* audio_instance =
85 arc_bridge_service()->audio()->instance(); 86 arc_bridge_service()->audio()->GetInstanceForMethod("NotifySwitchState");
86 if (audio_instance) 87 if (audio_instance)
87 audio_instance->NotifySwitchState(switch_state); 88 audio_instance->NotifySwitchState(switch_state);
88 } 89 }
89 90
90 } // namespace arc 91 } // namespace arc
OLDNEW
« no previous file with comments | « chrome/browser/ui/app_list/arc/arc_package_syncable_service.cc ('k') | components/arc/bluetooth/arc_bluetooth_bridge.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698