summaryrefslogtreecommitdiffstats
path: root/Source/WebKit2/PluginProcess/PluginControllerProxy.h
diff options
context:
space:
mode:
authorBen Murdoch <benm@google.com>2011-05-24 11:24:40 +0100
committerBen Murdoch <benm@google.com>2011-06-02 09:53:15 +0100
commit81bc750723a18f21cd17d1b173cd2a4dda9cea6e (patch)
tree7a9e5ed86ff429fd347a25153107221543909b19 /Source/WebKit2/PluginProcess/PluginControllerProxy.h
parent94088a6d336c1dd80a1e734af51e96abcbb689a7 (diff)
downloadexternal_webkit-81bc750723a18f21cd17d1b173cd2a4dda9cea6e.zip
external_webkit-81bc750723a18f21cd17d1b173cd2a4dda9cea6e.tar.gz
external_webkit-81bc750723a18f21cd17d1b173cd2a4dda9cea6e.tar.bz2
Merge WebKit at r80534: Intial merge by Git
Change-Id: Ia7a83357124c9e1cdb1debf55d9661ec0bd09a61
Diffstat (limited to 'Source/WebKit2/PluginProcess/PluginControllerProxy.h')
-rw-r--r--Source/WebKit2/PluginProcess/PluginControllerProxy.h12
1 files changed, 12 insertions, 0 deletions
diff --git a/Source/WebKit2/PluginProcess/PluginControllerProxy.h b/Source/WebKit2/PluginProcess/PluginControllerProxy.h
index c39542a..e470f85 100644
--- a/Source/WebKit2/PluginProcess/PluginControllerProxy.h
+++ b/Source/WebKit2/PluginProcess/PluginControllerProxy.h
@@ -69,6 +69,8 @@ public:
uint32_t remoteLayerClientID() const;
#endif
+ PluginController* asPluginController() { return this; }
+
private:
PluginControllerProxy(WebProcessConnection* connection, uint64_t pluginInstanceID, const String& userAgent, bool isPrivateBrowsingEnabled, bool isAcceleratedCompositingEnabled);
@@ -97,6 +99,8 @@ private:
virtual String cookiesForURL(const String&);
virtual void setCookiesForURL(const String& urlString, const String& cookieString);
virtual bool isPrivateBrowsingEnabled();
+ virtual void protectPluginFromDestruction();
+ virtual void unprotectPluginFromDestruction();
// Message handlers.
void frameDidFinishLoading(uint64_t requestID);
@@ -117,6 +121,7 @@ private:
void handleMouseLeaveEvent(const WebMouseEvent&, bool& handled);
void handleKeyboardEvent(const WebKeyboardEvent&, bool& handled);
void paintEntirePlugin();
+ void snapshot(WebCore::IntSize& bufferSize, SharedMemory::Handle& backingStoreHandle);
void setFocus(bool);
void didUpdate();
void getPluginScriptableNPObject(uint64_t& pluginScriptableNPObjectID);
@@ -152,6 +157,13 @@ private:
// The paint timer, used for coalescing painting.
RunLoop::Timer<PluginControllerProxy> m_paintTimer;
+
+ // A counter used to prevent the plug-in from being destroyed.
+ unsigned m_pluginDestructionProtectCount;
+
+ // A timer that we use to prevent destruction of the plug-in while plug-in
+ // code is on the stack.
+ RunLoop::Timer<PluginControllerProxy> m_pluginDestroyTimer;
// Whether we're waiting for the plug-in proxy in the web process to draw the contents of its
// backing store into the web process backing store.