summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
authorapatrick@chromium.org <apatrick@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-02-23 21:03:26 +0000
committerapatrick@chromium.org <apatrick@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-02-23 21:03:26 +0000
commit0b4d43bc81aa786440e8e71de990fad93b32ca5d (patch)
tree31dd60485e6b90fd960a805d4987ebff87974781 /chrome
parentcfbb875f047c61690b3a50dbe271a5a96be254f3 (diff)
downloadchromium_src-0b4d43bc81aa786440e8e71de990fad93b32ca5d.zip
chromium_src-0b4d43bc81aa786440e8e71de990fad93b32ca5d.tar.gz
chromium_src-0b4d43bc81aa786440e8e71de990fad93b32ca5d.tar.bz2
Fix bad merge at r75645.
TEST=try BUG=none Review URL: http://codereview.chromium.org/6580007 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@75782 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r--chrome/browser/renderer_host/gpu_message_filter.h46
-rw-r--r--chrome/browser/renderer_host/render_widget_host_view.h319
2 files changed, 4 insertions, 361 deletions
diff --git a/chrome/browser/renderer_host/gpu_message_filter.h b/chrome/browser/renderer_host/gpu_message_filter.h
index 50d53942..251602a 100644
--- a/chrome/browser/renderer_host/gpu_message_filter.h
+++ b/chrome/browser/renderer_host/gpu_message_filter.h
@@ -6,49 +6,7 @@
#define CHROME_BROWSER_RENDERER_HOST_GPU_MESSAGE_FILTER_H_
#pragma once
-#include "chrome/browser/browser_message_filter.h"
-
-struct GPUCreateCommandBufferConfig;
-class GPUInfo;
-class GpuProcessHost;
-class GpuProcessHostUIShim;
-
-namespace IPC {
-struct ChannelHandle;
-}
-
-// A message filter for messages from the renderer to the GpuProcessHost(UIShim)
-// in the browser. Such messages are typically destined for the GPU process,
-// but need to be mediated by the browser.
-class GpuMessageFilter : public BrowserMessageFilter,
- public base::SupportsWeakPtr<GpuMessageFilter> {
- public:
- explicit GpuMessageFilter(int render_process_id);
-
- // BrowserMessageFilter methods:
- virtual void OverrideThreadForMessage(const IPC::Message& message,
- BrowserThread::ID* thread);
- virtual bool OnMessageReceived(const IPC::Message& message,
- bool* message_was_ok);
- virtual void OnDestruct() const;
-
- private:
- friend class BrowserThread;
- friend class DeleteTask<GpuMessageFilter>;
- virtual ~GpuMessageFilter();
-
- // Message handlers called on the browser IO thread:
- void OnEstablishGpuChannel();
- void OnSynchronizeGpu(IPC::Message* reply);
- void OnCreateViewCommandBuffer(
- int32 render_view_id,
- const GPUCreateCommandBufferConfig& init_params,
- IPC::Message* reply);
-
- int gpu_host_id_;
- int render_process_id_;
-
- DISALLOW_COPY_AND_ASSIGN(GpuMessageFilter);
-};
+// TODO(jam): remove this file when all files have been converted.
+#include "content/browser/renderer_host/gpu_message_filter.h"
#endif // CHROME_BROWSER_RENDERER_HOST_GPU_MESSAGE_FILTER_H_
diff --git a/chrome/browser/renderer_host/render_widget_host_view.h b/chrome/browser/renderer_host/render_widget_host_view.h
index 00afed8..9b95550 100644
--- a/chrome/browser/renderer_host/render_widget_host_view.h
+++ b/chrome/browser/renderer_host/render_widget_host_view.h
@@ -6,322 +6,7 @@
#define CHROME_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_H_
#pragma once
-#if defined(OS_MACOSX)
-#include <OpenGL/OpenGL.h>
-#endif
-
-#include <string>
-#include <vector>
-
-#include "app/surface/transport_dib.h"
-#include "base/process_util.h"
-#include "third_party/skia/include/core/SkBitmap.h"
-#include "third_party/skia/include/core/SkColor.h"
-#include "third_party/WebKit/Source/WebKit/chromium/public/WebPopupType.h"
-#include "third_party/WebKit/Source/WebKit/chromium/public/WebTextInputType.h"
-#include "ui/gfx/native_widget_types.h"
-#include "ui/gfx/rect.h"
-
-namespace gfx {
-class Rect;
-class Size;
-}
-namespace IPC {
-class Message;
-}
-
-class BackingStore;
-class RenderProcessHost;
-class RenderWidgetHost;
-class WebCursor;
-struct NativeWebKeyboardEvent;
-struct ViewHostMsg_AccessibilityNotification_Params;
-
-namespace webkit_glue {
-struct WebAccessibility;
-}
-
-namespace webkit {
-namespace npapi {
-struct WebPluginGeometry;
-}
-}
-
-// RenderWidgetHostView is an interface implemented by an object that acts as
-// the "View" portion of a RenderWidgetHost. The RenderWidgetHost and its
-// associated RenderProcessHost own the "Model" in this case which is the
-// child renderer process. The View is responsible for receiving events from
-// the surrounding environment and passing them to the RenderWidgetHost, and
-// for actually displaying the content of the RenderWidgetHost when it
-// changes.
-class RenderWidgetHostView {
- public:
- virtual ~RenderWidgetHostView();
-
- // Platform-specific creator. Use this to construct new RenderWidgetHostViews
- // rather than using RenderWidgetHostViewWin & friends.
- //
- // This function must NOT size it, because the RenderView in the renderer
- // wounldn't have been created yet. The widget would set its "waiting for
- // resize ack" flag, and the ack would never come becasue no RenderView
- // received it.
- //
- // The RenderWidgetHost must already be created (because we can't know if it's
- // going to be a regular RenderWidgetHost or a RenderViewHost (a subclass).
- static RenderWidgetHostView* CreateViewForWidget(RenderWidgetHost* widget);
-
- // Retrieves the RenderWidgetHostView corresponding to the specified
- // |native_view|, or NULL if there is no such instance.
- static RenderWidgetHostView* GetRenderWidgetHostViewFromNativeView(
- gfx::NativeView native_view);
-
- // Perform all the initialization steps necessary for this object to represent
- // a popup (such as a <select> dropdown), then shows the popup at |pos|.
- virtual void InitAsPopup(RenderWidgetHostView* parent_host_view,
- const gfx::Rect& pos) = 0;
-
- // Perform all the initialization steps necessary for this object to represent
- // a full screen window.
- virtual void InitAsFullscreen() = 0;
-
- // Returns the associated RenderWidgetHost.
- virtual RenderWidgetHost* GetRenderWidgetHost() const = 0;
-
- // Notifies the View that it has become visible.
- virtual void DidBecomeSelected() = 0;
-
- // Notifies the View that it has been hidden.
- virtual void WasHidden() = 0;
-
- // Tells the View to size itself to the specified size.
- virtual void SetSize(const gfx::Size& size) = 0;
-
- // Retrieves the native view used to contain plugins and identify the
- // renderer in IPC messages.
- virtual gfx::NativeView GetNativeView() = 0;
-
- // Moves all plugin windows as described in the given list.
- virtual void MovePluginWindows(
- const std::vector<webkit::npapi::WebPluginGeometry>& moves) = 0;
-
- // Actually set/take focus to/from the associated View component.
- virtual void Focus() = 0;
- virtual void Blur() = 0;
-
- // Returns true if the View currently has the focus.
- virtual bool HasFocus() = 0;
-
- // Shows/hides the view. These must always be called together in pairs.
- // It is not legal to call Hide() multiple times in a row.
- virtual void Show() = 0;
- virtual void Hide() = 0;
-
- // Whether the view is showing.
- virtual bool IsShowing() = 0;
-
- // Retrieve the bounds of the View, in screen coordinates.
- virtual gfx::Rect GetViewBounds() const = 0;
-
- // Sets the cursor to the one associated with the specified cursor_type
- virtual void UpdateCursor(const WebCursor& cursor) = 0;
-
- // Indicates whether the page has finished loading.
- virtual void SetIsLoading(bool is_loading) = 0;
-
- // Updates the state of the input method attached to the view.
- virtual void ImeUpdateTextInputState(WebKit::WebTextInputType type,
- const gfx::Rect& caret_rect) = 0;
-
- // Cancel the ongoing composition of the input method attached to the view.
- virtual void ImeCancelComposition() = 0;
-
- // Informs the view that a portion of the widget's backing store was scrolled
- // and/or painted. The view should ensure this gets copied to the screen.
- //
- // If the scroll_rect is non-empty, then a portion of the widget's backing
- // store was scrolled by dx pixels horizontally and dy pixels vertically.
- // The exposed rect from the scroll operation is included in copy_rects.
- //
- // There are subtle performance implications here. The RenderWidget gets sent
- // a paint ack after this returns, so if the view only ever invalidates in
- // response to this, then on Windows, where WM_PAINT has lower priority than
- // events which can cause renderer resizes/paint rect updates, e.g.
- // drag-resizing can starve painting; this function thus provides the view its
- // main chance to ensure it stays painted and not just invalidated. On the
- // other hand, if this always blindly paints, then if we're already in the
- // midst of a paint on the callstack, we can double-paint unnecessarily.
- // (Worse, we might recursively call RenderWidgetHost::GetBackingStore().)
- // Thus implementers should generally paint as much of |rect| as possible
- // synchronously with as little overpainting as possible.
- virtual void DidUpdateBackingStore(
- const gfx::Rect& scroll_rect, int scroll_dx, int scroll_dy,
- const std::vector<gfx::Rect>& copy_rects) = 0;
-
- // Notifies the View that the renderer has ceased to exist.
- virtual void RenderViewGone(base::TerminationStatus status,
- int error_code) = 0;
-
- // Notifies the View that the renderer will be delete soon.
- virtual void WillDestroyRenderWidget(RenderWidgetHost* rwh) = 0;
-
- // Tells the View to destroy itself.
- virtual void Destroy() = 0;
-
- // Tells the View that the tooltip text for the current mouse position over
- // the page has changed.
- virtual void SetTooltipText(const std::wstring& tooltip_text) = 0;
-
- // Notifies the View that the renderer text selection has changed.
- virtual void SelectionChanged(const std::string& text) {}
-
- // Tells the View whether the context menu is showing. This is used on Linux
- // to suppress updates to webkit focus for the duration of the show.
- virtual void ShowingContextMenu(bool showing) {}
-
- // Allocate a backing store for this view
- virtual BackingStore* AllocBackingStore(const gfx::Size& size) = 0;
-
-#if defined(OS_MACOSX)
- // Tells the view whether or not to accept first responder status. If |flag|
- // is true, the view does not accept first responder status and instead
- // manually becomes first responder when it receives a mouse down event. If
- // |flag| is false, the view participates in the key-view chain as normal.
- virtual void SetTakesFocusOnlyOnMouseDown(bool flag) = 0;
-
- // Retrieve the bounds of the view, in cocoa view coordinates.
- // If the UI scale factor is 2, |GetViewBounds()| will return a size of e.g.
- // (400, 300) in pixels, while this method will return (200, 150).
- // Even though this returns an gfx::Rect, the result is NOT IN PIXELS.
- virtual gfx::Rect GetViewCocoaBounds() const = 0;
-
- // Get the view's window's position on the screen.
- virtual gfx::Rect GetRootWindowRect() = 0;
-
- // Set the view's active state (i.e., tint state of controls).
- virtual void SetActive(bool active) = 0;
-
- // Notifies the view that its enclosing window has changed visibility
- // (minimized/unminimized, app hidden/unhidden, etc).
- // TODO(stuartmorgan): This is a temporary plugin-specific workaround for
- // <http://crbug.com/34266>. Once that is fixed, this (and the corresponding
- // message and renderer-side handling) can be removed in favor of using
- // WasHidden/DidBecomeSelected.
- virtual void SetWindowVisibility(bool visible) = 0;
-
- // Informs the view that its containing window's frame changed.
- virtual void WindowFrameChanged() = 0;
-
- // Informs the view that a plugin gained or lost focus.
- virtual void PluginFocusChanged(bool focused, int plugin_id) = 0;
-
- // Start plugin IME.
- virtual void StartPluginIme() = 0;
-
- // Does any event handling necessary for plugin IME; should be called after
- // the plugin has already had a chance to process the event. If plugin IME is
- // not enabled, this is a no-op, so it is always safe to call.
- // Returns true if the event was handled by IME.
- virtual bool PostProcessEventForPluginIme(
- const NativeWebKeyboardEvent& event) = 0;
-
- // Methods associated with GPU-accelerated plug-in instances.
- virtual gfx::PluginWindowHandle AllocateFakePluginWindowHandle(
- bool opaque, bool root) = 0;
- virtual void DestroyFakePluginWindowHandle(
- gfx::PluginWindowHandle window) = 0;
- virtual void AcceleratedSurfaceSetIOSurface(
- gfx::PluginWindowHandle window,
- int32 width,
- int32 height,
- uint64 io_surface_identifier) = 0;
- virtual void AcceleratedSurfaceSetTransportDIB(
- gfx::PluginWindowHandle window,
- int32 width,
- int32 height,
- TransportDIB::Handle transport_dib) = 0;
- // |window| and |surface_id| indicate which accelerated surface's
- // buffers swapped. |renderer_id|, |route_id| and
- // |swap_buffers_count| are used to formulate a reply to the GPU
- // process to prevent it from getting too far ahead. They may all be
- // zero, in which case no flow control is enforced; this case is
- // currently used for accelerated plugins.
- virtual void AcceleratedSurfaceBuffersSwapped(
- gfx::PluginWindowHandle window,
- uint64 surface_id,
- int renderer_id,
- int32 route_id,
- int gpu_host_id,
- uint64 swap_buffers_count) = 0;
- virtual void GpuRenderingStateDidChange() = 0;
-#endif
-
-#if defined(TOOLKIT_USES_GTK)
- virtual void CreatePluginContainer(gfx::PluginWindowHandle id) = 0;
- virtual void DestroyPluginContainer(gfx::PluginWindowHandle id) = 0;
- virtual void AcceleratedCompositingActivated(bool activated) = 0;
-#endif
-
-#if defined(OS_WIN)
- virtual void WillWmDestroy() = 0;
- virtual void ShowCompositorHostWindow(bool show) = 0;
-#endif
-
- virtual gfx::PluginWindowHandle AcquireCompositingSurface() = 0;
- virtual void ReleaseCompositingSurface(gfx::PluginWindowHandle surface) = 0;
-
- // Toggles visual muting of the render view area. This is on when a
- // constrained window is showing, for example. |color| is the shade of
- // the overlay that covers the render view. If |animate| is true, the overlay
- // gradually fades in; otherwise it takes effect immediately. To remove the
- // fade effect, pass a NULL value for |color|. In this case, |animate| is
- // ignored.
- virtual void SetVisuallyDeemphasized(const SkColor* color, bool animate) = 0;
-
- void set_popup_type(WebKit::WebPopupType popup_type) {
- popup_type_ = popup_type;
- }
- WebKit::WebPopupType popup_type() const { return popup_type_; }
-
- // Subclasses should override this method to do what is appropriate to set
- // the custom background for their platform.
- virtual void SetBackground(const SkBitmap& background);
- const SkBitmap& background() const { return background_; }
-
- // Returns true if the native view, |native_view|, is contained within in the
- // widget associated with this RenderWidgetHostView.
- virtual bool ContainsNativeView(gfx::NativeView native_view) const = 0;
-
- virtual void UpdateAccessibilityTree(
- const webkit_glue::WebAccessibility& tree) { }
- virtual void OnAccessibilityNotifications(
- const std::vector<ViewHostMsg_AccessibilityNotification_Params>& params) {
- }
-
- gfx::Rect reserved_contents_rect() const {
- return reserved_rect_;
- }
- void set_reserved_contents_rect(const gfx::Rect& reserved_rect) {
- reserved_rect_ = reserved_rect;
- }
-
- protected:
- // Interface class only, do not construct.
- RenderWidgetHostView() : popup_type_(WebKit::WebPopupTypeNone) {}
-
- // Whether this view is a popup and what kind of popup it is (select,
- // autofill...).
- WebKit::WebPopupType popup_type_;
-
- // A custom background to paint behind the web content. This will be tiled
- // horizontally. Can be null, in which case we fall back to painting white.
- SkBitmap background_;
-
- // The current reserved area in view coordinates where contents should not be
- // rendered to draw the resize corner, sidebar mini tabs etc.
- gfx::Rect reserved_rect_;
-
- private:
- DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostView);
-};
+// TODO(jam): remove this file when all files have been converted.
+#include "content/browser/renderer_host/render_widget_host_view.h"
#endif // CHROME_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_H_