From c407dc5cd9bdc5668497f21b26b09d988ab439de Mon Sep 17 00:00:00 2001 From: Ben Murdoch Date: Thu, 29 Jul 2010 17:14:53 +0100 Subject: Merge Chromium src@r53293 Change-Id: Ia79acf8670f385cee48c45b0a75371d8e950af34 --- chrome/browser/nacl_host/nacl_broker_host_win.h | 49 +++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 chrome/browser/nacl_host/nacl_broker_host_win.h (limited to 'chrome/browser/nacl_host/nacl_broker_host_win.h') diff --git a/chrome/browser/nacl_host/nacl_broker_host_win.h b/chrome/browser/nacl_host/nacl_broker_host_win.h new file mode 100644 index 0000000..8668328 --- /dev/null +++ b/chrome/browser/nacl_host/nacl_broker_host_win.h @@ -0,0 +1,49 @@ +// Copyright (c) 2010 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. + +#ifndef CHROME_BROWSER_NACL_HOST_NACL_BROKER_HOST_WIN_H_ +#define CHROME_BROWSER_NACL_HOST_NACL_BROKER_HOST_WIN_H_ + +#include "base/basictypes.h" +#include "base/process.h" +#include "chrome/browser/browser_child_process_host.h" +#include "ipc/ipc_message.h" + +class NaClBrokerHost : public BrowserChildProcessHost { + public: + explicit NaClBrokerHost(ResourceDispatcherHost* resource_dispatcher_host); + ~NaClBrokerHost(); + + // This function starts the broker process. It needs to be called + // before loaders can be launched. + bool Init(); + + // Send a message to the broker process, causing it to launch + // a Native Client loader process. + bool LaunchLoader(const std::wstring& loader_channel_id); + + // Stop the broker process. + void StopBroker(); + + private: + // ResourceDispatcherHost::Receiver implementation: + virtual URLRequestContext* GetRequestContext( + uint32 request_id, + const ViewHostMsg_Resource_Request& request_data); + + virtual bool CanShutdown() { return true; } + + // Handler for NaClProcessMsg_LoaderLaunched message + void OnLoaderLaunched(const std::wstring& loader_channel_id, + base::ProcessHandle handle); + + // IPC::Channel::Listener + virtual void OnMessageReceived(const IPC::Message& msg); + + bool stopping_; + + DISALLOW_COPY_AND_ASSIGN(NaClBrokerHost); +}; + +#endif // CHROME_BROWSER_NACL_HOST_NACL_BROKER_HOST_WIN_H_ -- cgit v1.1