summaryrefslogtreecommitdiffstats
path: root/WebCore/page/Frame.h
diff options
context:
space:
mode:
Diffstat (limited to 'WebCore/page/Frame.h')
-rw-r--r--WebCore/page/Frame.h174
1 files changed, 59 insertions, 115 deletions
diff --git a/WebCore/page/Frame.h b/WebCore/page/Frame.h
index 1e6b9b6..c09c330 100644
--- a/WebCore/page/Frame.h
+++ b/WebCore/page/Frame.h
@@ -29,16 +29,13 @@
#define Frame_h
#include "AnimationController.h"
-#include "CSSMutableStyleDeclaration.h"
#include "DragImage.h"
#include "Editor.h"
#include "EventHandler.h"
#include "FrameLoader.h"
#include "FrameTree.h"
#include "ScriptController.h"
-#include "ScrollBehavior.h"
#include "UserScriptTypes.h"
-#include "ZoomMode.h"
#if PLATFORM(WIN)
#include "FrameWin.h"
@@ -67,38 +64,32 @@ namespace WebCore {
class RenderPart;
class TiledBackingStore;
- class Frame : public RefCounted<Frame>
-#if ENABLE(TILED_BACKING_STORE)
- , public TiledBackingStoreClient
+#if !ENABLE(TILED_BACKING_STORE)
+ class TiledBackingStoreClient { };
#endif
- {
+
+ class Frame : public RefCounted<Frame>, public TiledBackingStoreClient {
public:
static PassRefPtr<Frame> create(Page*, HTMLFrameOwnerElement*, FrameLoaderClient*);
- void setView(PassRefPtr<FrameView>);
- ~Frame();
void init();
+ void setView(PassRefPtr<FrameView>);
+ void createView(const IntSize&, const Color&, bool, const IntSize&, bool,
+ ScrollbarMode = ScrollbarAuto, bool horizontalLock = false,
+ ScrollbarMode = ScrollbarAuto, bool verticalLock = false);
- Page* page() const;
- void detachFromPage();
- void transferChildFrameToNewDocument();
-
- HTMLFrameOwnerElement* ownerElement() const;
+ ~Frame();
+ void detachFromPage();
void pageDestroyed();
void disconnectOwnerElement();
+ Page* page() const;
+ HTMLFrameOwnerElement* ownerElement() const;
+
Document* document() const;
FrameView* view() const;
- void setDOMWindow(DOMWindow*);
- void clearFormerDOMWindow(DOMWindow*);
-
- // Unlike many of the accessors in Frame, domWindow() always creates a new DOMWindow if m_domWindow is null.
- // Callers that don't need a new DOMWindow to be created should use existingDOMWindow().
- DOMWindow* domWindow() const;
- DOMWindow* existingDOMWindow() { return m_domWindow.get(); }
-
Editor* editor() const;
EventHandler* eventHandler() const;
FrameLoader* loader() const;
@@ -108,31 +99,30 @@ namespace WebCore {
AnimationController* animation() const;
ScriptController* script();
- RenderView* contentRenderer() const; // root renderer for the document contained in this frame
- RenderPart* ownerRenderer() const; // renderer for the element that contains this frame
+ RenderView* contentRenderer() const; // Root of the render tree for the document contained in this frame.
+ RenderPart* ownerRenderer() const; // Renderer for the element that contains this frame.
+
+ void transferChildFrameToNewDocument();
+
+ // ======== All public functions below this point are candidates to move out of Frame into another class. ========
bool isDisconnected() const;
void setIsDisconnected(bool);
bool excludeFromTextSearch() const;
void setExcludeFromTextSearch(bool);
- void createView(const IntSize&, const Color&, bool, const IntSize &, bool,
- ScrollbarMode = ScrollbarAuto, bool horizontalLock = false,
- ScrollbarMode = ScrollbarAuto, bool verticalLock = false);
-
void injectUserScripts(UserScriptInjectionTime);
String layerTreeAsText() const;
- private:
- void injectUserScriptsForWorld(DOMWrapperWorld*, const UserScriptVector&, UserScriptInjectionTime);
-
- private:
- Frame(Page*, HTMLFrameOwnerElement*, FrameLoaderClient*);
-
- // === undecided, would like to consider moving to another class
+ // Unlike most accessors in this class, domWindow() always creates a new DOMWindow if m_domWindow is null.
+ // Callers that don't need a new DOMWindow to be created should use existingDOMWindow().
+ DOMWindow* domWindow() const;
+ DOMWindow* existingDOMWindow() { return m_domWindow.get(); }
+ void setDOMWindow(DOMWindow*);
+ void clearFormerDOMWindow(DOMWindow*);
+ void clearDOMWindow();
- public:
static Frame* frameForWidget(const Widget*);
Settings* settings() const; // can be NULL
@@ -144,12 +134,16 @@ namespace WebCore {
void setInViewSourceMode(bool = true);
void keepAlive(); // Used to keep the frame alive when running a script that might destroy it.
-#ifndef NDEBUG
static void cancelAllKeepAlive();
-#endif
void setDocument(PassRefPtr<Document>);
+ void setPageZoomFactor(float factor);
+ float pageZoomFactor() const { return m_pageZoomFactor; }
+ void setTextZoomFactor(float factor);
+ float textZoomFactor() const { return m_textZoomFactor; }
+ void setPageAndTextZoomFactors(float pageZoomFactor, float textZoomFactor);
+
#if ENABLE(ORIENTATION_EVENTS)
// Orientation is the interface orientation in degrees. Some examples are:
// 0 is straight up; -90 is when the device is rotated 90 clockwise;
@@ -163,95 +157,40 @@ namespace WebCore {
String documentTypeString() const;
- // This method -- and the corresponding list of former DOM windows --
- // should move onto ScriptController
- void clearDOMWindow();
-
String displayStringModifiedByEncoding(const String& str) const
{
return document() ? document()->displayStringModifiedByEncoding(str) : str;
}
-#if ENABLE(TILED_BACKING_STORE)
- // FIXME: This should be in FrameView, not Frame.
- TiledBackingStore* tiledBackingStore() const { return m_tiledBackingStore.get(); }
- void setTiledBackingStoreEnabled(bool);
-#endif
-
DragImageRef nodeImage(Node*);
DragImageRef dragImageForSelection();
- private:
- void lifeSupportTimerFired(Timer<Frame>*);
-
- // === to be moved into SelectionController
-
- public:
- TextGranularity selectionGranularity() const;
-
- bool shouldChangeSelection(const VisibleSelection&) const;
- bool shouldDeleteSelection(const VisibleSelection&) const;
- void setFocusedNodeIfNeeded();
- void notifyRendererOfSelectionChange(bool userTriggered);
-
- void paintDragCaret(GraphicsContext*, int tx, int ty, const IntRect& clipRect) const;
-
bool isContentEditable() const; // if true, everything in frame is editable
- CSSMutableStyleDeclaration* typingStyle() const;
- void setTypingStyle(CSSMutableStyleDeclaration*);
- void clearTypingStyle();
-
- FloatRect selectionBounds(bool clipToVisibleContent = true) const;
- enum SelectionRectRespectTransforms { RespectTransforms = true, IgnoreTransforms = false };
- void selectionTextRects(Vector<FloatRect>&, SelectionRectRespectTransforms respectTransforms, bool clipToVisibleContent = true) const;
-
- HTMLFormElement* currentForm() const;
-
- void revealSelection(const ScrollAlignment& = ScrollAlignment::alignCenterIfNeeded, bool revealExtent = false);
- void setSelectionFromNone();
-
- SelectionController* dragCaretController() const;
+ VisiblePosition visiblePositionForPoint(const IntPoint& framePoint);
+ Document* documentAtPoint(const IntPoint& windowPoint);
String searchForLabelsAboveCell(RegularExpression*, HTMLTableCellElement*, size_t* resultDistanceFromStartOfCell);
String searchForLabelsBeforeElement(const Vector<String>& labels, Element*, size_t* resultDistance, bool* resultIsInCellAbove);
String matchLabelsAgainstElement(const Vector<String>& labels, Element*);
- VisiblePosition visiblePositionForPoint(const IntPoint& framePoint);
- Document* documentAtPoint(const IntPoint& windowPoint);
-
-#if ENABLE(TILED_BACKING_STORE)
- // FIXME: This should be in FrameView, not Frame.
-
- private:
- // TiledBackingStoreClient interface
- virtual void tiledBackingStorePaintBegin();
- virtual void tiledBackingStorePaint(GraphicsContext*, const IntRect&);
- virtual void tiledBackingStorePaintEnd(const Vector<IntRect>& paintedArea);
- virtual IntRect tiledBackingStoreContentsRect();
- virtual IntRect tiledBackingStoreVisibleRect();
-#endif
-
#if PLATFORM(MAC)
-
- // === undecided, would like to consider moving to another class
-
- public:
- NSString* searchForNSLabelsAboveCell(RegularExpression*, HTMLTableCellElement*, size_t* resultDistanceFromStartOfCell);
NSString* searchForLabelsBeforeElement(NSArray* labels, Element*, size_t* resultDistance, bool* resultIsInCellAbove);
NSString* matchLabelsAgainstElement(NSArray* labels, Element*);
-#if ENABLE(DASHBOARD_SUPPORT)
- NSMutableDictionary* dashboardRegionsDictionary();
-#endif
-
NSImage* selectionImage(bool forceBlackText = false) const;
NSImage* snapshotDragImage(Node*, NSRect* imageRect, NSRect* elementRect) const;
NSImage* imageFromRect(NSRect) const;
-
#endif
+ // ========
+
private:
+ Frame(Page*, HTMLFrameOwnerElement*, FrameLoaderClient*);
+
+ void injectUserScriptsForWorld(DOMWrapperWorld*, const UserScriptVector&, UserScriptInjectionTime);
+ void lifeSupportTimerFired(Timer<Frame>*);
+
Page* m_page;
mutable FrameTree m_treeNode;
mutable FrameLoader m_loader;
@@ -271,10 +210,11 @@ namespace WebCore {
mutable EventHandler m_eventHandler;
mutable AnimationController m_animationController;
- RefPtr<CSSMutableStyleDeclaration> m_typingStyle;
-
Timer<Frame> m_lifeSupportTimer;
+ float m_pageZoomFactor;
+ float m_textZoomFactor;
+
#if ENABLE(ORIENTATION_EVENTS)
int m_orientation;
#endif
@@ -283,7 +223,21 @@ namespace WebCore {
bool m_isDisconnected;
bool m_excludeFromTextSearch;
-#if ENABLE(TILED_BACKING_STORE)
+#if ENABLE(TILED_BACKING_STORE)
+ // FIXME: The tiled backing store belongs in FrameView, not Frame.
+
+ public:
+ TiledBackingStore* tiledBackingStore() const { return m_tiledBackingStore.get(); }
+ void setTiledBackingStoreEnabled(bool);
+
+ private:
+ // TiledBackingStoreClient interface
+ virtual void tiledBackingStorePaintBegin();
+ virtual void tiledBackingStorePaint(GraphicsContext*, const IntRect&);
+ virtual void tiledBackingStorePaintEnd(const Vector<IntRect>& paintedArea);
+ virtual IntRect tiledBackingStoreContentsRect();
+ virtual IntRect tiledBackingStoreVisibleRect();
+
OwnPtr<TiledBackingStore> m_tiledBackingStore;
#endif
};
@@ -333,16 +287,6 @@ namespace WebCore {
return &m_animationController;
}
- inline CSSMutableStyleDeclaration* Frame::typingStyle() const
- {
- return m_typingStyle.get();
- }
-
- inline void Frame::clearTypingStyle()
- {
- m_typingStyle = 0;
- }
-
inline HTMLFrameOwnerElement* Frame::ownerElement() const
{
return m_ownerElement;