blob: adfc65eb37e05746476630a57ac5b596e74b3699 [file] [log] [blame]
[email protected]f85f0702010-01-30 09:31:011// Copyright (c) 2010 The Chromium Authors. All rights reserved.
license.botbf09a502008-08-24 00:55:552// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
initial.commit09911bf2008-07-26 23:55:294
[email protected]1d97d2e2008-12-18 23:39:025#ifndef CHROME_RENDERER_RENDER_THREAD_H_
6#define CHROME_RENDERER_RENDER_THREAD_H_
[email protected]32b76ef2010-07-26 23:08:247#pragma once
initial.commit09911bf2008-07-26 23:55:298
[email protected]af7eb3fb2010-09-23 21:31:069#include <map>
[email protected]b68d5ed2009-04-16 02:41:2810#include <string>
[email protected]1bc83062009-02-06 00:16:3711#include <vector>
12
initial.commit09911bf2008-07-26 23:55:2913#include "base/shared_memory.h"
[email protected]71d6d852009-12-07 22:12:3614#include "base/time.h"
15#include "base/timer.h"
[email protected]037fce02009-01-22 01:42:1516#include "build/build_config.h"
[email protected]8930d472009-02-21 08:05:2817#include "chrome/common/child_thread.h"
[email protected]b9ab10c2009-08-07 18:09:5518#include "chrome/common/css_colors.h"
[email protected]4bce24e2010-09-07 20:45:0119#include "chrome/common/gpu_info.h"
[email protected]3e90d4a2009-07-03 17:38:3920#include "chrome/renderer/visitedlink_slave.h"
[email protected]5c7293a2010-03-17 06:40:5721#include "gfx/native_widget_types.h"
[email protected]a83d42292010-08-17 22:51:1022#include "ipc/ipc_channel_proxy.h"
[email protected]cb6037d2009-11-16 22:55:1723#include "ipc/ipc_platform_file.h"
initial.commit09911bf2008-07-26 23:55:2924
[email protected]1edc16b82009-04-07 17:45:5425class AppCacheDispatcher;
[email protected]dd9241932010-02-24 19:23:1326class CookieMessageFilter;
[email protected]017022b2009-07-27 23:06:3427class DBMessageFilter;
[email protected]a8624712009-04-17 00:51:3528class DevToolsAgentFilter;
[email protected]39008c02009-02-11 23:59:2529class FilePath;
[email protected]e13ad79b2010-07-22 21:36:5030class GpuChannelHost;
[email protected]70c19a932010-05-14 12:59:1131class IndexedDBDispatcher;
[email protected]dfcb62a2009-06-17 19:32:4332class ListValue;
[email protected]b7c7bcf2009-10-03 07:07:3433class NullableString16;
[email protected]55e57d42009-02-25 06:10:1734class RendererHistogram;
[email protected]e13ad79b2010-07-22 21:36:5035class RendererHistogramSnapshots;
[email protected]74be069e82010-06-25 00:12:4936class RendererNetPredictor;
[email protected]8d86fce2009-02-26 23:37:5537class RendererWebKitClientImpl;
[email protected]85c55dc2009-11-06 03:05:4638class SpellCheck;
[email protected]39008c02009-02-11 23:59:2539class SkBitmap;
[email protected]4d395d092009-02-11 21:40:4040class UserScriptSlave;
[email protected]cccf90932009-08-23 17:56:2541class URLPattern;
[email protected]2b437e232010-04-02 01:30:0842class WebDatabaseObserverImpl;
[email protected]cccf90932009-08-23 17:56:2543
[email protected]f85f0702010-01-30 09:31:0144struct ContentSettings;
[email protected]9b6f40e2009-06-11 15:54:2645struct RendererPreferences;
[email protected]56879f932010-12-13 21:05:3746struct DOMStorageMsg_Event_Params;
[email protected]5351dbc2010-08-27 15:22:1147struct ViewMsg_ExtensionsUpdated_Params;
[email protected]4e6419c2010-01-15 04:50:3448struct ViewMsg_New_Params;
[email protected]39008c02009-02-11 23:59:2549struct WebPreferences;
initial.commit09911bf2008-07-26 23:55:2950
[email protected]c6a7b862010-08-20 22:19:3851namespace base {
52class MessageLoopProxy;
[email protected]3ead1322010-11-19 20:01:0053template<class T> class ScopedCallbackFactory;
[email protected]c6a7b862010-08-20 22:19:3854class Thread;
55}
56
[email protected]46f36a492010-07-28 19:36:4157namespace IPC {
58struct ChannelHandle;
59}
60
[email protected]3ead1322010-11-19 20:01:0061namespace safe_browsing {
62class Scorer;
63}
64
[email protected]b7c7bcf2009-10-03 07:07:3465namespace WebKit {
66class WebStorageEventDispatcher;
67}
68
[email protected]af7eb3fb2010-09-23 21:31:0669namespace v8 {
70class Extension;
71}
72
[email protected]81a34412009-01-05 19:17:2473// The RenderThreadBase is the minimal interface that a RenderView/Widget
74// expects from a render thread. The interface basically abstracts a way to send
75// and receive messages.
[email protected]00c39612010-03-06 02:53:2876//
[email protected]f3ede412010-06-21 22:52:1677// TODO(brettw): This has two different and opposing usage patterns which
78// make it confusing.
79//
80// In the first mode, callers call RenderThread::current() to get the one and
81// only global RenderThread (bug 10837: this should be renamed get()). Then
82// they access it. Since RenderThread is a concrete class, this can be NULL
83// during unit tests. Callers need to NULL check this every time. Some callers
84// don't happen to get called during unit tests and don't do the NULL checks,
85// which is also confusing since it's not clear if you need to or not.
86//
87// In the second mode, the abstract base class RenderThreadBase is passed to
88// RenderView and RenderWidget. Normally, this points to
89// RenderThread::current() so it's quite confusing which accessing mode should
90// be used. However, during unit testing, this class is replaced with a mock
91// to support testing functions, and is guaranteed non-NULL.
92//
93// It might be nice not to have the ::current() call and put all of the
94// functions on the abstract class so they can be mocked. However, there are
95// some standalone functions like in ChromiumBridge that are not associated
96// with a view that need to access the current thread to send messages to the
97// browser process. These need the ::current() paradigm. So instead, we should
98// probably remove the render_thread_ parameter to RenderView/Widget in
99// preference to just getting the global singleton. We can make it easier to
100// understand by moving everything to the abstract interface and saying that
101// there should never be a NULL RenderThread::current(). Tests would be
102// responsible for setting up the mock one.
[email protected]8930d472009-02-21 08:05:28103class RenderThreadBase {
[email protected]8085dbc82008-09-26 22:53:44104 public:
105 virtual ~RenderThreadBase() {}
106
[email protected]8930d472009-02-21 08:05:28107 virtual bool Send(IPC::Message* msg) = 0;
108
[email protected]8085dbc82008-09-26 22:53:44109 // Called to add or remove a listener for a particular message routing ID.
110 // These methods normally get delegated to a MessageRouter.
111 virtual void AddRoute(int32 routing_id, IPC::Channel::Listener* listener) = 0;
112 virtual void RemoveRoute(int32 routing_id) = 0;
[email protected]81a34412009-01-05 19:17:24113
114 virtual void AddFilter(IPC::ChannelProxy::MessageFilter* filter) = 0;
115 virtual void RemoveFilter(IPC::ChannelProxy::MessageFilter* filter) = 0;
[email protected]bee16aab2009-08-26 15:55:03116
117 // Called by a RenderWidget when it is hidden or restored.
118 virtual void WidgetHidden() = 0;
119 virtual void WidgetRestored() = 0;
[email protected]b8f41a192010-04-19 18:25:04120
121 // True if this process should be treated as an extension process.
122 virtual bool IsExtensionProcess() const = 0;
[email protected]bc535ee52010-08-31 18:40:32123
124 // True if this process is running in an incognito profile.
125 virtual bool IsIncognitoProcess() const = 0;
[email protected]8085dbc82008-09-26 22:53:44126};
127
initial.commit09911bf2008-07-26 23:55:29128// The RenderThread class represents a background thread where RenderView
129// instances live. The RenderThread supports an API that is used by its
130// consumer to talk indirectly to the RenderViews and supporting objects.
131// Likewise, it provides an API for the RenderViews to talk back to the main
[email protected]57c6a652009-05-04 07:58:34132// process (i.e., their corresponding TabContents).
initial.commit09911bf2008-07-26 23:55:29133//
134// Most of the communication occurs in the form of IPC messages. They are
135// routed to the RenderThread according to the routing IDs of the messages.
136// The routing IDs correspond to RenderView instances.
[email protected]8930d472009-02-21 08:05:28137class RenderThread : public RenderThreadBase,
138 public ChildThread {
initial.commit09911bf2008-07-26 23:55:29139 public:
[email protected]8930d472009-02-21 08:05:28140 // Grabs the IPC channel name from the command line.
141 RenderThread();
142 // Constructor that's used when running in single process mode.
[email protected]11f4857282009-11-13 19:56:17143 explicit RenderThread(const std::string& channel_name);
[email protected]8085dbc82008-09-26 22:53:44144 virtual ~RenderThread();
initial.commit09911bf2008-07-26 23:55:29145
[email protected]8930d472009-02-21 08:05:28146 // Returns the one render thread for this process. Note that this should only
147 // be accessed when running on the render thread itself
[email protected]00c39612010-03-06 02:53:28148 //
149 // TODO(brettw) this should be on the abstract base class instead of here,
150 // and return the base class' interface instead. Currently this causes
151 // problems with testing. See the comment above RenderThreadBase above.
[email protected]8930d472009-02-21 08:05:28152 static RenderThread* current();
initial.commit09911bf2008-07-26 23:55:29153
[email protected]c1f50aa2010-02-18 03:46:57154 // Returns the routing ID of the RenderWidget containing the current script
155 // execution context (corresponding to WebFrame::frameForCurrentContext).
156 static int32 RoutingIDForCurrentContext();
157
[email protected]45776222009-07-15 20:21:58158 // Overridden from RenderThreadBase.
[email protected]c1f50aa2010-02-18 03:46:57159 virtual bool Send(IPC::Message* msg);
160 virtual void AddRoute(int32 routing_id, IPC::Channel::Listener* listener);
161 virtual void RemoveRoute(int32 routing_id);
[email protected]81a34412009-01-05 19:17:24162 virtual void AddFilter(IPC::ChannelProxy::MessageFilter* filter);
163 virtual void RemoveFilter(IPC::ChannelProxy::MessageFilter* filter);
[email protected]bee16aab2009-08-26 15:55:03164 virtual void WidgetHidden();
165 virtual void WidgetRestored();
[email protected]bc535ee52010-08-31 18:40:32166 virtual bool IsExtensionProcess() const { return is_extension_process_; }
167 virtual bool IsIncognitoProcess() const { return is_incognito_process_; }
[email protected]bee16aab2009-08-26 15:55:03168
[email protected]c1f50aa2010-02-18 03:46:57169 // These methods modify how the next message is sent. Normally, when sending
170 // a synchronous message that runs a nested message loop, we need to suspend
171 // callbacks into WebKit. This involves disabling timers and deferring
172 // resource loads. However, there are exceptions when we need to customize
173 // the behavior.
174 void DoNotSuspendWebKitSharedTimer();
175 void DoNotNotifyWebKitOfModalLoop();
176
[email protected]8d86fce2009-02-26 23:37:55177 VisitedLinkSlave* visited_link_slave() const {
178 return visited_link_slave_.get();
179 }
initial.commit09911bf2008-07-26 23:55:29180
[email protected]8d86fce2009-02-26 23:37:55181 UserScriptSlave* user_script_slave() const {
182 return user_script_slave_.get();
183 }
[email protected]1e0f70402008-10-16 23:57:47184
[email protected]f430b5712009-08-21 21:46:31185 AppCacheDispatcher* appcache_dispatcher() const {
186 return appcache_dispatcher_.get();
187 }
188
[email protected]70c19a932010-05-14 12:59:11189 IndexedDBDispatcher* indexed_db_dispatcher() const {
190 return indexed_db_dispatcher_.get();
191 }
192
[email protected]85c55dc2009-11-06 03:05:46193 SpellCheck* spellchecker() const {
194 return spellchecker_.get();
195 }
[email protected]85c55dc2009-11-06 03:05:46196
[email protected]3ead1322010-11-19 20:01:00197 // Returns the phishing Scorer object, or NULL if a model has not been passed
198 // in from the browser yet.
199 const safe_browsing::Scorer* phishing_scorer() const {
200 return phishing_scorer_.get();
201 }
202
[email protected]b547fd42009-04-23 23:16:27203 bool plugin_refresh_allowed() const { return plugin_refresh_allowed_; }
204
initial.commit09911bf2008-07-26 23:55:29205 // Do DNS prefetch resolution of a hostname.
206 void Resolve(const char* name, size_t length);
207
[email protected]55e57d42009-02-25 06:10:17208 // Send all the Histogram data to browser.
[email protected]c9a3ef82009-05-28 22:02:46209 void SendHistograms(int sequence_number);
[email protected]55e57d42009-02-25 06:10:17210
initial.commit09911bf2008-07-26 23:55:29211 // Invokes InformHostOfCacheStats after a short delay. Used to move this
212 // bookkeeping operation off the critical latency path.
213 void InformHostOfCacheStatsLater();
214
[email protected]c40acc32010-01-14 01:02:53215 // Sends a message to the browser to close all connections.
216 void CloseCurrentConnections();
[email protected]b07f29092009-06-05 07:33:21217
218 // Sends a message to the browser to enable or disable the disk cache.
219 void SetCacheMode(bool enabled);
220
[email protected]c5d79342010-06-05 01:27:34221 // Sends a message to the browser to clear the disk cache.
222 void ClearCache();
223
[email protected]12893c32010-08-19 17:30:54224 // Sends a message to the browser to enable/disable spdy.
225 void EnableSpdy(bool enable);
226
[email protected]c8865962009-12-16 07:47:39227 // Update the list of active extensions that will be reported when we crash.
228 void UpdateActiveExtensions();
229
[email protected]6217d392010-03-25 22:08:35230 // Asynchronously establish a channel to the GPU plugin if not previously
231 // established or if it has been lost (for example if the GPU plugin crashed).
232 // Use GetGpuChannel() to determine when the channel is ready for use.
233 void EstablishGpuChannel();
234
[email protected]3bf4d532010-03-27 00:23:34235 // Synchronously establish a channel to the GPU plugin if not previously
236 // established or if it has been lost (for example if the GPU plugin crashed).
237 // If there is a pending asynchronous request, it will be completed by the
238 // time this routine returns.
239 GpuChannelHost* EstablishGpuChannelSync();
240
[email protected]6217d392010-03-25 22:08:35241 // Get the GPU channel. Returns NULL if the channel is not established or
242 // has been lost.
243 GpuChannelHost* GetGpuChannel();
244
[email protected]c6a7b862010-08-20 22:19:38245 // Returns a MessageLoopProxy instance corresponding to the message loop
246 // of the thread on which file operations should be run. Must be called
247 // on the renderer's main thread.
248 scoped_refptr<base::MessageLoopProxy> GetFileThreadMessageLoopProxy();
249
[email protected]af7eb3fb2010-09-23 21:31:06250 // This function is called for every registered V8 extension each time a new
251 // script context is created. Returns true if the given V8 extension is
252 // allowed to run on the given URL and extension group.
253 bool AllowScriptExtension(const std::string& v8_extension_name,
254 const GURL& url,
255 int extension_group);
256
[email protected]8930d472009-02-21 08:05:28257 private:
258 virtual void OnControlMessageReceived(const IPC::Message& msg);
initial.commit09911bf2008-07-26 23:55:29259
[email protected]42f1d7822009-07-23 18:17:55260 void Init();
initial.commit09911bf2008-07-26 23:55:29261
[email protected]176aa482008-11-14 03:25:15262 void OnUpdateVisitedLinks(base::SharedMemoryHandle table);
[email protected]3e90d4a2009-07-03 17:38:39263 void OnAddVisitedLinks(const VisitedLinkSlave::Fingerprints& fingerprints);
264 void OnResetVisitedLinks();
[email protected]b75b8292010-10-01 07:28:25265 void OnSetZoomLevelForCurrentURL(const GURL& url, double zoom_level);
[email protected]0314ae02010-04-08 09:18:29266 void OnSetContentSettingsForCurrentURL(
267 const GURL& url, const ContentSettings& content_settings);
[email protected]b2a74ca2010-03-12 17:57:09268 void OnUpdateUserScripts(base::SharedMemoryHandle table);
[email protected]703e807a2009-03-28 19:56:51269 void OnSetExtensionFunctionNames(const std::vector<std::string>& names);
[email protected]5351dbc2010-08-27 15:22:11270 void OnExtensionsUpdated(
271 const ViewMsg_ExtensionsUpdated_Params& params);
[email protected]45776222009-07-15 20:21:58272 void OnPageActionsUpdated(const std::string& extension_id,
[email protected]b7c7bcf2009-10-03 07:07:34273 const std::vector<std::string>& page_actions);
[email protected]56879f932010-12-13 21:05:37274 void OnDOMStorageEvent(const DOMStorageMsg_Event_Params& params);
[email protected]75e126b932009-09-28 19:38:49275 void OnExtensionSetAPIPermissions(
276 const std::string& extension_id,
[email protected]0df165f2010-09-28 16:49:40277 const std::set<std::string>& permissions);
[email protected]75e126b932009-09-28 19:38:49278 void OnExtensionSetHostPermissions(
279 const GURL& extension_url,
280 const std::vector<URLPattern>& permissions);
initial.commit09911bf2008-07-26 23:55:29281 void OnSetNextPageID(int32 next_page_id);
[email protected]b2a74ca2010-03-12 17:57:09282 void OnSetIsIncognitoProcess(bool is_incognito_process);
[email protected]b9ab10c2009-08-07 18:09:55283 void OnSetCSSColors(const std::vector<CSSColors::CSSColorMapping>& colors);
[email protected]4e6419c2010-01-15 04:50:34284 void OnCreateNewView(const ViewMsg_New_Params& params);
initial.commit09911bf2008-07-26 23:55:29285 void OnTransferBitmap(const SkBitmap& bitmap, int resource_id);
286 void OnSetCacheCapacities(size_t min_dead_capacity,
287 size_t max_dead_capacity,
288 size_t capacity);
[email protected]163753f2010-10-01 20:59:03289 void OnClearCache();
initial.commit09911bf2008-07-26 23:55:29290 void OnGetCacheResourceStats();
291
[email protected]55e57d42009-02-25 06:10:17292 // Send all histograms to browser.
[email protected]c9a3ef82009-05-28 22:02:46293 void OnGetRendererHistograms(int sequence_number);
[email protected]55e57d42009-02-25 06:10:17294
[email protected]d41041092009-10-08 06:56:57295 // Send tcmalloc info to browser.
296 void OnGetRendererTcmalloc();
[email protected]38b48a82009-11-11 01:51:32297 void OnGetV8HeapStats();
[email protected]d41041092009-10-08 06:56:57298
[email protected]a7ab1b782010-10-21 23:24:16299 void OnExtensionMessageInvoke(const std::string& extension_id,
300 const std::string& function_name,
[email protected]d7259472010-03-24 08:40:49301 const ListValue& args,
[email protected]a807bbe2010-04-14 10:51:19302 const GURL& event_url);
[email protected]fede6ca12009-10-08 18:24:26303 void OnPurgeMemory();
[email protected]b78e168b2009-09-21 22:05:45304 void OnPurgePluginListCache(bool reload_pages);
[email protected]75e5a872009-04-02 23:56:11305
[email protected]cb6037d2009-11-16 22:55:17306 void OnInitSpellChecker(IPC::PlatformFileForTransit bdict_file,
[email protected]85c55dc2009-11-06 03:05:46307 const std::vector<std::string>& custom_words,
308 const std::string& language,
309 bool auto_spell_correct);
310 void OnSpellCheckWordAdded(const std::string& word);
311 void OnSpellCheckEnableAutoSpellCorrect(bool enable);
[email protected]85c55dc2009-11-06 03:05:46312
[email protected]4bce24e2010-09-07 20:45:01313 void OnGpuChannelEstablished(const IPC::ChannelHandle& channel_handle,
314 const GPUInfo& gpu_info);
[email protected]6217d392010-03-25 22:08:35315
[email protected]31c90db2010-09-23 00:59:18316 void OnSetPhishingModel(IPC::PlatformFileForTransit model_file);
317
[email protected]b3df5a42010-05-11 14:31:09318 void OnGetAccessibilityTree();
319
[email protected]47158302010-11-16 14:10:22320 void OnSetSpeechInputEnabled(bool enabled);
321
initial.commit09911bf2008-07-26 23:55:29322 // Gather usage statistics from the in-memory cache and inform our host.
323 // These functions should be call periodically so that the host can make
324 // decisions about how to allocation resources using current information.
325 void InformHostOfCacheStats();
326
[email protected]90a3fbb12009-02-28 01:13:47327 // We initialize WebKit as late as possible.
328 void EnsureWebKitInitialized();
329
[email protected]bee16aab2009-08-26 15:55:03330 // A task we invoke periodically to assist with idle cleanup.
331 void IdleHandler();
332
[email protected]71d6d852009-12-07 22:12:36333 // Schedule a call to IdleHandler with the given initial delay.
334 void ScheduleIdleHandler(double initial_delay_s);
335
[email protected]af7eb3fb2010-09-23 21:31:06336 // Registers the given V8 extension with WebKit, and also tracks what pages
337 // it is allowed to run on.
338 void RegisterExtension(v8::Extension* extension, bool restrict_to_extensions);
339
[email protected]3ead1322010-11-19 20:01:00340 // Callback to be run once the phishing Scorer has been created.
341 void PhishingScorerCreated(safe_browsing::Scorer* scorer);
342
initial.commit09911bf2008-07-26 23:55:29343 // These objects live solely on the render thread.
[email protected]bee16aab2009-08-26 15:55:03344 scoped_ptr<ScopedRunnableMethodFactory<RenderThread> > task_factory_;
[email protected]3ead1322010-11-19 20:01:00345 scoped_ptr<base::ScopedCallbackFactory<RenderThread> > callback_factory_;
[email protected]42f1d7822009-07-23 18:17:55346 scoped_ptr<VisitedLinkSlave> visited_link_slave_;
347 scoped_ptr<UserScriptSlave> user_script_slave_;
[email protected]74be069e82010-06-25 00:12:49348 scoped_ptr<RendererNetPredictor> renderer_net_predictor_;
[email protected]f430b5712009-08-21 21:46:31349 scoped_ptr<AppCacheDispatcher> appcache_dispatcher_;
[email protected]70c19a932010-05-14 12:59:11350 scoped_ptr<IndexedDBDispatcher> indexed_db_dispatcher_;
[email protected]9291ed12009-07-23 17:33:22351 scoped_refptr<DevToolsAgentFilter> devtools_agent_filter_;
[email protected]42f1d7822009-07-23 18:17:55352 scoped_ptr<RendererHistogramSnapshots> histogram_snapshots_;
353 scoped_ptr<RendererWebKitClientImpl> webkit_client_;
[email protected]b7c7bcf2009-10-03 07:07:34354 scoped_ptr<WebKit::WebStorageEventDispatcher> dom_storage_event_dispatcher_;
[email protected]2b437e232010-04-02 01:30:08355 scoped_ptr<WebDatabaseObserverImpl> web_database_observer_impl_;
[email protected]85c55dc2009-11-06 03:05:46356 scoped_ptr<SpellCheck> spellchecker_;
[email protected]3ead1322010-11-19 20:01:00357 scoped_ptr<const safe_browsing::Scorer> phishing_scorer_;
[email protected]9291ed12009-07-23 17:33:22358
[email protected]e2b2d4a2009-10-24 03:32:59359 // Used on the renderer and IPC threads.
[email protected]017022b2009-07-27 23:06:34360 scoped_refptr<DBMessageFilter> db_message_filter_;
[email protected]dd9241932010-02-24 19:23:13361 scoped_refptr<CookieMessageFilter> cookie_message_filter_;
[email protected]017022b2009-07-27 23:06:34362
[email protected]5fa1c542009-05-05 20:36:07363#if defined(OS_POSIX)
364 scoped_refptr<IPC::ChannelProxy::MessageFilter>
365 suicide_on_channel_error_filter_;
366#endif
367
[email protected]b547fd42009-04-23 23:16:27368 // If true, then a GetPlugins call is allowed to rescan the disk.
369 bool plugin_refresh_allowed_;
370
[email protected]bee16aab2009-08-26 15:55:03371 // Is there a pending task for doing CacheStats.
372 bool cache_stats_task_pending_;
373
374 // The count of RenderWidgets running through this thread.
375 int widget_count_;
376
377 // The count of hidden RenderWidgets running through this thread.
378 int hidden_widget_count_;
379
380 // The current value of the idle notification timer delay.
381 double idle_notification_delay_in_s_;
382
[email protected]71d6d852009-12-07 22:12:36383 // True if this renderer is running extensions.
384 bool is_extension_process_;
385
[email protected]b2a74ca2010-03-12 17:57:09386 // True if this renderer is incognito.
387 bool is_incognito_process_;
388
[email protected]80fc08c52010-03-09 07:43:50389 bool suspend_webkit_shared_timer_;
390 bool notify_webkit_of_modal_loop_;
[email protected]c1f50aa2010-02-18 03:46:57391
[email protected]47158302010-11-16 14:10:22392 // True if this renderer has speech input enabled, set once during thread
393 // initialization.
394 bool is_speech_input_enabled_;
395
[email protected]71d6d852009-12-07 22:12:36396 // Timer that periodically calls IdleHandler.
397 base::RepeatingTimer<RenderThread> idle_timer_;
398
399 // Same as above, but on a longer timer and will run even if the process is
400 // not idle, to ensure that IdleHandle gets called eventually.
401 base::RepeatingTimer<RenderThread> forced_idle_timer_;
402
[email protected]6217d392010-03-25 22:08:35403 // The channel from the renderer process to the GPU process.
404 scoped_refptr<GpuChannelHost> gpu_channel_;
405
[email protected]c6a7b862010-08-20 22:19:38406 // A lazily initiated thread on which file operations are run.
407 scoped_ptr<base::Thread> file_thread_;
408
[email protected]af7eb3fb2010-09-23 21:31:06409 // Map of registered v8 extensions. The key is the extension name. The value
410 // is true if the extension should be restricted to extension-related
411 // contexts.
412 std::map<std::string, bool> v8_extensions_;
413
[email protected]1bc83062009-02-06 00:16:37414 DISALLOW_COPY_AND_ASSIGN(RenderThread);
initial.commit09911bf2008-07-26 23:55:29415};
416
[email protected]1d97d2e2008-12-18 23:39:02417#endif // CHROME_RENDERER_RENDER_THREAD_H_