Index: content/common/zygote_fork_delegate.h |
diff --git a/content/common/zygote_fork_delegate.h b/content/common/zygote_fork_delegate.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f74cf50b66c0a5c9d54991af56263c8f788a2ff8 |
--- /dev/null |
+++ b/content/common/zygote_fork_delegate.h |
@@ -0,0 +1,45 @@ |
+// Copyright (c) 2011 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 CONTENT_COMMON_ZYGOTE_FORK_DELEGATE_H_ |
+#define CONTENT_COMMON_ZYGOTE_FORK_DELEGATE_H_ |
+#pragma once |
+ |
+#include "base/basictypes.h" |
+ |
+class ZygoteForkDelegate { |
+ public: |
+ // A ZygoteForkDelegate is created during Chrome linux zygote |
+ // initialization, and provides "fork()" functionality with |
+ // as an alternative to forking the zygote. A new delegate is |
+ // passed in as an argument to ZygoteMain(). |
+ ZygoteForkDelegate() {}; |
jam
2011/06/21 20:54:08
nit: no need for semicolon
Brad Chen
2011/06/21 23:43:48
Done.
|
+ virtual ~ZygoteForkDelegate() {}; |
+ // Initialization happens in the zygote after it has been |
+ // started by ZygoteMain. |
+ virtual void Init(const bool sandboxed, |
+ const int browserdesc, |
+ const int sandboxdesc) = 0; |
+ // Returns 'true' if the delegate would like to handle a given |
+ // fork request. Otherwise returns false. |
+ virtual bool CanHelp(const std::string& process_type) = 0; |
+ // Delegate forks, returning a -1 on failure. Outside the |
+ // suid sandbox, Fork() returns the Linux process ID. Inside |
+ // the sandbox, returns a positive integer, with PID discovery |
+ // handled by the sandbox. |
+ virtual pid_t Fork(const std::vector<int>& fds) = 0; |
+}; |
+ |
+class NullForkDelegate : public ZygoteForkDelegate { |
+ public: |
+ NullForkDelegate() {}; |
+ ~NullForkDelegate() {}; |
+ virtual void Init(const bool sandboxed, |
+ const int browserdesc, |
+ const int sandboxdesc) {}; |
+ virtual bool CanHelp(const std::string& process_type) { return false; }; |
+ virtual pid_t Fork(const std::vector<int>& fds) { return -1; }; |
+}; |
+ |
+#endif // CONTENT_COMMON_ZYGOTE_FORK_DELEGATE_H_ |