// Copyright 2014 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 MOJO_SHELL_CHILD_PROCESS_HOST_H_ #define MOJO_SHELL_CHILD_PROCESS_HOST_H_ #include "base/macros.h" #include "base/process/process_handle.h" #include "mojo/embedder/platform_channel_pair.h" #include "mojo/embedder/scoped_platform_handle.h" #include "mojo/shell/child_process.h" // For |ChildProcess::Type|. namespace mojo { namespace shell { class Context; // (Base) class for a "child process host". Handles launching and connecting a // platform-specific "pipe" to the child, and supports joining the child // process. Intended for use as a base class, but may be used on its own in // simple cases. // // This class is not thread-safe. It should be created/used/destroyed on a // single thread. // // Note: Does not currently work on Windows before Vista. class ChildProcessHost { public: class Delegate { public: virtual void WillStart() = 0; virtual void DidStart(bool success) = 0; }; ChildProcessHost(Context* context, Delegate* delegate, ChildProcess::Type type); virtual ~ChildProcessHost(); // |Start()|s the child process; calls the delegate's |DidStart()| (on the // thread on which |Start()| was called) when the child has been started (or // failed to start). After calling |Start()|, this object must not be // destroyed until |DidStart()| has been called. // TODO(vtl): Consider using weak pointers and removing this requirement. void Start(); // Waits for the child process to terminate, and returns its exit code. // Note: If |Start()| has been called, this must not be called until the // callback has been called. int Join(); embedder::ScopedPlatformHandle* platform_channel() { return &platform_channel_; } protected: Context* context() const { return context_; } private: bool DoLaunch(); void DidLaunch(bool success); Context* const context_; Delegate* const delegate_; const ChildProcess::Type type_; base::ProcessHandle child_process_handle_; embedder::PlatformChannelPair platform_channel_pair_; // Platform-specific "pipe" to the child process. Valid immediately after // creation. embedder::ScopedPlatformHandle platform_channel_; DISALLOW_COPY_AND_ASSIGN(ChildProcessHost); }; } // namespace shell } // namespace mojo #endif // MOJO_SHELL_CHILD_PROCESS_HOST_H_