OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CONTENT_PUBLIC_BROWSER_RENDER_PROCESS_HOST_OBSERVER_H_ | 5 #ifndef CONTENT_PUBLIC_BROWSER_RENDER_PROCESS_HOST_OBSERVER_H_ |
6 #define CONTENT_PUBLIC_BROWSER_RENDER_PROCESS_HOST_OBSERVER_H_ | 6 #define CONTENT_PUBLIC_BROWSER_RENDER_PROCESS_HOST_OBSERVER_H_ |
7 | 7 |
8 #include "base/process/kill.h" | 8 #include "base/process/kill.h" |
9 #include "base/process/process_handle.h" | 9 #include "base/process/process_handle.h" |
10 #include "content/common/content_export.h" | 10 #include "content/common/content_export.h" |
11 | 11 |
12 namespace content { | 12 namespace content { |
13 | 13 |
14 class RenderProcessHost; | 14 class RenderProcessHost; |
15 | 15 |
16 // An observer API implemented by classes which are interested | 16 // An observer API implemented by classes which are interested |
17 // in RenderProcessHost lifecycle events. | 17 // in RenderProcessHost lifecycle events. |
18 class CONTENT_EXPORT RenderProcessHostObserver { | 18 class CONTENT_EXPORT RenderProcessHostObserver { |
19 public: | 19 public: |
20 // This method is invoked when a render process exited (either normally or | 20 // This method is invoked when the process of the observed RenderProcessHost |
21 // with a crash). To determine if the process closed normally or crashed, | 21 // exits (either normally or with a crash). To determine if the process closed |
22 // examine the |status| parameter. | 22 // normally or crashed, examine the |status| parameter. |
23 // | 23 // |
24 // Note that this is equivalent to WebContentsObserver::RenderProcessGone(). | 24 // This will cause a call to WebContentsObserver::RenderProcessGone() for the |
| 25 // active renderer process for the top-level frame; for code that needs to be |
| 26 // a WebContentsObserver anyway, consider whether that API might be a better |
| 27 // choice. |
25 virtual void RenderProcessExited(RenderProcessHost* host, | 28 virtual void RenderProcessExited(RenderProcessHost* host, |
26 base::TerminationStatus status, | 29 base::TerminationStatus status, |
27 int exit_code) {} | 30 int exit_code) {} |
28 | 31 |
29 // This method is invoked when the observed RenderProcessHost itself is | 32 // This method is invoked when the observed RenderProcessHost itself is |
30 // destroyed. This is guaranteed to be the last call made to the observer. | 33 // destroyed. This is guaranteed to be the last call made to the observer. |
31 virtual void RenderProcessHostDestroyed(RenderProcessHost* host) {} | 34 virtual void RenderProcessHostDestroyed(RenderProcessHost* host) {} |
32 | 35 |
33 protected: | 36 protected: |
34 virtual ~RenderProcessHostObserver() {} | 37 virtual ~RenderProcessHostObserver() {} |
35 }; | 38 }; |
36 | 39 |
37 } // namespace content | 40 } // namespace content |
38 | 41 |
39 #endif // CONTENT_PUBLIC_BROWSER_RENDER_PROCESS_HOST_OBSERVER_H_ | 42 #endif // CONTENT_PUBLIC_BROWSER_RENDER_PROCESS_HOST_OBSERVER_H_ |
OLD | NEW |