Index: remoting/host/desktop_process_main.cc |
diff --git a/remoting/host/desktop_process_main.cc b/remoting/host/desktop_process_main.cc |
deleted file mode 100644 |
index fa678de69ef4386064b3cbc2550d5099d906c4b7..0000000000000000000000000000000000000000 |
--- a/remoting/host/desktop_process_main.cc |
+++ /dev/null |
@@ -1,144 +0,0 @@ |
-// 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. |
-// |
-// This file implements the Windows service controlling Me2Me host processes |
-// running within user sessions. |
- |
-#include "base/at_exit.h" |
-#include "base/bind.h" |
-#include "base/bind_helpers.h" |
-#include "base/command_line.h" |
-#include "base/file_path.h" |
-#include "base/message_loop.h" |
-#include "base/run_loop.h" |
-#include "base/scoped_native_library.h" |
-#include "base/stringprintf.h" |
-#include "base/utf_string_conversions.h" |
-#include "base/win/windows_version.h" |
-#include "remoting/base/auto_thread_task_runner.h" |
-#include "remoting/base/breakpad.h" |
-#include "remoting/host/desktop_process.h" |
-#include "remoting/host/host_exit_codes.h" |
-#include "remoting/host/logging.h" |
-#include "remoting/host/usage_stats_consent.h" |
- |
-#if defined(OS_MACOSX) |
-#include "base/mac/scoped_nsautorelease_pool.h" |
-#endif // defined(OS_MACOSX) |
- |
-#if defined(OS_WIN) |
-#include <commctrl.h> |
-#endif // defined(OS_WIN) |
- |
-namespace { |
- |
-// The command line switch specifying the name of the daemon IPC endpoint. |
-const char kDaemonIpcSwitchName[] = "daemon-pipe"; |
- |
-// "--help" or "--?" prints the usage message. |
-const char kHelpSwitchName[] = "help"; |
-const char kQuestionSwitchName[] = "?"; |
- |
-const char kUsageMessage[] = |
- "\n" |
- "Usage: %s [options]\n" |
- "\n" |
- "Options:\n" |
- " --help, --? - Print this message.\n"; |
- |
-void Usage(const FilePath& program_name) { |
- std::string display_name = UTF16ToUTF8(program_name.LossyDisplayName()); |
- LOG(INFO) << StringPrintf(kUsageMessage, display_name.c_str()); |
-} |
- |
-} // namespace |
- |
-int main(int argc, char** argv) { |
-#if defined(OS_MACOSX) |
- // Needed so we don't leak objects when threads are created. |
- base::mac::ScopedNSAutoreleasePool pool; |
-#endif |
- |
- CommandLine::Init(argc, argv); |
- |
- // This object instance is required by Chrome code (for example, |
- // LazyInstance, MessageLoop). |
- base::AtExitManager exit_manager; |
- |
- remoting::InitHostLogging(); |
- |
- const CommandLine* command_line = CommandLine::ForCurrentProcess(); |
- if (command_line->HasSwitch(kHelpSwitchName) || |
- command_line->HasSwitch(kQuestionSwitchName)) { |
- Usage(command_line->GetProgram()); |
- return remoting::kSuccessExitCode; |
- } |
- |
- std::string channel_name = |
- command_line->GetSwitchValueASCII(kDaemonIpcSwitchName); |
- |
- if (channel_name.empty()) { |
- Usage(command_line->GetProgram()); |
- return remoting::kUsageExitCode; |
- } |
- |
- MessageLoop message_loop(MessageLoop::TYPE_UI); |
- base::RunLoop run_loop; |
- base::Closure quit_ui_task_runner = base::Bind( |
- base::IgnoreResult(&base::SingleThreadTaskRunner::PostTask), |
- message_loop.message_loop_proxy(), |
- FROM_HERE, run_loop.QuitClosure()); |
- scoped_refptr<remoting::AutoThreadTaskRunner> ui_task_runner = |
- new remoting::AutoThreadTaskRunner(message_loop.message_loop_proxy(), |
- quit_ui_task_runner); |
- |
- remoting::DesktopProcess desktop_process(ui_task_runner, channel_name); |
- if (!desktop_process.Start()) |
- return remoting::kInitializationFailed; |
- |
- // Run the UI message loop. |
- ui_task_runner = NULL; |
- run_loop.Run(); |
- |
- return remoting::kSuccessExitCode; |
-} |
- |
-#if defined(OS_WIN) |
- |
-int CALLBACK WinMain(HINSTANCE instance, |
- HINSTANCE previous_instance, |
- LPSTR raw_command_line, |
- int show_command) { |
-#ifdef OFFICIAL_BUILD |
- if (remoting::IsUsageStatsAllowed()) { |
- remoting::InitializeCrashReporting(); |
- } |
-#endif // OFFICIAL_BUILD |
- |
- // Register and initialize common controls. |
- INITCOMMONCONTROLSEX info; |
- info.dwSize = sizeof(info); |
- info.dwICC = ICC_STANDARD_CLASSES; |
- InitCommonControlsEx(&info); |
- |
- // Mark the process as DPI-aware, so Windows won't scale coordinates in APIs. |
- // N.B. This API exists on Vista and above. |
- if (base::win::GetVersion() >= base::win::VERSION_VISTA) { |
- FilePath path(base::GetNativeLibraryName(UTF8ToUTF16("user32"))); |
- base::ScopedNativeLibrary user32(path); |
- CHECK(user32.is_valid()); |
- |
- typedef BOOL (WINAPI * SetProcessDPIAwareFn)(); |
- SetProcessDPIAwareFn set_process_dpi_aware = |
- static_cast<SetProcessDPIAwareFn>( |
- user32.GetFunctionPointer("SetProcessDPIAware")); |
- set_process_dpi_aware(); |
- } |
- |
- // CommandLine::Init() ignores the passed |argc| and |argv| on Windows getting |
- // the command line from GetCommandLineW(), so we can safely pass NULL here. |
- return main(0, NULL); |
-} |
- |
-#endif // defined(OS_WIN) |