| Index: chrome/nacl/nacl_main.cc
|
| ===================================================================
|
| --- chrome/nacl/nacl_main.cc (revision 0)
|
| +++ chrome/nacl/nacl_main.cc (revision 0)
|
| @@ -0,0 +1,75 @@
|
| +// Copyright (c) 2006-2009 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.
|
| +
|
| +#include "build/build_config.h"
|
| +
|
| +#if defined(OS_WIN)
|
| +#include "app/win_util.h"
|
| +#endif
|
| +#include "base/command_line.h"
|
| +#include "base/message_loop.h"
|
| +#include "base/string_util.h"
|
| +#include "base/system_monitor.h"
|
| +#include "chrome/common/child_process.h"
|
| +#include "chrome/common/chrome_constants.h"
|
| +#include "chrome/common/chrome_switches.h"
|
| +#include "chrome/common/logging_chrome.h"
|
| +#include "chrome/common/main_function_params.h"
|
| +#include "chrome/nacl/nacl_thread.h"
|
| +
|
| +#if defined(OS_WIN)
|
| +#include "chrome/test/injection_test_dll.h"
|
| +#include "sandbox/src/sandbox.h"
|
| +#endif
|
| +
|
| +// main() routine for running as the sel_ldr process.
|
| +int NaClMain(const MainFunctionParams& parameters) {
|
| + // The main thread of the plugin services IO.
|
| + MessageLoopForIO main_message_loop;
|
| + std::wstring app_name = chrome::kBrowserAppName;
|
| + PlatformThread::SetName(WideToASCII(app_name + L"_NaClMain").c_str());
|
| +
|
| + // Initialize the SystemMonitor
|
| + base::SystemMonitor::Start();
|
| +
|
| +#if defined(OS_WIN)
|
| + const CommandLine& parsed_command_line = parameters.command_line_;
|
| +
|
| + sandbox::TargetServices* target_services =
|
| + parameters.sandbox_info_.TargetServices();
|
| +
|
| + DLOG(INFO) << "Started plugin with " <<
|
| + parsed_command_line.command_line_string();
|
| +
|
| + HMODULE sandbox_test_module = NULL;
|
| + bool no_sandbox = parsed_command_line.HasSwitch(switches::kNoSandbox);
|
| + if (target_services && !no_sandbox) {
|
| + // The command line might specify a test plugin to load.
|
| + if (parsed_command_line.HasSwitch(switches::kTestSandbox)) {
|
| + std::wstring test_plugin_name =
|
| + parsed_command_line.GetSwitchValue(switches::kTestSandbox);
|
| + sandbox_test_module = LoadLibrary(test_plugin_name.c_str());
|
| + DCHECK(sandbox_test_module);
|
| + }
|
| + }
|
| +
|
| +#else
|
| + NOTIMPLEMENTED() << " non-windows startup, plugin startup dialog etc.";
|
| +#endif
|
| +
|
| + {
|
| + ChildProcess nacl_process;
|
| + nacl_process.set_main_thread(new NaClThread());
|
| +#if defined(OS_WIN)
|
| + if (!no_sandbox && target_services)
|
| + target_services->LowerToken();
|
| +#endif
|
| +
|
| + MessageLoop::current()->Run();
|
| + }
|
| +
|
| + return 0;
|
| +}
|
| +
|
| +
|
|
|
| Property changes on: chrome\nacl\nacl_main.cc
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|