| /* |
| * Copyright (C) 2010, 2011 Apple Inc. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * 1. Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * 2. Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. |
| * |
| * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' |
| * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, |
| * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS |
| * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
| * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
| * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF |
| * THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #ifndef WebPageProxy_h |
| #define WebPageProxy_h |
| |
| #include "APIObject.h" |
| #include "APIPolicyClient.h" |
| #include "APISession.h" |
| #include "AutoCorrectionCallback.h" |
| #include "Connection.h" |
| #include "DragControllerAction.h" |
| #include "DrawingAreaProxy.h" |
| #include "EditorState.h" |
| #include "GeolocationPermissionRequestManagerProxy.h" |
| #include "InteractionInformationAtPosition.h" |
| #include "LayerTreeContext.h" |
| #include "MessageSender.h" |
| #include "NotificationPermissionRequestManagerProxy.h" |
| #include "PageLoadState.h" |
| #include "PlatformProcessIdentifier.h" |
| #include "SandboxExtension.h" |
| #include "ShareableBitmap.h" |
| #include "WKBase.h" |
| #include "WKPagePrivate.h" |
| #include "WebColorPicker.h" |
| #include "WebContextMenuItemData.h" |
| #include "WebCoreArgumentCoders.h" |
| #include "WebFindClient.h" |
| #include "WebFormClient.h" |
| #include "WebFrameProxy.h" |
| #include "WebHistoryClient.h" |
| #include "WebHitTestResult.h" |
| #include "WebLoaderClient.h" |
| #include "WebPageContextMenuClient.h" |
| #include "WebPageCreationParameters.h" |
| #include <WebCore/AlternativeTextClient.h> // FIXME: Needed by WebPageProxyMessages.h for DICTATION_ALTERNATIVES. |
| #include "WebPageProxyMessages.h" |
| #include "WebPopupMenuProxy.h" |
| #include "WebUIClient.h" |
| #include <WebCore/Color.h> |
| #include <WebCore/DragActions.h> |
| #include <WebCore/DragSession.h> |
| #include <WebCore/HitTestResult.h> |
| #include <WebCore/Page.h> |
| #include <WebCore/PlatformScreen.h> |
| #include <WebCore/ScrollTypes.h> |
| #include <WebCore/TextChecking.h> |
| #include <WebCore/TextGranularity.h> |
| #include <WebCore/ViewState.h> |
| #include <wtf/HashMap.h> |
| #include <wtf/HashSet.h> |
| #include <wtf/OwnPtr.h> |
| #include <wtf/PassOwnPtr.h> |
| #include <wtf/PassRefPtr.h> |
| #include <wtf/Ref.h> |
| #include <wtf/RefPtr.h> |
| #include <wtf/Vector.h> |
| #include <wtf/text/WTFString.h> |
| |
| #if ENABLE(DRAG_SUPPORT) |
| #include <WebCore/DragActions.h> |
| #include <WebCore/DragSession.h> |
| #endif |
| |
| #if ENABLE(TOUCH_EVENTS) |
| #include "NativeWebTouchEvent.h" |
| #endif |
| |
| #if PLATFORM(EFL) |
| #include "WKPageEfl.h" |
| #include "WebUIPopupMenuClient.h" |
| #include <Evas.h> |
| #endif |
| |
| #if PLATFORM(MAC) |
| #include <WebCore/PlatformLayer.h> |
| #endif |
| |
| namespace API { |
| class URLRequest; |
| } |
| |
| namespace IPC { |
| class ArgumentDecoder; |
| class Connection; |
| } |
| |
| namespace WebCore { |
| class AuthenticationChallenge; |
| class Cursor; |
| class DragData; |
| class FloatRect; |
| class GraphicsLayer; |
| class IntSize; |
| class ProtectionSpace; |
| class SharedBuffer; |
| struct FileChooserSettings; |
| struct TextAlternativeWithRange; |
| struct TextCheckingResult; |
| struct ViewportAttributes; |
| struct WindowFeatures; |
| } |
| |
| #if USE(APPKIT) |
| OBJC_CLASS WKView; |
| #endif |
| |
| #if PLATFORM(GTK) |
| typedef GtkWidget* PlatformWidget; |
| #endif |
| |
| namespace WebKit { |
| |
| class CertificateInfo; |
| class NativeWebKeyboardEvent; |
| class NativeWebMouseEvent; |
| class NativeWebWheelEvent; |
| class PageClient; |
| class RemoteScrollingCoordinatorProxy; |
| class StringPairVector; |
| class WebBackForwardList; |
| class WebBackForwardListItem; |
| class WebColorPickerResultListenerProxy; |
| class WebContextMenuProxy; |
| class WebEditCommandProxy; |
| class WebFullScreenManagerProxy; |
| class WebKeyboardEvent; |
| class WebMouseEvent; |
| class WebOpenPanelResultListenerProxy; |
| class WebPageGroup; |
| class WebProcessProxy; |
| class WebWheelEvent; |
| struct AttributedString; |
| struct ColorSpaceData; |
| struct DictionaryPopupInfo; |
| struct EditorState; |
| struct PlatformPopupMenuData; |
| struct PrintInfo; |
| struct WebPopupItem; |
| |
| #if ENABLE(VIBRATION) |
| class WebVibrationProxy; |
| #endif |
| |
| typedef GenericCallback<WKStringRef, StringImpl*> StringCallback; |
| typedef GenericCallback<WKSerializedScriptValueRef, WebSerializedScriptValue*> ScriptValueCallback; |
| |
| #if PLATFORM(GTK) |
| typedef GenericCallback<WKErrorRef> PrintFinishedCallback; |
| #endif |
| |
| #if ENABLE(TOUCH_EVENTS) |
| struct QueuedTouchEvents { |
| QueuedTouchEvents(const NativeWebTouchEvent& event) |
| : forwardedEvent(event) |
| { |
| } |
| NativeWebTouchEvent forwardedEvent; |
| Vector<NativeWebTouchEvent> deferredTouchEvents; |
| }; |
| #endif |
| |
| // FIXME: Make a version of CallbackBase with three arguments, and define ValidateCommandCallback as a specialization. |
| class ValidateCommandCallback : public CallbackBase { |
| public: |
| typedef void (*CallbackFunction)(WKStringRef, bool, int32_t, WKErrorRef, void*); |
| |
| static PassRefPtr<ValidateCommandCallback> create(void* context, CallbackFunction callback) |
| { |
| return adoptRef(new ValidateCommandCallback(context, callback)); |
| } |
| |
| virtual ~ValidateCommandCallback() |
| { |
| ASSERT(!m_callback); |
| } |
| |
| void performCallbackWithReturnValue(StringImpl* returnValue1, bool returnValue2, int returnValue3) |
| { |
| ASSERT(m_callback); |
| |
| m_callback(toAPI(returnValue1), returnValue2, returnValue3, 0, context()); |
| |
| m_callback = 0; |
| } |
| |
| void invalidate() |
| { |
| ASSERT(m_callback); |
| |
| RefPtr<API::Error> error = API::Error::create(); |
| m_callback(0, 0, 0, toAPI(error.get()), context()); |
| |
| m_callback = 0; |
| } |
| |
| private: |
| |
| ValidateCommandCallback(void* context, CallbackFunction callback) |
| : CallbackBase(context) |
| , m_callback(callback) |
| { |
| } |
| |
| CallbackFunction m_callback; |
| }; |
| |
| #if PLATFORM(IOS) |
| class GestureCallback : public CallbackBase { |
| public: |
| typedef void (*CallbackFunction)(const WebCore::IntPoint&, uint32_t, uint32_t, uint32_t, WKErrorRef, void*); |
| |
| static PassRefPtr<GestureCallback> create(void* context, CallbackFunction callback) |
| { |
| return adoptRef(new GestureCallback(context, callback)); |
| } |
| |
| virtual ~GestureCallback() |
| { |
| ASSERT(!m_callback); |
| } |
| |
| void performCallbackWithReturnValue(const WebCore::IntPoint& returnValue1, uint32_t returnValue2, uint32_t returnValue3, uint32_t returnValue4) |
| { |
| ASSERT(m_callback); |
| |
| m_callback(returnValue1, returnValue2, returnValue3, returnValue4, 0, context()); |
| |
| m_callback = 0; |
| } |
| |
| void invalidate() |
| { |
| ASSERT(m_callback); |
| |
| RefPtr<API::Error> error = API::Error::create(); |
| m_callback(WebCore::IntPoint(), 0, 0, 0, toAPI(error.get()), context()); |
| |
| m_callback = 0; |
| } |
| |
| private: |
| |
| GestureCallback(void* context, CallbackFunction callback) |
| : CallbackBase(context) |
| , m_callback(callback) |
| { |
| ASSERT(m_callback); |
| } |
| |
| CallbackFunction m_callback; |
| }; |
| |
| class TouchesCallback : public CallbackBase { |
| public: |
| typedef void (*CallbackFunction)(const WebCore::IntPoint&, uint32_t, WKErrorRef, void*); |
| |
| static PassRefPtr<TouchesCallback> create(void* context, CallbackFunction callback) |
| { |
| return adoptRef(new TouchesCallback(context, callback)); |
| } |
| |
| virtual ~TouchesCallback() |
| { |
| ASSERT(!m_callback); |
| } |
| |
| void performCallbackWithReturnValue(const WebCore::IntPoint& returnValue1, uint32_t returnValue2) |
| { |
| ASSERT(m_callback); |
| |
| m_callback(returnValue1, returnValue2, 0, context()); |
| |
| m_callback = 0; |
| } |
| |
| void invalidate() |
| { |
| ASSERT(m_callback); |
| |
| RefPtr<API::Error> error = API::Error::create(); |
| m_callback(WebCore::IntPoint(), 0, toAPI(error.get()), context()); |
| |
| m_callback = 0; |
| } |
| |
| private: |
| |
| TouchesCallback(void* context, CallbackFunction callback) |
| : CallbackBase(context) |
| , m_callback(callback) |
| { |
| ASSERT(m_callback); |
| } |
| |
| CallbackFunction m_callback; |
| }; |
| #endif |
| |
| class WebPageProxy : public API::ObjectImpl<API::Object::Type::Page> |
| #if ENABLE(INPUT_TYPE_COLOR) |
| , public WebColorPicker::Client |
| #endif |
| , public WebPopupMenuProxy::Client |
| , public IPC::MessageReceiver |
| , public IPC::MessageSender { |
| public: |
| |
| static PassRefPtr<WebPageProxy> create(PageClient&, WebProcessProxy&, WebPageGroup&, API::Session&, uint64_t pageID); |
| virtual ~WebPageProxy(); |
| |
| void setSession(API::Session&); |
| |
| uint64_t pageID() const { return m_pageID; } |
| uint64_t sessionID() const { return m_session->getID(); } |
| |
| WebFrameProxy* mainFrame() const { return m_mainFrame.get(); } |
| WebFrameProxy* focusedFrame() const { return m_focusedFrame.get(); } |
| WebFrameProxy* frameSetLargestFrame() const { return m_frameSetLargestFrame.get(); } |
| |
| DrawingAreaProxy* drawingArea() const { return m_drawingArea.get(); } |
| |
| #if ENABLE(ASYNC_SCROLLING) |
| RemoteScrollingCoordinatorProxy* scrollingCoordinatorProxy() const { return m_scrollingCoordinatorProxy.get(); } |
| #endif |
| |
| WebBackForwardList& backForwardList() { return m_backForwardList.get(); } |
| |
| #if ENABLE(INSPECTOR) |
| WebInspectorProxy* inspector(); |
| #endif |
| |
| #if ENABLE(VIBRATION) |
| WebVibrationProxy* vibration() { return m_vibration.get(); } |
| #endif |
| |
| #if ENABLE(FULLSCREEN_API) |
| WebFullScreenManagerProxy* fullScreenManager(); |
| #endif |
| |
| #if ENABLE(CONTEXT_MENUS) |
| void initializeContextMenuClient(const WKPageContextMenuClientBase*); |
| #endif |
| void initializeFindClient(const WKPageFindClientBase*); |
| void initializeFindMatchesClient(const WKPageFindMatchesClientBase*); |
| void initializeFormClient(const WKPageFormClientBase*); |
| void initializeLoaderClient(const WKPageLoaderClientBase*); |
| void setPolicyClient(std::unique_ptr<API::PolicyClient>); |
| void initializeUIClient(const WKPageUIClientBase*); |
| #if PLATFORM(EFL) |
| void initializeUIPopupMenuClient(const WKPageUIPopupMenuClientBase*); |
| #endif |
| |
| void initializeWebPage(); |
| |
| void close(); |
| bool tryClose(); |
| bool isClosed() const { return m_isClosed; } |
| |
| void loadURL(const String&, API::Object* userData = nullptr); |
| void loadURLRequest(API::URLRequest*, API::Object* userData = nullptr); |
| void loadFile(const String& fileURL, const String& resourceDirectoryURL, API::Object* userData = nullptr); |
| void loadData(API::Data*, const String& MIMEType, const String& encoding, const String& baseURL, API::Object* userData = nullptr); |
| void loadHTMLString(const String& htmlString, const String& baseURL, API::Object* userData = nullptr); |
| void loadAlternateHTMLString(const String& htmlString, const String& baseURL, const String& unreachableURL, API::Object* userData = nullptr); |
| void loadPlainTextString(const String&, API::Object* userData = nullptr); |
| void loadWebArchiveData(API::Data*, API::Object* userData = nullptr); |
| |
| void stopLoading(); |
| void reload(bool reloadFromOrigin); |
| |
| void goForward(); |
| bool canGoForward() const; |
| void goBack(); |
| bool canGoBack() const; |
| |
| void goToBackForwardItem(WebBackForwardListItem*); |
| void tryRestoreScrollPosition(); |
| void didChangeBackForwardList(WebBackForwardListItem* addedItem, Vector<RefPtr<API::Object>>* removedItems); |
| void willGoToBackForwardListItem(uint64_t itemID, IPC::MessageDecoder&); |
| |
| bool willHandleHorizontalScrollEvents() const; |
| |
| bool canShowMIMEType(const String& mimeType); |
| |
| bool drawsBackground() const { return m_drawsBackground; } |
| void setDrawsBackground(bool); |
| |
| bool drawsTransparentBackground() const { return m_drawsTransparentBackground; } |
| void setDrawsTransparentBackground(bool); |
| |
| WebCore::Color underlayColor() const { return m_underlayColor; } |
| void setUnderlayColor(const WebCore::Color&); |
| |
| void viewWillStartLiveResize(); |
| void viewWillEndLiveResize(); |
| |
| void setInitialFocus(bool forward, bool isKeyboardEventValid, const WebKeyboardEvent&); |
| void setWindowResizerSize(const WebCore::IntSize&); |
| |
| void clearSelection(); |
| |
| void setViewNeedsDisplay(const WebCore::IntRect&); |
| void displayView(); |
| bool canScrollView(); |
| void scrollView(const WebCore::IntRect& scrollRect, const WebCore::IntSize& scrollOffset); |
| |
| enum class WantsReplyOrNot { DoesNotWantReply, DoesWantReply }; |
| void viewStateDidChange(WebCore::ViewState::Flags mayHaveChanged, WantsReplyOrNot = WantsReplyOrNot::DoesNotWantReply); |
| bool isInWindow() const { return m_viewState & WebCore::ViewState::IsInWindow; } |
| void waitForDidUpdateViewState(); |
| |
| WebCore::IntSize viewSize() const; |
| bool isViewVisible() const { return m_viewState & WebCore::ViewState::IsVisible; } |
| bool isViewWindowActive() const; |
| bool isProcessSuppressible() const; |
| |
| void executeEditCommand(const String& commandName); |
| void validateCommand(const String& commandName, PassRefPtr<ValidateCommandCallback>); |
| #if PLATFORM(IOS) |
| void selectWithGesture(const WebCore::IntPoint, WebCore::TextGranularity, uint32_t gestureType, uint32_t gestureState, PassRefPtr<GestureCallback>); |
| void updateSelectionWithTouches(const WebCore::IntPoint, uint32_t touches, bool baseIsStart, PassRefPtr<TouchesCallback>); |
| void selectWithTwoTouches(const WebCore::IntPoint from, const WebCore::IntPoint to, uint32_t gestureType, uint32_t gestureState, PassRefPtr<GestureCallback>); |
| void extendSelection(WebCore::TextGranularity); |
| void requestAutocorrectionData(const String& textForAutocorrection, PassRefPtr<AutocorrectionDataCallback>); |
| void applyAutocorrection(const String& correction, const String& originalText, PassRefPtr<StringCallback>); |
| void requestAutocorrectionContext(PassRefPtr<AutocorrectionContextCallback>); |
| void getAutocorrectionContext(String& contextBefore, String& markedText, String& selectedText, String& contextAfter, uint64_t& location, uint64_t& length); |
| void didReceivePositionInformation(const InteractionInformationAtPosition&); |
| void getPositionInformation(const WebCore::IntPoint&, InteractionInformationAtPosition&); |
| void requestPositionInformation(const WebCore::IntPoint&); |
| #endif |
| |
| const EditorState& editorState() const { return m_editorState; } |
| bool canDelete() const { return hasSelectedRange() && isContentEditable(); } |
| bool hasSelectedRange() const { return m_editorState.selectionIsRange; } |
| bool isContentEditable() const { return m_editorState.isContentEditable; } |
| |
| bool maintainsInactiveSelection() const { return m_maintainsInactiveSelection; } |
| void setMaintainsInactiveSelection(bool); |
| #if USE(TILED_BACKING_STORE) |
| void didRenderFrame(const WebCore::IntSize& contentsSize, const WebCore::IntRect& coveredRect); |
| #endif |
| #if PLATFORM(EFL) |
| void setThemePath(const String&); |
| #endif |
| |
| #if PLATFORM(GTK) |
| void setComposition(const String& text, Vector<WebCore::CompositionUnderline> underlines, uint64_t selectionStart, uint64_t selectionEnd, uint64_t replacementRangeStart, uint64_t replacementRangeEnd); |
| void confirmComposition(const String& compositionString, int64_t selectionStart, int64_t selectionLength); |
| void cancelComposition(); |
| #endif |
| |
| #if PLATFORM(GTK) |
| void setInputMethodState(bool enabled); |
| #endif |
| |
| #if PLATFORM(MAC) |
| void windowAndViewFramesChanged(const WebCore::FloatRect& viewFrameInWindowCoordinates, const WebCore::FloatPoint& accessibilityViewCoordinates); |
| void setMainFrameIsScrollable(bool); |
| |
| void setComposition(const String& text, Vector<WebCore::CompositionUnderline> underlines, uint64_t selectionStart, uint64_t selectionEnd, uint64_t replacementRangeStart, uint64_t replacementRangeEnd); |
| void confirmComposition(); |
| void cancelComposition(); |
| bool insertText(const String& text, uint64_t replacementRangeStart, uint64_t replacementRangeEnd); |
| bool insertDictatedText(const String& text, uint64_t replacementRangeStart, uint64_t replacementRangeEnd, const Vector<WebCore::TextAlternativeWithRange>& dictationAlternatives); |
| void getMarkedRange(uint64_t& location, uint64_t& length); |
| void getSelectedRange(uint64_t& location, uint64_t& length); |
| void getAttributedSubstringFromRange(uint64_t location, uint64_t length, AttributedString&); |
| uint64_t characterIndexForPoint(const WebCore::IntPoint); |
| WebCore::IntRect firstRectForCharacterRange(uint64_t, uint64_t); |
| bool executeKeypressCommands(const Vector<WebCore::KeypressCommand>&); |
| |
| void sendComplexTextInputToPlugin(uint64_t pluginComplexTextInputIdentifier, const String& textInput); |
| bool shouldDelayWindowOrderingForEvent(const WebMouseEvent&); |
| bool acceptsFirstMouse(int eventNumber, const WebMouseEvent&); |
| |
| void setAcceleratedCompositingRootLayer(PlatformLayer* rootLayer); |
| |
| #if USE(APPKIT) |
| WKView* wkView() const; |
| void intrinsicContentSizeDidChange(const WebCore::IntSize& intrinsicContentSize); |
| #endif |
| #endif // PLATFORM(MAC) |
| #if PLATFORM(EFL) |
| void handleInputMethodKeydown(bool& handled); |
| void confirmComposition(const String&); |
| void setComposition(const String&, Vector<WebCore::CompositionUnderline>&, int); |
| void cancelComposition(); |
| #endif |
| #if PLATFORM(GTK) |
| PlatformWidget viewWidget(); |
| #endif |
| #if USE(TILED_BACKING_STORE) |
| void commitPageTransitionViewport(); |
| #endif |
| |
| void handleMouseEvent(const NativeWebMouseEvent&); |
| void handleWheelEvent(const NativeWebWheelEvent&); |
| void handleKeyboardEvent(const NativeWebKeyboardEvent&); |
| #if ENABLE(TOUCH_EVENTS) |
| void handleTouchEvent(const NativeWebTouchEvent&); |
| #endif |
| |
| void scrollBy(WebCore::ScrollDirection, WebCore::ScrollGranularity); |
| void centerSelectionInVisibleArea(); |
| |
| const String& toolTip() const { return m_toolTip; } |
| |
| const String& userAgent() const { return m_userAgent; } |
| void setApplicationNameForUserAgent(const String&); |
| const String& applicationNameForUserAgent() const { return m_applicationNameForUserAgent; } |
| void setCustomUserAgent(const String&); |
| const String& customUserAgent() const { return m_customUserAgent; } |
| static String standardUserAgent(const String& applicationName = String()); |
| |
| bool supportsTextEncoding() const; |
| void setCustomTextEncodingName(const String&); |
| String customTextEncodingName() const { return m_customTextEncodingName; } |
| |
| bool areActiveDOMObjectsAndAnimationsSuspended() const { return m_isPageSuspended; } |
| void resumeActiveDOMObjectsAndAnimations(); |
| void suspendActiveDOMObjectsAndAnimations(); |
| |
| double estimatedProgress() const; |
| |
| void terminateProcess(); |
| |
| typedef bool (*WebPageProxySessionStateFilterCallback)(WKPageRef, WKStringRef type, WKTypeRef object, void* context); |
| PassRefPtr<API::Data> sessionStateData(WebPageProxySessionStateFilterCallback, void* context) const; |
| void restoreFromSessionStateData(API::Data*); |
| |
| bool supportsTextZoom() const; |
| double textZoomFactor() const { return m_textZoomFactor; } |
| void setTextZoomFactor(double); |
| double pageZoomFactor() const { return m_pageZoomFactor; } |
| void setPageZoomFactor(double); |
| void setPageAndTextZoomFactors(double pageZoomFactor, double textZoomFactor); |
| |
| void scalePage(double scale, const WebCore::IntPoint& origin); |
| double pageScaleFactor() const { return m_pageScaleFactor; } |
| |
| float deviceScaleFactor() const; |
| void setIntrinsicDeviceScaleFactor(float); |
| void setCustomDeviceScaleFactor(float); |
| void windowScreenDidChange(PlatformDisplayID); |
| |
| void setUseFixedLayout(bool); |
| void setFixedLayoutSize(const WebCore::IntSize&); |
| bool useFixedLayout() const { return m_useFixedLayout; }; |
| const WebCore::IntSize& fixedLayoutSize() const { return m_fixedLayoutSize; }; |
| |
| void listenForLayoutMilestones(WebCore::LayoutMilestones); |
| |
| void setVisibilityStatePrerender(); |
| void didUpdateViewState() { m_waitingForDidUpdateViewState = false; } |
| |
| bool hasHorizontalScrollbar() const { return m_mainFrameHasHorizontalScrollbar; } |
| bool hasVerticalScrollbar() const { return m_mainFrameHasVerticalScrollbar; } |
| |
| void setSuppressScrollbarAnimations(bool); |
| bool areScrollbarAnimationsSuppressed() const { return m_suppressScrollbarAnimations; } |
| |
| bool isPinnedToLeftSide() const { return m_mainFrameIsPinnedToLeftSide; } |
| bool isPinnedToRightSide() const { return m_mainFrameIsPinnedToRightSide; } |
| bool isPinnedToTopSide() const { return m_mainFrameIsPinnedToTopSide; } |
| bool isPinnedToBottomSide() const { return m_mainFrameIsPinnedToBottomSide; } |
| |
| bool rubberBandsAtLeft() const; |
| void setRubberBandsAtLeft(bool); |
| bool rubberBandsAtRight() const; |
| void setRubberBandsAtRight(bool); |
| bool rubberBandsAtTop() const; |
| void setRubberBandsAtTop(bool); |
| bool rubberBandsAtBottom() const; |
| void setRubberBandsAtBottom(bool); |
| |
| void setBackgroundExtendsBeyondPage(bool); |
| bool backgroundExtendsBeyondPage() const; |
| |
| void setPaginationMode(WebCore::Pagination::Mode); |
| WebCore::Pagination::Mode paginationMode() const { return m_paginationMode; } |
| void setPaginationBehavesLikeColumns(bool); |
| bool paginationBehavesLikeColumns() const { return m_paginationBehavesLikeColumns; } |
| void setPageLength(double); |
| double pageLength() const { return m_pageLength; } |
| void setGapBetweenPages(double); |
| double gapBetweenPages() const { return m_gapBetweenPages; } |
| unsigned pageCount() const { return m_pageCount; } |
| |
| #if PLATFORM(MAC) |
| // Called by the web process through a message. |
| void registerWebProcessAccessibilityToken(const IPC::DataReference&); |
| // Called by the UI process when it is ready to send its tokens to the web process. |
| void registerUIProcessAccessibilityTokens(const IPC::DataReference& elemenToken, const IPC::DataReference& windowToken); |
| bool readSelectionFromPasteboard(const String& pasteboardName); |
| String stringSelectionForPasteboard(); |
| PassRefPtr<WebCore::SharedBuffer> dataSelectionForPasteboard(const String& pasteboardType); |
| void makeFirstResponder(); |
| |
| ColorSpaceData colorSpace(); |
| #endif |
| |
| void pageScaleFactorDidChange(double); |
| void pageZoomFactorDidChange(double); |
| |
| void setMemoryCacheClientCallsEnabled(bool); |
| |
| // Find. |
| void findString(const String&, FindOptions, unsigned maxMatchCount); |
| void findStringMatches(const String&, FindOptions, unsigned maxMatchCount); |
| void getImageForFindMatch(int32_t matchIndex); |
| void selectFindMatch(int32_t matchIndex); |
| void didGetImageForFindMatch(const ShareableBitmap::Handle& contentImageHandle, uint32_t matchIndex); |
| void hideFindUI(); |
| void countStringMatches(const String&, FindOptions, unsigned maxMatchCount); |
| void didCountStringMatches(const String&, uint32_t matchCount); |
| void setFindIndicator(const WebCore::FloatRect& selectionRectInWindowCoordinates, const Vector<WebCore::FloatRect>& textRectsInSelectionRectCoordinates, float contentImageScaleFactor, const ShareableBitmap::Handle& contentImageHandle, bool fadeOut, bool animate); |
| void didFindString(const String&, uint32_t matchCount); |
| void didFailToFindString(const String&); |
| void didFindStringMatches(const String&, Vector<Vector<WebCore::IntRect>> matchRects, int32_t firstIndexAfterSelection); |
| |
| void getContentsAsString(PassRefPtr<StringCallback>); |
| #if ENABLE(MHTML) |
| void getContentsAsMHTMLData(PassRefPtr<DataCallback>, bool useBinaryEncoding); |
| #endif |
| void getMainResourceDataOfFrame(WebFrameProxy*, PassRefPtr<DataCallback>); |
| void getResourceDataFromFrame(WebFrameProxy*, API::URL*, PassRefPtr<DataCallback>); |
| void getRenderTreeExternalRepresentation(PassRefPtr<StringCallback>); |
| void getSelectionOrContentsAsString(PassRefPtr<StringCallback>); |
| void getSelectionAsWebArchiveData(PassRefPtr<DataCallback>); |
| void getSourceForFrame(WebFrameProxy*, PassRefPtr<StringCallback>); |
| void getWebArchiveOfFrame(WebFrameProxy*, PassRefPtr<DataCallback>); |
| void runJavaScriptInMainFrame(const String&, PassRefPtr<ScriptValueCallback>); |
| void forceRepaint(PassRefPtr<VoidCallback>); |
| |
| float headerHeight(WebFrameProxy*); |
| float footerHeight(WebFrameProxy*); |
| void drawHeader(WebFrameProxy*, const WebCore::FloatRect&); |
| void drawFooter(WebFrameProxy*, const WebCore::FloatRect&); |
| |
| #if PLATFORM(MAC) |
| // Dictionary. |
| void performDictionaryLookupAtLocation(const WebCore::FloatPoint&); |
| #endif |
| |
| void receivedPolicyDecision(WebCore::PolicyAction, WebFrameProxy*, uint64_t listenerID); |
| |
| void backForwardRemovedItem(uint64_t itemID); |
| |
| #if ENABLE(DRAG_SUPPORT) |
| // Drag and drop support. |
| void dragEntered(WebCore::DragData&, const String& dragStorageName = String()); |
| void dragUpdated(WebCore::DragData&, const String& dragStorageName = String()); |
| void dragExited(WebCore::DragData&, const String& dragStorageName = String()); |
| void performDrag(WebCore::DragData&, const String& dragStorageName, const SandboxExtension::Handle&, const SandboxExtension::HandleArray&); |
| |
| void didPerformDragControllerAction(WebCore::DragSession); |
| void dragEnded(const WebCore::IntPoint& clientPosition, const WebCore::IntPoint& globalPosition, uint64_t operation); |
| #if PLATFORM(MAC) |
| void setDragImage(const WebCore::IntPoint& clientPosition, const ShareableBitmap::Handle& dragImageHandle, bool isLinkDrag); |
| void setPromisedData(const String& pasteboardName, const SharedMemory::Handle& imageHandle, uint64_t imageSize, const String& filename, const String& extension, |
| const String& title, const String& url, const String& visibleURL, const SharedMemory::Handle& archiveHandle, uint64_t archiveSize); |
| #endif |
| #if PLATFORM(GTK) |
| void startDrag(const WebCore::DragData&, const ShareableBitmap::Handle& dragImage); |
| #endif |
| #endif |
| |
| void processDidBecomeUnresponsive(); |
| void interactionOccurredWhileProcessUnresponsive(); |
| void processDidBecomeResponsive(); |
| void processDidCrash(); |
| |
| #if USE(ACCELERATED_COMPOSITING) |
| virtual void enterAcceleratedCompositingMode(const LayerTreeContext&); |
| virtual void exitAcceleratedCompositingMode(); |
| virtual void updateAcceleratedCompositingMode(const LayerTreeContext&); |
| #endif |
| |
| void didDraw(); |
| |
| enum UndoOrRedo { Undo, Redo }; |
| void addEditCommand(WebEditCommandProxy*); |
| void removeEditCommand(WebEditCommandProxy*); |
| bool isValidEditCommand(WebEditCommandProxy*); |
| void registerEditCommand(PassRefPtr<WebEditCommandProxy>, UndoOrRedo); |
| |
| #if PLATFORM(MAC) |
| void registerKeypressCommandName(const String& name) { m_knownKeypressCommandNames.add(name); } |
| bool isValidKeypressCommandName(const String& name) const { return m_knownKeypressCommandNames.contains(name); } |
| #endif |
| |
| WebProcessProxy& process() { return m_process.get(); } |
| PlatformProcessIdentifier processIdentifier() const; |
| |
| WebPageGroup& pageGroup() { return m_pageGroup.get(); } |
| |
| bool isValid() const; |
| |
| PassRefPtr<API::Array> relatedPages() const; |
| |
| const String& urlAtProcessExit() const { return m_urlAtProcessExit; } |
| FrameLoadState::State loadStateAtProcessExit() const { return m_loadStateAtProcessExit; } |
| |
| #if ENABLE(DRAG_SUPPORT) |
| WebCore::DragSession dragSession() const { return m_currentDragSession; } |
| void resetDragOperation() { m_currentDragSession = WebCore::DragSession(); } |
| #endif |
| |
| void preferencesDidChange(); |
| |
| #if ENABLE(CONTEXT_MENUS) |
| // Called by the WebContextMenuProxy. |
| void contextMenuItemSelected(const WebContextMenuItemData&); |
| #endif |
| |
| // Called by the WebOpenPanelResultListenerProxy. |
| void didChooseFilesForOpenPanel(const Vector<String>&); |
| void didCancelForOpenPanel(); |
| |
| WebPageCreationParameters creationParameters(); |
| |
| #if USE(COORDINATED_GRAPHICS) |
| void findZoomableAreaForPoint(const WebCore::IntPoint&, const WebCore::IntSize&); |
| #endif |
| |
| #if PLATFORM(EFL) || PLATFORM(GTK) |
| void handleDownloadRequest(DownloadProxy*); |
| #endif |
| |
| void advanceToNextMisspelling(bool startBeforeSelection); |
| void changeSpellingToWord(const String& word); |
| #if USE(APPKIT) |
| void uppercaseWord(); |
| void lowercaseWord(); |
| void capitalizeWord(); |
| #endif |
| |
| #if PLATFORM(MAC) |
| bool isSmartInsertDeleteEnabled() const { return m_isSmartInsertDeleteEnabled; } |
| void setSmartInsertDeleteEnabled(bool); |
| #endif |
| |
| #if PLATFORM(GTK) |
| String accessibilityPlugID() const { return m_accessibilityPlugID; } |
| #endif |
| |
| void setCanRunModal(bool); |
| bool canRunModal(); |
| |
| void beginPrinting(WebFrameProxy*, const PrintInfo&); |
| void endPrinting(); |
| void computePagesForPrinting(WebFrameProxy*, const PrintInfo&, PassRefPtr<ComputedPagesCallback>); |
| #if PLATFORM(MAC) |
| void drawRectToImage(WebFrameProxy*, const PrintInfo&, const WebCore::IntRect&, const WebCore::IntSize&, PassRefPtr<ImageCallback>); |
| void drawPagesToPDF(WebFrameProxy*, const PrintInfo&, uint32_t first, uint32_t count, PassRefPtr<DataCallback>); |
| #elif PLATFORM(GTK) |
| void drawPagesForPrinting(WebFrameProxy*, const PrintInfo&, PassRefPtr<PrintFinishedCallback>); |
| #endif |
| |
| PageLoadState& pageLoadState() { return m_pageLoadState; } |
| |
| #if PLATFORM(MAC) |
| void handleAlternativeTextUIResult(const String& result); |
| #endif |
| |
| void saveDataToFileInDownloadsFolder(const String& suggestedFilename, const String& mimeType, const String& originatingURLString, API::Data*); |
| void savePDFToFileInDownloadsFolder(const String& suggestedFilename, const String& originatingURLString, const IPC::DataReference&); |
| #if PLATFORM(MAC) |
| void savePDFToTemporaryFolderAndOpenWithNativeApplicationRaw(const String& suggestedFilename, const String& originatingURLString, const uint8_t* data, unsigned long size, const String& pdfUUID); |
| void savePDFToTemporaryFolderAndOpenWithNativeApplication(const String& suggestedFilename, const String& originatingURLString, const IPC::DataReference&, const String& pdfUUID); |
| void openPDFFromTemporaryFolderWithNativeApplication(const String& pdfUUID); |
| #endif |
| |
| WebCore::IntRect visibleScrollerThumbRect() const { return m_visibleScrollerThumbRect; } |
| |
| uint64_t renderTreeSize() const { return m_renderTreeSize; } |
| |
| void setShouldSendEventsSynchronously(bool sync) { m_shouldSendEventsSynchronously = sync; }; |
| |
| void printMainFrame(); |
| |
| void setMediaVolume(float); |
| void setMayStartMediaWhenInWindow(bool); |
| |
| // WebPopupMenuProxy::Client |
| virtual NativeWebMouseEvent* currentlyProcessedMouseDownEvent(); |
| |
| #if PLATFORM(GTK) && USE(TEXTURE_MAPPER_GL) |
| void setAcceleratedCompositingWindowId(uint64_t nativeWindowId); |
| #endif |
| |
| void setSuppressVisibilityUpdates(bool flag) { m_suppressVisibilityUpdates = flag; } |
| bool suppressVisibilityUpdates() { return m_suppressVisibilityUpdates; } |
| |
| #if PLATFORM(IOS) |
| void didFinishScrolling(const WebCore::FloatPoint& contentOffset); |
| void didFinishZooming(float newScale); |
| |
| void tapHighlightAtPosition(const WebCore::FloatPoint&, uint64_t& requestID); |
| |
| void blurAssistedNode(); |
| #endif |
| |
| void postMessageToInjectedBundle(const String& messageName, API::Object* messageBody); |
| |
| #if ENABLE(INPUT_TYPE_COLOR) |
| void setColorPickerColor(const WebCore::Color&); |
| void endColorPicker(); |
| #endif |
| |
| const WebLoaderClient& loaderClient() { return m_loaderClient; } |
| |
| WebCore::IntSize minimumLayoutSize() const { return m_minimumLayoutSize; } |
| void setMinimumLayoutSize(const WebCore::IntSize&); |
| |
| bool autoSizingShouldExpandToViewHeight() const { return m_autoSizingShouldExpandToViewHeight; } |
| void setAutoSizingShouldExpandToViewHeight(bool); |
| |
| bool mainFrameInViewSourceMode() const { return m_mainFrameInViewSourceMode; } |
| void setMainFrameInViewSourceMode(bool); |
| |
| void didReceiveAuthenticationChallengeProxy(uint64_t frameID, PassRefPtr<AuthenticationChallengeProxy>); |
| |
| int64_t spellDocumentTag(); |
| void didFinishCheckingText(uint64_t requestID, const Vector<WebCore::TextCheckingResult>&); |
| void didCancelCheckingText(uint64_t requestID); |
| |
| void connectionWillOpen(IPC::Connection*); |
| void connectionWillClose(IPC::Connection*); |
| |
| void didSaveToPageCache(); |
| |
| void setScrollPinningBehavior(WebCore::ScrollPinningBehavior); |
| WebCore::ScrollPinningBehavior scrollPinningBehavior() { return m_scrollPinningBehavior; } |
| |
| private: |
| WebPageProxy(PageClient&, WebProcessProxy&, WebPageGroup&, API::Session&, uint64_t pageID); |
| void platformInitialize(); |
| |
| void updateViewState(WebCore::ViewState::Flags flagsToUpdate = WebCore::ViewState::AllFlags); |
| |
| void resetState(); |
| void resetStateAfterProcessExited(); |
| |
| void setUserAgent(const String&); |
| |
| // IPC::MessageReceiver |
| virtual void didReceiveMessage(IPC::Connection*, IPC::MessageDecoder&) override; |
| virtual void didReceiveSyncMessage(IPC::Connection*, IPC::MessageDecoder&, std::unique_ptr<IPC::MessageEncoder>&) override; |
| |
| // IPC::MessageSender |
| virtual bool sendMessage(std::unique_ptr<IPC::MessageEncoder>, unsigned messageSendFlags) override; |
| virtual IPC::Connection* messageSenderConnection() override; |
| virtual uint64_t messageSenderDestinationID() override; |
| |
| // WebPopupMenuProxy::Client |
| virtual void valueChangedForPopupMenu(WebPopupMenuProxy*, int32_t newSelectedIndex); |
| virtual void setTextFromItemForPopupMenu(WebPopupMenuProxy*, int32_t index); |
| #if PLATFORM(GTK) |
| virtual void failedToShowPopupMenu(); |
| #endif |
| |
| // Implemented in generated WebPageProxyMessageReceiver.cpp |
| void didReceiveWebPageProxyMessage(IPC::Connection*, IPC::MessageDecoder&); |
| void didReceiveSyncWebPageProxyMessage(IPC::Connection*, IPC::MessageDecoder&, std::unique_ptr<IPC::MessageEncoder>&); |
| |
| void didCreateMainFrame(uint64_t frameID); |
| void didCreateSubframe(uint64_t frameID); |
| |
| void didStartProvisionalLoadForFrame(uint64_t frameID, const String& url, const String& unreachableURL, IPC::MessageDecoder&); |
| void didReceiveServerRedirectForProvisionalLoadForFrame(uint64_t frameID, const String&, IPC::MessageDecoder&); |
| void didFailProvisionalLoadForFrame(uint64_t frameID, const WebCore::ResourceError&, IPC::MessageDecoder&); |
| void didCommitLoadForFrame(uint64_t frameID, const String& mimeType, uint32_t frameLoadType, const WebCore::CertificateInfo&, IPC::MessageDecoder&); |
| void didFinishDocumentLoadForFrame(uint64_t frameID, IPC::MessageDecoder&); |
| void didFinishLoadForFrame(uint64_t frameID, IPC::MessageDecoder&); |
| void didFailLoadForFrame(uint64_t frameID, const WebCore::ResourceError&, IPC::MessageDecoder&); |
| void didSameDocumentNavigationForFrame(uint64_t frameID, uint32_t sameDocumentNavigationType, const String&, IPC::MessageDecoder&); |
| void didReceiveTitleForFrame(uint64_t frameID, const String&, IPC::MessageDecoder&); |
| void didFirstLayoutForFrame(uint64_t frameID, IPC::MessageDecoder&); |
| void didFirstVisuallyNonEmptyLayoutForFrame(uint64_t frameID, IPC::MessageDecoder&); |
| void didLayout(uint32_t layoutMilestones, IPC::MessageDecoder&); |
| void didRemoveFrameFromHierarchy(uint64_t frameID, IPC::MessageDecoder&); |
| void didDisplayInsecureContentForFrame(uint64_t frameID, IPC::MessageDecoder&); |
| void didRunInsecureContentForFrame(uint64_t frameID, IPC::MessageDecoder&); |
| void didDetectXSSForFrame(uint64_t frameID, IPC::MessageDecoder&); |
| void frameDidBecomeFrameSet(uint64_t frameID, bool); |
| void didStartProgress(); |
| void didChangeProgress(double); |
| void didFinishProgress(); |
| |
| void decidePolicyForNavigationAction(uint64_t frameID, uint32_t navigationType, uint32_t modifiers, int32_t mouseButton, uint64_t originatingFrameID, const WebCore::ResourceRequest& originalRequest, const WebCore::ResourceRequest& request, uint64_t listenerID, IPC::MessageDecoder&, bool& receivedPolicyAction, uint64_t& policyAction, uint64_t& downloadID); |
| void decidePolicyForNewWindowAction(uint64_t frameID, uint32_t navigationType, uint32_t modifiers, int32_t mouseButton, const WebCore::ResourceRequest&, const String& frameName, uint64_t listenerID, IPC::MessageDecoder&); |
| void decidePolicyForResponse(uint64_t frameID, const WebCore::ResourceResponse&, const WebCore::ResourceRequest&, bool canShowMIMEType, uint64_t listenerID, IPC::MessageDecoder&); |
| void decidePolicyForResponseSync(uint64_t frameID, const WebCore::ResourceResponse&, const WebCore::ResourceRequest&, bool canShowMIMEType, uint64_t listenerID, IPC::MessageDecoder&, bool& receivedPolicyAction, uint64_t& policyAction, uint64_t& downloadID); |
| void unableToImplementPolicy(uint64_t frameID, const WebCore::ResourceError&, IPC::MessageDecoder&); |
| |
| void willSubmitForm(uint64_t frameID, uint64_t sourceFrameID, const Vector<std::pair<String, String>>& textFieldValues, uint64_t listenerID, IPC::MessageDecoder&); |
| |
| // UI client |
| void createNewPage(const WebCore::ResourceRequest&, const WebCore::WindowFeatures&, uint32_t modifiers, int32_t mouseButton, uint64_t& newPageID, WebPageCreationParameters&); |
| void showPage(); |
| void closePage(bool stopResponsivenessTimer); |
| void runJavaScriptAlert(uint64_t frameID, const String&); |
| void runJavaScriptConfirm(uint64_t frameID, const String&, bool& result); |
| void runJavaScriptPrompt(uint64_t frameID, const String&, const String&, String& result); |
| void shouldInterruptJavaScript(bool& result); |
| void setStatusText(const String&); |
| void mouseDidMoveOverElement(const WebHitTestResult::Data& hitTestResultData, uint32_t modifiers, IPC::MessageDecoder&); |
| #if ENABLE(NETSCAPE_PLUGIN_API) |
| void unavailablePluginButtonClicked(uint32_t opaquePluginUnavailabilityReason, const String& mimeType, const String& pluginURLString, const String& pluginsPageURLString, const String& frameURLString, const String& pageURLString); |
| #endif // ENABLE(NETSCAPE_PLUGIN_API) |
| #if ENABLE(WEBGL) |
| void webGLPolicyForURL(const String& url, uint32_t& loadPolicy); |
| #endif // ENABLE(WEBGL) |
| void setToolbarsAreVisible(bool toolbarsAreVisible); |
| void getToolbarsAreVisible(bool& toolbarsAreVisible); |
| void setMenuBarIsVisible(bool menuBarIsVisible); |
| void getMenuBarIsVisible(bool& menuBarIsVisible); |
| void setStatusBarIsVisible(bool statusBarIsVisible); |
| void getStatusBarIsVisible(bool& statusBarIsVisible); |
| void setIsResizable(bool isResizable); |
| void getIsResizable(bool& isResizable); |
| void setWindowFrame(const WebCore::FloatRect&); |
| void getWindowFrame(WebCore::FloatRect&); |
| void screenToWindow(const WebCore::IntPoint& screenPoint, WebCore::IntPoint& windowPoint); |
| void windowToScreen(const WebCore::IntRect& viewRect, WebCore::IntRect& result); |
| void runBeforeUnloadConfirmPanel(const String& message, uint64_t frameID, bool& shouldClose); |
| void didChangeViewportProperties(const WebCore::ViewportAttributes&); |
| void pageDidScroll(); |
| void runOpenPanel(uint64_t frameID, const WebCore::FileChooserSettings&); |
| void printFrame(uint64_t frameID); |
| void exceededDatabaseQuota(uint64_t frameID, const String& originIdentifier, const String& databaseName, const String& displayName, uint64_t currentQuota, uint64_t currentOriginUsage, uint64_t currentDatabaseUsage, uint64_t expectedUsage, PassRefPtr<Messages::WebPageProxy::ExceededDatabaseQuota::DelayedReply>); |
| void requestGeolocationPermissionForFrame(uint64_t geolocationID, uint64_t frameID, String originIdentifier); |
| void runModal(); |
| void notifyScrollerThumbIsVisibleInRect(const WebCore::IntRect&); |
| void recommendedScrollbarStyleDidChange(int32_t newStyle); |
| void didChangeScrollbarsForMainFrame(bool hasHorizontalScrollbar, bool hasVerticalScrollbar); |
| void didChangeScrollOffsetPinningForMainFrame(bool pinnedToLeftSide, bool pinnedToRightSide, bool pinnedToTopSide, bool pinnedToBottomSide); |
| void didChangePageCount(unsigned); |
| #if ENABLE(NETSCAPE_PLUGIN_API) |
| void didFailToInitializePlugin(const String& mimeType, const String& frameURLString, const String& pageURLString); |
| void didBlockInsecurePluginVersion(const String& mimeType, const String& pluginURLString, const String& frameURLString, const String& pageURLString, bool replacementObscured); |
| #endif // ENABLE(NETSCAPE_PLUGIN_API) |
| void setCanShortCircuitHorizontalWheelEvents(bool canShortCircuitHorizontalWheelEvents) { m_canShortCircuitHorizontalWheelEvents = canShortCircuitHorizontalWheelEvents; } |
| |
| void reattachToWebProcess(); |
| void reattachToWebProcessWithItem(WebBackForwardListItem*); |
| |
| void requestNotificationPermission(uint64_t notificationID, const String& originString); |
| void showNotification(const String& title, const String& body, const String& iconURL, const String& tag, const String& lang, const String& dir, const String& originString, uint64_t notificationID); |
| void cancelNotification(uint64_t notificationID); |
| void clearNotifications(const Vector<uint64_t>& notificationIDs); |
| void didDestroyNotification(uint64_t notificationID); |
| |
| #if USE(TILED_BACKING_STORE) |
| void pageDidRequestScroll(const WebCore::IntPoint&); |
| void pageTransitionViewportReady(); |
| #endif |
| #if USE(COORDINATED_GRAPHICS) |
| void didFindZoomableArea(const WebCore::IntPoint&, const WebCore::IntRect&); |
| #endif |
| #if PLATFORM(EFL) || PLATFORM(IOS) |
| void didChangeContentSize(const WebCore::IntSize&); |
| #endif |
| |
| #if ENABLE(TOUCH_EVENTS) |
| void needTouchEvents(bool); |
| #endif |
| |
| #if ENABLE(INPUT_TYPE_COLOR) |
| void showColorPicker(const WebCore::Color& initialColor, const WebCore::IntRect&); |
| void didChooseColor(const WebCore::Color&); |
| void didEndColorPicker(); |
| #endif |
| |
| void editorStateChanged(const EditorState&); |
| |
| // Back/Forward list management |
| void backForwardAddItem(uint64_t itemID); |
| void backForwardGoToItem(uint64_t itemID, SandboxExtension::Handle&); |
| void backForwardItemAtIndex(int32_t index, uint64_t& itemID); |
| void backForwardBackListCount(int32_t& count); |
| void backForwardForwardListCount(int32_t& count); |
| void backForwardClear(); |
| |
| // Undo management |
| void registerEditCommandForUndo(uint64_t commandID, uint32_t editAction); |
| void clearAllEditCommands(); |
| void canUndoRedo(uint32_t action, bool& result); |
| void executeUndoRedo(uint32_t action, bool& result); |
| |
| // Keyboard handling |
| #if PLATFORM(MAC) |
| void interpretQueuedKeyEvent(const EditorState&, bool& handled, Vector<WebCore::KeypressCommand>&); |
| void executeSavedCommandBySelector(const String& selector, bool& handled); |
| #endif |
| |
| #if PLATFORM(GTK) |
| void getEditorCommandsForKeyEvent(const AtomicString&, Vector<String>&); |
| void bindAccessibilityTree(const String&); |
| #endif |
| #if PLATFORM(EFL) |
| void getEditorCommandsForKeyEvent(Vector<String>&); |
| #endif |
| |
| // Popup Menu. |
| void showPopupMenu(const WebCore::IntRect& rect, uint64_t textDirection, const Vector<WebPopupItem>& items, int32_t selectedIndex, const PlatformPopupMenuData&); |
| void hidePopupMenu(); |
| |
| #if ENABLE(CONTEXT_MENUS) |
| // Context Menu. |
| void showContextMenu(const WebCore::IntPoint& menuLocation, const WebHitTestResult::Data&, const Vector<WebContextMenuItemData>&, IPC::MessageDecoder&); |
| void internalShowContextMenu(const WebCore::IntPoint& menuLocation, const WebHitTestResult::Data&, const Vector<WebContextMenuItemData>&, IPC::MessageDecoder&); |
| #endif |
| |
| // Search popup results |
| void saveRecentSearches(const String&, const Vector<String>&); |
| void loadRecentSearches(const String&, Vector<String>&); |
| |
| #if PLATFORM(MAC) |
| // Speech. |
| void getIsSpeaking(bool&); |
| void speak(const String&); |
| void stopSpeaking(); |
| |
| // Spotlight. |
| void searchWithSpotlight(const String&); |
| |
| void searchTheWeb(const String&); |
| |
| // Dictionary. |
| void didPerformDictionaryLookup(const AttributedString&, const DictionaryPopupInfo&); |
| #endif |
| |
| // Spelling and grammar. |
| #if USE(UNIFIED_TEXT_CHECKING) |
| void checkTextOfParagraph(const String& text, uint64_t checkingTypes, Vector<WebCore::TextCheckingResult>& results); |
| #endif |
| void checkSpellingOfString(const String& text, int32_t& misspellingLocation, int32_t& misspellingLength); |
| void checkGrammarOfString(const String& text, Vector<WebCore::GrammarDetail>&, int32_t& badGrammarLocation, int32_t& badGrammarLength); |
| void spellingUIIsShowing(bool&); |
| void updateSpellingUIWithMisspelledWord(const String& misspelledWord); |
| void updateSpellingUIWithGrammarString(const String& badGrammarPhrase, const WebCore::GrammarDetail&); |
| void getGuessesForWord(const String& word, const String& context, Vector<String>& guesses); |
| void learnWord(const String& word); |
| void ignoreWord(const String& word); |
| void requestCheckingOfString(uint64_t requestID, const WebCore::TextCheckingRequestData&); |
| |
| void setFocus(bool focused); |
| void takeFocus(uint32_t direction); |
| void setToolTip(const String&); |
| void setCursor(const WebCore::Cursor&); |
| void setCursorHiddenUntilMouseMoves(bool); |
| |
| void didReceiveEvent(uint32_t opaqueType, bool handled); |
| void stopResponsivenessTimer(); |
| |
| void voidCallback(uint64_t); |
| void dataCallback(const IPC::DataReference&, uint64_t); |
| void imageCallback(const ShareableBitmap::Handle&, uint64_t); |
| void stringCallback(const String&, uint64_t); |
| void scriptValueCallback(const IPC::DataReference&, uint64_t); |
| void computedPagesCallback(const Vector<WebCore::IntRect>&, double totalScaleFactorForPrinting, uint64_t); |
| void validateCommandCallback(const String&, bool, int, uint64_t); |
| #if PLATFORM(IOS) |
| void gestureCallback(const WebCore::IntPoint&, uint32_t, uint32_t, uint32_t, uint64_t); |
| void touchesCallback(const WebCore::IntPoint&, uint32_t, uint64_t); |
| void autocorrectionDataCallback(const Vector<WebCore::FloatRect>&, const String&, float, uint64_t, uint64_t); |
| void autocorrectionContextCallback(const String&, const String&, const String&, const String&, uint64_t, uint64_t, uint64_t); |
| void interpretKeyEvent(const EditorState&, bool isCharEvent, bool& handled); |
| #endif |
| #if PLATFORM(GTK) |
| void printFinishedCallback(const WebCore::ResourceError&, uint64_t); |
| #endif |
| |
| void focusedFrameChanged(uint64_t frameID); |
| void frameSetLargestFrameChanged(uint64_t frameID); |
| |
| void canAuthenticateAgainstProtectionSpaceInFrame(uint64_t frameID, const WebCore::ProtectionSpace&, bool& canAuthenticate); |
| void didReceiveAuthenticationChallenge(uint64_t frameID, const WebCore::AuthenticationChallenge&, uint64_t challengeID); |
| |
| #if PLATFORM(MAC) |
| void pluginFocusOrWindowFocusChanged(uint64_t pluginComplexTextInputIdentifier, bool pluginHasFocusAndWindowHasFocus); |
| void setPluginComplexTextInputState(uint64_t pluginComplexTextInputIdentifier, uint64_t complexTextInputState); |
| #endif |
| |
| bool maybeInitializeSandboxExtensionHandle(const WebCore::URL&, SandboxExtension::Handle&); |
| |
| #if PLATFORM(MAC) && !PLATFORM(IOS) |
| void substitutionsPanelIsShowing(bool&); |
| void showCorrectionPanel(int32_t panelType, const WebCore::FloatRect& boundingBoxOfReplacedString, const String& replacedString, const String& replacementString, const Vector<String>& alternativeReplacementStrings); |
| void dismissCorrectionPanel(int32_t reason); |
| void dismissCorrectionPanelSoon(int32_t reason, String& result); |
| void recordAutocorrectionResponse(int32_t responseType, const String& replacedString, const String& replacementString); |
| |
| #if USE(DICTATION_ALTERNATIVES) |
| void showDictationAlternativeUI(const WebCore::FloatRect& boundingBoxOfDictatedText, uint64_t dictationContext); |
| void removeDictationAlternatives(uint64_t dictationContext); |
| void dictationAlternatives(uint64_t dictationContext, Vector<String>& result); |
| #endif |
| #endif // PLATFORM(MAC) && !PLATFORM(IOS) |
| |
| #if PLATFORM(IOS) |
| void mainDocumentDidReceiveMobileDocType(); |
| |
| void didGetTapHighlightGeometries(uint64_t requestID, const WebCore::Color& color, const Vector<WebCore::FloatQuad>& geometries, const WebCore::IntSize& topLeftRadius, const WebCore::IntSize& topRightRadius, const WebCore::IntSize& bottomLeftRadius, const WebCore::IntSize& bottomRightRadius); |
| |
| void didChangeViewportArguments(const WebCore::ViewportArguments& viewportArguments); |
| |
| void startAssistingNode(const WebCore::IntRect&, bool hasNextFocusable, bool hasPreviousFocusable); |
| void stopAssistingNode(); |
| void notifyRevealedSelection(); |
| #endif // PLATFORM(IOS) |
| |
| #if USE(SOUP) && !ENABLE(CUSTOM_PROTOCOLS) |
| void didReceiveURIRequest(String uriString, uint64_t requestID); |
| #endif |
| |
| void clearLoadDependentCallbacks(); |
| |
| void performDragControllerAction(DragControllerAction, WebCore::DragData&, const String& dragStorageName, const SandboxExtension::Handle&, const SandboxExtension::HandleArray&); |
| |
| void updateBackingStoreDiscardableState(); |
| |
| void setRenderTreeSize(uint64_t treeSize) { m_renderTreeSize = treeSize; } |
| |
| #if PLUGIN_ARCHITECTURE(X11) |
| void createPluginContainer(uint64_t& windowID); |
| void windowedPluginGeometryDidChange(const WebCore::IntRect& frameRect, const WebCore::IntRect& clipRect, uint64_t windowID); |
| #endif |
| |
| void processNextQueuedWheelEvent(); |
| void sendWheelEvent(const WebWheelEvent&); |
| |
| #if ENABLE(NETSCAPE_PLUGIN_API) |
| void findPlugin(const String& mimeType, uint32_t processType, const String& urlString, const String& frameURLString, const String& pageURLString, bool allowOnlyApplicationPlugins, uint64_t& pluginProcessToken, String& newMIMEType, uint32_t& pluginLoadPolicy, String& unavailabilityDescription, String& useBlockedPluginTitle); |
| #endif |
| |
| PageClient& m_pageClient; |
| WebLoaderClient m_loaderClient; |
| std::unique_ptr<API::PolicyClient> m_policyClient; |
| WebFormClient m_formClient; |
| WebUIClient m_uiClient; |
| #if PLATFORM(EFL) |
| WebUIPopupMenuClient m_uiPopupMenuClient; |
| #endif |
| WebFindClient m_findClient; |
| WebFindMatchesClient m_findMatchesClient; |
| #if ENABLE(CONTEXT_MENUS) |
| WebPageContextMenuClient m_contextMenuClient; |
| #endif |
| |
| std::unique_ptr<DrawingAreaProxy> m_drawingArea; |
| #if ENABLE(ASYNC_SCROLLING) |
| std::unique_ptr<RemoteScrollingCoordinatorProxy> m_scrollingCoordinatorProxy; |
| #endif |
| |
| Ref<WebProcessProxy> m_process; |
| Ref<WebPageGroup> m_pageGroup; |
| RefPtr<WebFrameProxy> m_mainFrame; |
| RefPtr<WebFrameProxy> m_focusedFrame; |
| RefPtr<WebFrameProxy> m_frameSetLargestFrame; |
| |
| String m_userAgent; |
| String m_applicationNameForUserAgent; |
| String m_customUserAgent; |
| String m_customTextEncodingName; |
| |
| #if ENABLE(INSPECTOR) |
| RefPtr<WebInspectorProxy> m_inspector; |
| #endif |
| |
| #if ENABLE(FULLSCREEN_API) |
| RefPtr<WebFullScreenManagerProxy> m_fullScreenManager; |
| #endif |
| |
| #if ENABLE(VIBRATION) |
| RefPtr<WebVibrationProxy> m_vibration; |
| #endif |
| |
| HashMap<uint64_t, RefPtr<VoidCallback>> m_voidCallbacks; |
| HashMap<uint64_t, RefPtr<DataCallback>> m_dataCallbacks; |
| HashMap<uint64_t, RefPtr<ImageCallback>> m_imageCallbacks; |
| HashMap<uint64_t, RefPtr<StringCallback>> m_stringCallbacks; |
| HashSet<uint64_t> m_loadDependentStringCallbackIDs; |
| HashMap<uint64_t, RefPtr<ScriptValueCallback>> m_scriptValueCallbacks; |
| HashMap<uint64_t, RefPtr<ComputedPagesCallback>> m_computedPagesCallbacks; |
| HashMap<uint64_t, RefPtr<ValidateCommandCallback>> m_validateCommandCallbacks; |
| #if PLATFORM(IOS) |
| HashMap<uint64_t, RefPtr<GestureCallback>> m_gestureCallbacks; |
| HashMap<uint64_t, RefPtr<TouchesCallback>> m_touchesCallbacks; |
| HashMap<uint64_t, RefPtr<AutocorrectionDataCallback>> m_autocorrectionCallbacks; |
| HashMap<uint64_t, RefPtr<AutocorrectionContextCallback>> m_autocorrectionContextCallbacks; |
| #endif |
| #if PLATFORM(GTK) |
| HashMap<uint64_t, RefPtr<PrintFinishedCallback>> m_printFinishedCallbacks; |
| #endif |
| |
| HashSet<WebEditCommandProxy*> m_editCommandSet; |
| |
| #if PLATFORM(MAC) |
| HashSet<String> m_knownKeypressCommandNames; |
| #endif |
| |
| RefPtr<WebPopupMenuProxy> m_activePopupMenu; |
| RefPtr<WebContextMenuProxy> m_activeContextMenu; |
| WebHitTestResult::Data m_activeContextMenuHitTestResultData; |
| RefPtr<WebOpenPanelResultListenerProxy> m_openPanelResultListener; |
| GeolocationPermissionRequestManagerProxy m_geolocationPermissionRequestManager; |
| NotificationPermissionRequestManagerProxy m_notificationPermissionRequestManager; |
| |
| WebCore::ViewState::Flags m_viewState; |
| |
| bool m_canGoBack; |
| bool m_canGoForward; |
| Ref<WebBackForwardList> m_backForwardList; |
| |
| bool m_maintainsInactiveSelection; |
| |
| String m_toolTip; |
| |
| String m_urlAtProcessExit; |
| FrameLoadState::State m_loadStateAtProcessExit; |
| |
| EditorState m_editorState; |
| bool m_temporarilyClosedComposition; // Editor state changed from hasComposition to !hasComposition, but that was only with shouldIgnoreCompositionSelectionChange yet. |
| |
| double m_textZoomFactor; |
| double m_pageZoomFactor; |
| double m_pageScaleFactor; |
| float m_intrinsicDeviceScaleFactor; |
| float m_customDeviceScaleFactor; |
| |
| LayerHostingMode m_layerHostingMode; |
| |
| bool m_drawsBackground; |
| bool m_drawsTransparentBackground; |
| |
| WebCore::Color m_underlayColor; |
| |
| bool m_areMemoryCacheClientCallsEnabled; |
| |
| bool m_useFixedLayout; |
| WebCore::IntSize m_fixedLayoutSize; |
| |
| bool m_suppressScrollbarAnimations; |
| |
| WebCore::Pagination::Mode m_paginationMode; |
| bool m_paginationBehavesLikeColumns; |
| double m_pageLength; |
| double m_gapBetweenPages; |
| |
| // If the process backing the web page is alive and kicking. |
| bool m_isValid; |
| |
| // Whether WebPageProxy::close() has been called on this page. |
| bool m_isClosed; |
| |
| // Whether it can run modal child web pages. |
| bool m_canRunModal; |
| |
| bool m_isInPrintingMode; |
| bool m_isPerformingDOMPrintOperation; |
| |
| bool m_inDecidePolicyForResponseSync; |
| const WebCore::ResourceRequest* m_decidePolicyForResponseRequest; |
| bool m_syncMimeTypePolicyActionIsValid; |
| WebCore::PolicyAction m_syncMimeTypePolicyAction; |
| uint64_t m_syncMimeTypePolicyDownloadID; |
| |
| bool m_inDecidePolicyForNavigationAction; |
| bool m_syncNavigationActionPolicyActionIsValid; |
| WebCore::PolicyAction m_syncNavigationActionPolicyAction; |
| uint64_t m_syncNavigationActionPolicyDownloadID; |
| |
| Deque<NativeWebKeyboardEvent> m_keyEventQueue; |
| Deque<NativeWebWheelEvent> m_wheelEventQueue; |
| Deque<OwnPtr<Vector<NativeWebWheelEvent>>> m_currentlyProcessedWheelEvents; |
| |
| bool m_processingMouseMoveEvent; |
| OwnPtr<NativeWebMouseEvent> m_nextMouseMoveEvent; |
| OwnPtr<NativeWebMouseEvent> m_currentlyProcessedMouseDownEvent; |
| |
| #if ENABLE(TOUCH_EVENTS) |
| bool m_needTouchEvents; |
| Deque<QueuedTouchEvents> m_touchEventQueue; |
| #endif |
| #if ENABLE(INPUT_TYPE_COLOR) |
| RefPtr<WebColorPicker> m_colorPicker; |
| RefPtr<WebColorPickerResultListenerProxy> m_colorPickerResultListener; |
| #endif |
| |
| uint64_t m_pageID; |
| Ref<API::Session> m_session; |
| |
| bool m_isPageSuspended; |
| |
| #if PLATFORM(MAC) |
| bool m_isSmartInsertDeleteEnabled; |
| #endif |
| |
| #if PLATFORM(GTK) |
| String m_accessibilityPlugID; |
| #endif |
| |
| int64_t m_spellDocumentTag; |
| bool m_hasSpellDocumentTag; |
| unsigned m_pendingLearnOrIgnoreWordMessageCount; |
| |
| #if ENABLE(DRAG_SUPPORT) |
| WebCore::DragSession m_currentDragSession; |
| #endif |
| |
| PageLoadState m_pageLoadState; |
| |
| bool m_mainFrameHasHorizontalScrollbar; |
| bool m_mainFrameHasVerticalScrollbar; |
| |
| // Whether horizontal wheel events can be handled directly for swiping purposes. |
| bool m_canShortCircuitHorizontalWheelEvents; |
| |
| bool m_mainFrameIsPinnedToLeftSide; |
| bool m_mainFrameIsPinnedToRightSide; |
| bool m_mainFrameIsPinnedToTopSide; |
| bool m_mainFrameIsPinnedToBottomSide; |
| |
| bool m_useLegacyImplicitRubberBandControl; |
| bool m_rubberBandsAtLeft; |
| bool m_rubberBandsAtRight; |
| bool m_rubberBandsAtTop; |
| bool m_rubberBandsAtBottom; |
| |
| bool m_backgroundExtendsBeyondPage; |
| |
| bool m_mainFrameInViewSourceMode; |
| |
| unsigned m_pageCount; |
| |
| WebCore::IntRect m_visibleScrollerThumbRect; |
| |
| uint64_t m_renderTreeSize; |
| |
| bool m_shouldSendEventsSynchronously; |
| |
| bool m_suppressVisibilityUpdates; |
| bool m_autoSizingShouldExpandToViewHeight; |
| WebCore::IntSize m_minimumLayoutSize; |
| |
| float m_mediaVolume; |
| bool m_mayStartMediaWhenInWindow; |
| |
| bool m_waitingForDidUpdateViewState; |
| |
| #if PLATFORM(MAC) |
| HashMap<String, String> m_temporaryPDFFiles; |
| #endif |
| |
| WebCore::ScrollPinningBehavior m_scrollPinningBehavior; |
| }; |
| |
| } // namespace WebKit |
| |
| #endif // WebPageProxy_h |