Chromium Code Reviews

Unified Diff: chrome/browser/browser_child_process_host.h

Issue 2885017: Moved common parts of ChildProcessHost into chrome/common and created a Brows... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Code review changes Created 10 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
« no previous file with comments | « chrome/browser/browser.cc ('k') | chrome/browser/browser_child_process_host.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/browser_child_process_host.h
===================================================================
--- chrome/browser/browser_child_process_host.h (revision 51385)
+++ chrome/browser/browser_child_process_host.h (working copy)
@@ -2,51 +2,27 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#ifndef CHROME_BROWSER_CHILD_PROCESS_HOST_H_
-#define CHROME_BROWSER_CHILD_PROCESS_HOST_H_
+#ifndef CHROME_BROWSER_BROWSER_CHILD_PROCESS_HOST_H_
+#define CHROME_BROWSER_BROWSER_CHILD_PROCESS_HOST_H_
#include <list>
-#include <string>
-// Must be included early (e.g. before chrome/common/plugin_messages.h)
-#include "ipc/ipc_logging.h"
-
-#include "base/basictypes.h"
-#include "base/scoped_ptr.h"
#include "chrome/browser/child_process_launcher.h"
#include "chrome/browser/renderer_host/resource_dispatcher_host.h"
-#include "ipc/ipc_channel.h"
+#include "chrome/common/child_process_host.h"
-class CommandLine;
-class NotificationType;
// Plugins/workers and other child processes that live on the IO thread should
// derive from this class.
//
// [Browser]RenderProcessHost is the main exception that doesn't derive from
// this class. That project lives on the UI thread.
-class ChildProcessHost : public ResourceDispatcherHost::Receiver,
- public IPC::Channel::Listener,
- public ChildProcessLauncher::Client {
+class BrowserChildProcessHost : public ResourceDispatcherHost::Receiver,
+ public ChildProcessHost,
+ public ChildProcessLauncher::Client {
public:
- virtual ~ChildProcessHost();
+ virtual ~BrowserChildProcessHost();
- // Returns the pathname to be used for a child process. If a subprocess
- // pathname was specified on the command line, that will be used. Otherwise,
- // the default child process pathname will be returned. On most platforms,
- // this will be the same as the currently-executing process.
- //
- // The argument allow_self is used on Linux to indicate that we allow us to
- // fork from /proc/self/exe rather than using the "real" app path. This
- // prevents autoupdate from confusing us if it changes the file out from
- // under us. You will generally want to set this to true, except when there
- // is an override to the command line (for example, we're forking a renderer
- // in gdb). In this case, you'd use GetChildPath to get the real executable
- // file name, and then prepend the GDB command to the command line.
- //
- // On failure, returns an empty FilePath.
- static FilePath GetChildPath(bool allow_self);
-
// Prepares command_line for crash reporting as appropriate. On Linux and
// Mac, a command-line flag to enable crash reporting in the child process
// will be appended if needed, because the child process may not have access
@@ -69,22 +45,22 @@
public:
Iterator();
explicit Iterator(ProcessType type);
- ChildProcessHost* operator->() { return *iterator_; }
- ChildProcessHost* operator*() { return *iterator_; }
- ChildProcessHost* operator++();
+ BrowserChildProcessHost* operator->() { return *iterator_; }
+ BrowserChildProcessHost* operator*() { return *iterator_; }
+ BrowserChildProcessHost* operator++();
bool Done();
private:
bool all_;
ProcessType type_;
- std::list<ChildProcessHost*>::iterator iterator_;
+ std::list<BrowserChildProcessHost*>::iterator iterator_;
};
protected:
// The resource_dispatcher_host may be NULL to indicate none is needed for
// this process type.
- ChildProcessHost(ProcessType type,
- ResourceDispatcherHost* resource_dispatcher_host);
+ BrowserChildProcessHost(ProcessType type,
+ ResourceDispatcherHost* resource_dispatcher_host);
// Derived classes call this to launch the child process asynchronously.
void Launch(
@@ -96,66 +72,38 @@
#endif
CommandLine* cmd_line);
- // Derived classes return true if it's ok to shut down the child process.
- virtual bool CanShutdown() = 0;
-
- // Send the shutdown message to the child process, and remove this host from
- // the host list. Does not check if CanShutdown is true.
- void ForceShutdown();
-
- // Creates the IPC channel. Returns true iff it succeeded.
- bool CreateChannel();
-
- // Notifies us that an instance has been created on this child process.
- void InstanceCreated();
-
- // IPC::Channel::Listener implementation:
- virtual void OnMessageReceived(const IPC::Message& msg) { }
- virtual void OnChannelConnected(int32 peer_pid) { }
- virtual void OnChannelError() { }
-
// ChildProcessLauncher::Client implementation.
- virtual void OnProcessLaunched() {}
+ virtual void OnProcessLaunched() { }
// Derived classes can override this to know if the process crashed.
virtual void OnProcessCrashed() {}
- bool opening_channel() { return opening_channel_; }
- const std::string& channel_id() { return channel_id_; }
-
virtual bool DidChildCrash();
- // Called when the child process goes away.
+ // Overrides from ChildProcessHost
virtual void OnChildDied();
+ virtual bool InterceptMessageFromChild(const IPC::Message& msg);
+ virtual void Notify(NotificationType type);
+ // Extends the base class implementation and removes this host from
+ // the host list. Calls ChildProcessHost::ForceShutdown
+ virtual void ForceShutdown();
private:
- // Sends the given notification to the notification service on the UI thread.
- void Notify(NotificationType type);
-
- // By using an internal class as the IPC::Channel::Listener, we can intercept
- // OnMessageReceived/OnChannelConnected and do our own processing before
+ // By using an internal class as the ChildProcessLauncher::Client, we can
+ // intercept OnProcessLaunched and do our own processing before
// calling the subclass' implementation.
- class ListenerHook : public IPC::Channel::Listener,
- public ChildProcessLauncher::Client {
+ class ClientHook : public ChildProcessLauncher::Client {
public:
- explicit ListenerHook(ChildProcessHost* host);
- virtual void OnMessageReceived(const IPC::Message& msg);
- virtual void OnChannelConnected(int32 peer_pid);
- virtual void OnChannelError();
+ explicit ClientHook(BrowserChildProcessHost* host);
virtual void OnProcessLaunched();
private:
- ChildProcessHost* host_;
+ BrowserChildProcessHost* host_;
};
-
- ListenerHook listener_;
-
+ ClientHook client_;
// May be NULL if this current process has no resource dispatcher host.
ResourceDispatcherHost* resource_dispatcher_host_;
-
- bool opening_channel_; // True while we're waiting the channel to be opened.
- scoped_ptr<IPC::Channel> channel_;
- std::string channel_id_;
scoped_ptr<ChildProcessLauncher> child_process_;
};
-#endif // CHROME_BROWSER_CHILD_PROCESS_HOST_H_
+#endif // CHROME_BROWSER_BROWSER_CHILD_PROCESS_HOST_H_
+
« no previous file with comments | « chrome/browser/browser.cc ('k') | chrome/browser/browser_child_process_host.cc » ('j') | no next file with comments »

Powered by Google App Engine