diff options
author | Ben Murdoch <benm@google.com> | 2011-05-24 11:24:40 +0100 |
---|---|---|
committer | Ben Murdoch <benm@google.com> | 2011-06-02 09:53:15 +0100 |
commit | 81bc750723a18f21cd17d1b173cd2a4dda9cea6e (patch) | |
tree | 7a9e5ed86ff429fd347a25153107221543909b19 /Source/WebKit2/PluginProcess/PluginControllerProxy.h | |
parent | 94088a6d336c1dd80a1e734af51e96abcbb689a7 (diff) | |
download | external_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.h | 12 |
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. |