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

Unified Diff: remoting/host/desktop_process_main.cc

Issue 11970044: Merged all Chromoting Host code into remoting_core.dll (Windows). (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: host_ui_resource.h has been deleted. Created 7 years, 11 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 side-by-side diff with in-line comments
Download patch
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)

Powered by Google App Engine
This is Rietveld 408576698