Index: webkit/plugins/npapi/webplugin.h |
=================================================================== |
--- webkit/plugins/npapi/webplugin.h (revision 212369) |
+++ webkit/plugins/npapi/webplugin.h (working copy) |
@@ -1,198 +0,0 @@ |
-// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
-// Use of this source code is governed by a BSD-style license that can be |
-// found in the LICENSE file. |
- |
-#ifndef WEBKIT_PLUGINS_NPAPI_WEBPLUGIN_H_ |
-#define WEBKIT_PLUGINS_NPAPI_WEBPLUGIN_H_ |
- |
-#include <string> |
-#include <vector> |
- |
-#include "base/basictypes.h" |
-#include "ui/gfx/native_widget_types.h" |
-#include "ui/gfx/rect.h" |
-#include "ui/gl/gpu_preference.h" |
-#include "webkit/plugins/webkit_plugins_export.h" |
- |
-// TODO(port): this typedef is obviously incorrect on non-Windows |
-// platforms, but now a lot of code now accidentally depends on them |
-// existing. #ifdef out these declarations and fix all the users. |
-typedef void* HANDLE; |
- |
-class GURL; |
-struct NPObject; |
- |
-namespace webkit { |
-namespace npapi { |
- |
-class WebPluginResourceClient; |
-#if defined(OS_MACOSX) |
-class WebPluginAcceleratedSurface; |
-#endif |
- |
-// Describes the new location for a plugin window. |
-struct WEBKIT_PLUGINS_EXPORT WebPluginGeometry { |
- WebPluginGeometry(); |
- ~WebPluginGeometry(); |
- |
- bool Equals(const WebPluginGeometry& rhs) const; |
- |
- // On Windows, this is the plugin window in the plugin process. |
- // On X11, this is the XID of the plugin-side GtkPlug containing the |
- // GtkSocket hosting the actual plugin window. |
- // |
- // On Mac OS X, all of the plugin types are currently "windowless" |
- // (window == 0) except for the special case of the GPU plugin, |
- // which currently performs rendering on behalf of the Pepper 3D API |
- // and WebGL. The GPU plugin uses a simple integer for the |
- // PluginWindowHandle which is used to map to a side data structure |
- // containing information about the plugin. Soon this plugin will be |
- // generalized, at which point this mechanism will be rethought or |
- // removed. |
- gfx::PluginWindowHandle window; |
- gfx::Rect window_rect; |
- // Clip rect (include) and cutouts (excludes), relative to |
- // window_rect origin. |
- gfx::Rect clip_rect; |
- std::vector<gfx::Rect> cutout_rects; |
- bool rects_valid; |
- bool visible; |
-}; |
- |
-// The WebKit side of a plugin implementation. It provides wrappers around |
-// operations that need to interact with the frame and other WebCore objects. |
-class WebPlugin { |
- public: |
- virtual ~WebPlugin() {} |
- |
- // Called by the plugin delegate to let the WebPlugin know if the plugin is |
- // windowed (i.e. handle is not NULL) or windowless (handle is NULL). This |
- // tells the WebPlugin to send mouse/keyboard events to the plugin delegate, |
- // as well as the information about the HDC for paint operations. |
- virtual void SetWindow(gfx::PluginWindowHandle window) = 0; |
- |
- // Whether input events should be sent to the delegate. |
- virtual void SetAcceptsInputEvents(bool accepts) = 0; |
- |
- // Called by the plugin delegate to let it know that the window is being |
- // destroyed. |
- virtual void WillDestroyWindow(gfx::PluginWindowHandle window) = 0; |
-#if defined(OS_WIN) |
- // |pump_messages_event| is a event handle which is used in NPP_HandleEvent |
- // calls to pump messages if the plugin enters a modal loop. |
- // |dummy_activation_window} is used to ensure correct keyboard activation. |
- // It needs to be a child of the parent window. |
- virtual void SetWindowlessData(HANDLE pump_messages_event, |
- gfx::NativeViewId dummy_activation_window) = 0; |
-#endif |
- // Cancels a pending request. |
- virtual void CancelResource(unsigned long id) = 0; |
- virtual void Invalidate() = 0; |
- virtual void InvalidateRect(const gfx::Rect& rect) = 0; |
- |
- // Returns the NPObject for the browser's window object. Does not |
- // take a reference. |
- virtual NPObject* GetWindowScriptNPObject() = 0; |
- |
- // Returns the DOM element that loaded the plugin. Does not take a |
- // reference. |
- virtual NPObject* GetPluginElement() = 0; |
- |
- // Resolves the proxies for the url, returns true on success. |
- virtual bool FindProxyForUrl(const GURL& url, std::string* proxy_list) = 0; |
- |
- // Cookies |
- virtual void SetCookie(const GURL& url, |
- const GURL& first_party_for_cookies, |
- const std::string& cookie) = 0; |
- virtual std::string GetCookies(const GURL& url, |
- const GURL& first_party_for_cookies) = 0; |
- |
- // Handles GetURL/GetURLNotify/PostURL/PostURLNotify requests initiated |
- // by plugins. If the plugin wants notification of the result, notify_id will |
- // be non-zero. |
- virtual void HandleURLRequest(const char* url, |
- const char* method, |
- const char* target, |
- const char* buf, |
- unsigned int len, |
- int notify_id, |
- bool popups_allowed, |
- bool notify_redirects) = 0; |
- |
- // Cancels document load. |
- virtual void CancelDocumentLoad() = 0; |
- |
- // Initiates a HTTP range request for an existing stream. |
- virtual void InitiateHTTPRangeRequest(const char* url, |
- const char* range_info, |
- int range_request_id) = 0; |
- |
- // Returns true iff in incognito mode. |
- virtual bool IsOffTheRecord() = 0; |
- |
- // Called when the WebPluginResourceClient instance is deleted. |
- virtual void ResourceClientDeleted( |
- WebPluginResourceClient* resource_client) {} |
- |
- // Defers the loading of the resource identified by resource_id. This is |
- // controlled by the defer parameter. |
- virtual void SetDeferResourceLoading(unsigned long resource_id, |
- bool defer) = 0; |
- |
-#if defined(OS_MACOSX) |
- // Called to inform the WebPlugin that the plugin has gained or lost focus. |
- virtual void FocusChanged(bool focused) {} |
- |
- // Starts plugin IME. |
- virtual void StartIme() {} |
- |
- // Returns the accelerated surface abstraction for accelerated plugins. |
- virtual WebPluginAcceleratedSurface* GetAcceleratedSurface( |
- gfx::GpuPreference gpu_preference) = 0; |
- |
- // Core Animation plugin support. CA plugins always render through |
- // the compositor. |
- virtual void AcceleratedPluginEnabledRendering() = 0; |
- virtual void AcceleratedPluginAllocatedIOSurface(int32 width, |
- int32 height, |
- uint32 surface_id) = 0; |
- virtual void AcceleratedPluginSwappedIOSurface() = 0; |
-#endif |
- |
- // Handles NPN_URLRedirectResponse calls issued by plugins in response to |
- // HTTP URL redirect notifications. |
- virtual void URLRedirectResponse(bool allow, int resource_id) = 0; |
-}; |
- |
-// Simpler version of ResourceHandleClient that lends itself to proxying. |
-class WebPluginResourceClient { |
- public: |
- virtual ~WebPluginResourceClient() {} |
- |
- virtual void WillSendRequest(const GURL& url, int http_status_code) = 0; |
- // The request_is_seekable parameter indicates whether byte range requests |
- // can be issued for the underlying stream. |
- virtual void DidReceiveResponse(const std::string& mime_type, |
- const std::string& headers, |
- uint32 expected_length, |
- uint32 last_modified, |
- bool request_is_seekable) = 0; |
- virtual void DidReceiveData(const char* buffer, int length, |
- int data_offset) = 0; |
- // The resource ids passed here ensures that data for range requests |
- // is cleared. This applies for seekable streams. |
- virtual void DidFinishLoading(unsigned long resource_id) = 0; |
- virtual void DidFail(unsigned long resource_id) = 0; |
- virtual bool IsMultiByteResponseExpected() = 0; |
- virtual int ResourceId() = 0; |
- // Tells this object that it will get responses from multiple resources. |
- // This is necessary since the plugin process uses a single instance of |
- // PluginStreamUrl object for multiple range requests. |
- virtual void AddRangeRequestResourceId(unsigned long resource_id) { } |
-}; |
- |
-} // namespace npapi |
-} // namespace webkit |
- |
-#endif // WEBKIT_PLUGINS_NPAPI_WEBPLUGIN_H_ |