| 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 "remoting/host/basic_desktop_environment.h" | 5 #include "remoting/host/basic_desktop_environment.h" |
| 6 | 6 |
| 7 #include "base/bind.h" |
| 7 #include "base/logging.h" | 8 #include "base/logging.h" |
| 8 #include "base/single_thread_task_runner.h" | 9 #include "base/single_thread_task_runner.h" |
| 9 #include "media/video/capture/screen/screen_capturer.h" | 10 #include "media/video/capture/screen/screen_capturer.h" |
| 10 #include "remoting/host/audio_capturer.h" | 11 #include "remoting/host/audio_capturer.h" |
| 11 #include "remoting/host/client_session_control.h" | 12 #include "remoting/host/client_session_control.h" |
| 13 #include "remoting/host/host_window.h" |
| 12 #include "remoting/host/input_injector.h" | 14 #include "remoting/host/input_injector.h" |
| 13 #include "remoting/host/local_input_monitor.h" | 15 #include "remoting/host/local_input_monitor.h" |
| 14 #include "remoting/host/screen_controls.h" | 16 #include "remoting/host/screen_controls.h" |
| 17 #include "remoting/host/ui_strings.h" |
| 15 | 18 |
| 16 namespace remoting { | 19 namespace remoting { |
| 17 | 20 |
| 18 BasicDesktopEnvironment::~BasicDesktopEnvironment() { | 21 BasicDesktopEnvironment::~BasicDesktopEnvironment() { |
| 19 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 22 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 20 } | 23 } |
| 21 | 24 |
| 22 scoped_ptr<AudioCapturer> BasicDesktopEnvironment::CreateAudioCapturer() { | 25 scoped_ptr<AudioCapturer> BasicDesktopEnvironment::CreateAudioCapturer() { |
| 23 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 26 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 24 | 27 |
| (...skipping 18 matching lines...) Expand all Loading... |
| 43 | 46 |
| 44 // The basic desktop environment does not use X DAMAGE, since it is | 47 // The basic desktop environment does not use X DAMAGE, since it is |
| 45 // broken on many systems - see http://crbug.com/73423. | 48 // broken on many systems - see http://crbug.com/73423. |
| 46 return media::ScreenCapturer::Create(); | 49 return media::ScreenCapturer::Create(); |
| 47 } | 50 } |
| 48 | 51 |
| 49 BasicDesktopEnvironment::BasicDesktopEnvironment( | 52 BasicDesktopEnvironment::BasicDesktopEnvironment( |
| 50 scoped_refptr<base::SingleThreadTaskRunner> caller_task_runner, | 53 scoped_refptr<base::SingleThreadTaskRunner> caller_task_runner, |
| 51 scoped_refptr<base::SingleThreadTaskRunner> input_task_runner, | 54 scoped_refptr<base::SingleThreadTaskRunner> input_task_runner, |
| 52 scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner, | 55 scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner, |
| 53 base::WeakPtr<ClientSessionControl> client_session_control) | 56 base::WeakPtr<ClientSessionControl> client_session_control, |
| 57 const UiStrings* ui_strings) |
| 54 : caller_task_runner_(caller_task_runner), | 58 : caller_task_runner_(caller_task_runner), |
| 55 input_task_runner_(input_task_runner), | 59 input_task_runner_(input_task_runner), |
| 56 ui_task_runner_(ui_task_runner) { | 60 ui_task_runner_(ui_task_runner), |
| 61 ui_strings_(ui_strings) { |
| 57 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 62 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 58 | 63 |
| 59 // Create the local input monitor. | 64 // Create the local input monitor. |
| 60 local_input_monitor_ = LocalInputMonitor::Create(caller_task_runner_, | 65 local_input_monitor_ = LocalInputMonitor::Create(caller_task_runner_, |
| 61 input_task_runner_, | 66 input_task_runner_, |
| 62 ui_task_runner_, | 67 ui_task_runner_, |
| 63 client_session_control); | 68 client_session_control); |
| 69 |
| 70 // Create the disconnect window. |
| 71 std::string client_jid = client_session_control->client_jid(); |
| 72 std::string username = client_jid.substr(0, client_jid.find('/')); |
| 73 disconnect_window_ = HostWindow::CreateDisconnectWindow( |
| 74 caller_task_runner_, |
| 75 ui_task_runner_, |
| 76 base::Bind(&ClientSessionControl::DisconnectSession, |
| 77 client_session_control), |
| 78 username, |
| 79 *ui_strings_); |
| 64 } | 80 } |
| 65 | 81 |
| 66 BasicDesktopEnvironmentFactory::BasicDesktopEnvironmentFactory( | 82 BasicDesktopEnvironmentFactory::BasicDesktopEnvironmentFactory( |
| 67 scoped_refptr<base::SingleThreadTaskRunner> caller_task_runner, | 83 scoped_refptr<base::SingleThreadTaskRunner> caller_task_runner, |
| 68 scoped_refptr<base::SingleThreadTaskRunner> input_task_runner, | 84 scoped_refptr<base::SingleThreadTaskRunner> input_task_runner, |
| 69 scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner) | 85 scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner, |
| 86 const UiStrings& ui_strings) |
| 70 : caller_task_runner_(caller_task_runner), | 87 : caller_task_runner_(caller_task_runner), |
| 71 input_task_runner_(input_task_runner), | 88 input_task_runner_(input_task_runner), |
| 72 ui_task_runner_(ui_task_runner) { | 89 ui_task_runner_(ui_task_runner), |
| 90 ui_strings_(ui_strings) { |
| 73 } | 91 } |
| 74 | 92 |
| 75 BasicDesktopEnvironmentFactory::~BasicDesktopEnvironmentFactory() { | 93 BasicDesktopEnvironmentFactory::~BasicDesktopEnvironmentFactory() { |
| 76 } | 94 } |
| 77 | 95 |
| 78 scoped_ptr<DesktopEnvironment> BasicDesktopEnvironmentFactory::Create( | 96 scoped_ptr<DesktopEnvironment> BasicDesktopEnvironmentFactory::Create( |
| 79 base::WeakPtr<ClientSessionControl> client_session_control) { | 97 base::WeakPtr<ClientSessionControl> client_session_control) { |
| 80 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 98 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 81 | 99 |
| 82 return scoped_ptr<DesktopEnvironment>( | 100 return scoped_ptr<DesktopEnvironment>( |
| 83 new BasicDesktopEnvironment(caller_task_runner(), | 101 new BasicDesktopEnvironment(caller_task_runner(), |
| 84 input_task_runner(), | 102 input_task_runner(), |
| 85 ui_task_runner(), | 103 ui_task_runner(), |
| 86 client_session_control)); | 104 client_session_control, |
| 105 &ui_strings_)); |
| 87 } | 106 } |
| 88 | 107 |
| 89 bool BasicDesktopEnvironmentFactory::SupportsAudioCapture() const { | 108 bool BasicDesktopEnvironmentFactory::SupportsAudioCapture() const { |
| 90 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 109 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 91 | 110 |
| 92 return AudioCapturer::IsSupported(); | 111 return AudioCapturer::IsSupported(); |
| 93 } | 112 } |
| 94 | 113 |
| 95 } // namespace remoting | 114 } // namespace remoting |
| OLD | NEW |