[MacViews] Show comboboxes with a native NSMenu
[chromium-blink-merge.git] / content / browser / renderer_host / render_widget_helper.h
blob7f4ad7ea5e2e187aa105ec6dd3ea1e91386f8ed8
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HELPER_H_
6 #define CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HELPER_H_
8 #include <map>
10 #include "base/atomic_sequence_num.h"
11 #include "base/containers/hash_tables.h"
12 #include "base/memory/ref_counted.h"
13 #include "base/process/process.h"
14 #include "content/public/browser/browser_thread.h"
15 #include "content/public/browser/content_browser_client.h"
16 #include "content/public/browser/global_request_id.h"
17 #include "content/public/common/window_container_type.h"
18 #include "third_party/WebKit/public/web/WebPopupType.h"
19 #include "ui/gfx/native_widget_types.h"
21 namespace IPC {
22 class Message;
25 namespace base {
26 class TimeDelta;
29 struct ViewHostMsg_CreateWindow_Params;
31 namespace content {
32 class GpuProcessHost;
33 class ResourceDispatcherHostImpl;
34 class SessionStorageNamespace;
36 // Instantiated per RenderProcessHost to provide various optimizations on
37 // behalf of a RenderWidgetHost. This class bridges between the IO thread
38 // where the RenderProcessHost's MessageFilter lives and the UI thread where
39 // the RenderWidgetHost lives.
42 // OPTIMIZED TAB SWITCHING
44 // When a RenderWidgetHost is in a background tab, it is flagged as hidden.
45 // This causes the corresponding RenderWidget to stop sending BackingStore
46 // messages. The RenderWidgetHost also discards its backingstore when it is
47 // hidden, which helps free up memory. As a result, when a RenderWidgetHost
48 // is restored, it can be momentarily be without a backingstore. (Restoring
49 // a RenderWidgetHost results in a WasShown message being sent to the
50 // RenderWidget, which triggers a full BackingStore message.) This can lead
51 // to an observed rendering glitch as the WebContentsImpl will just have to
52 // fill white overtop the RenderWidgetHost until the RenderWidgetHost
53 // receives a BackingStore message to refresh its backingstore.
55 // To avoid this 'white flash', the RenderWidgetHost again makes use of the
56 // RenderWidgetHelper's WaitForBackingStoreMsg method. When the
57 // RenderWidgetHost's GetBackingStore method is called, it will call
58 // WaitForBackingStoreMsg if it has no backingstore.
60 // TRANSPORT DIB CREATION
62 // On some platforms (currently the Mac) the renderer cannot create transport
63 // DIBs because of sandbox limitations. Thus, it has to make synchronous IPCs
64 // to the browser for them. Since these requests are synchronous, they cannot
65 // terminate on the UI thread. Thus, in this case, this object performs the
66 // allocation and maintains the set of allocated transport DIBs which the
67 // renderers can refer to.
70 class RenderWidgetHelper
71 : public base::RefCountedThreadSafe<RenderWidgetHelper,
72 BrowserThread::DeleteOnIOThread> {
73 public:
74 RenderWidgetHelper();
76 void Init(int render_process_id,
77 ResourceDispatcherHostImpl* resource_dispatcher_host);
79 // Gets the next available routing id. This is thread safe.
80 int GetNextRoutingID();
82 // IO THREAD ONLY -----------------------------------------------------------
84 // Lookup the RenderWidgetHelper from the render_process_host_id. Returns NULL
85 // if not found. NOTE: The raw pointer is for temporary use only. To retain,
86 // store in a scoped_refptr.
87 static RenderWidgetHelper* FromProcessHostID(int render_process_host_id);
89 // UI THREAD ONLY -----------------------------------------------------------
91 // These two functions provide the backend implementation of the
92 // corresponding functions in RenderProcessHost. See those declarations
93 // for documentation.
94 void ResumeDeferredNavigation(const GlobalRequestID& request_id);
96 // Called to resume the requests for a view after it's ready. The view was
97 // created by CreateNewWindow which initially blocked the requests.
98 void ResumeRequestsForView(int route_id);
100 // IO THREAD ONLY -----------------------------------------------------------
102 void CreateNewWindow(
103 const ViewHostMsg_CreateWindow_Params& params,
104 bool no_javascript_access,
105 base::ProcessHandle render_process,
106 int* route_id,
107 int* main_frame_route_id,
108 int* surface_id,
109 SessionStorageNamespace* session_storage_namespace);
110 void CreateNewWidget(int opener_id,
111 blink::WebPopupType popup_type,
112 int* route_id,
113 int* surface_id);
114 void CreateNewFullscreenWidget(int opener_id, int* route_id, int* surface_id);
116 private:
117 friend class base::RefCountedThreadSafe<RenderWidgetHelper>;
118 friend struct BrowserThread::DeleteOnThread<BrowserThread::IO>;
119 friend class base::DeleteHelper<RenderWidgetHelper>;
121 ~RenderWidgetHelper();
123 // Called on the UI thread to finish creating a window.
124 void OnCreateWindowOnUI(
125 const ViewHostMsg_CreateWindow_Params& params,
126 int route_id,
127 int main_frame_route_id,
128 SessionStorageNamespace* session_storage_namespace);
130 // Called on the IO thread after a window was created on the UI thread.
131 void OnResumeRequestsForView(int route_id);
133 // Called on the UI thread to finish creating a widget.
134 void OnCreateWidgetOnUI(int32 opener_id,
135 int32 route_id,
136 int32 surface_id,
137 blink::WebPopupType popup_type);
139 // Called on the UI thread to create a fullscreen widget.
140 void OnCreateFullscreenWidgetOnUI(int32 opener_id,
141 int32 route_id,
142 int32 surface_id);
144 // Called on the IO thread to resume a paused navigation in the network
145 // stack without transferring it to a new renderer process.
146 void OnResumeDeferredNavigation(const GlobalRequestID& request_id);
148 // Called on the IO thread to resume a navigation paused immediately after
149 // receiving response headers.
150 void OnResumeResponseDeferredAtStart(const GlobalRequestID& request_id);
152 int render_process_id_;
154 // The next routing id to use.
155 base::AtomicSequenceNumber next_routing_id_;
157 ResourceDispatcherHostImpl* resource_dispatcher_host_;
159 DISALLOW_COPY_AND_ASSIGN(RenderWidgetHelper);
162 } // namespace content
164 #endif // CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HELPER_H_