diff options
Diffstat (limited to 'Source/WebKit2/UIProcess/WebUIClient.cpp')
-rw-r--r-- | Source/WebKit2/UIProcess/WebUIClient.cpp | 457 |
1 files changed, 0 insertions, 457 deletions
diff --git a/Source/WebKit2/UIProcess/WebUIClient.cpp b/Source/WebKit2/UIProcess/WebUIClient.cpp deleted file mode 100644 index bfa4d8e43..000000000 --- a/Source/WebKit2/UIProcess/WebUIClient.cpp +++ /dev/null @@ -1,457 +0,0 @@ -/* - * 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. - */ - -#include "config.h" -#include "WebUIClient.h" - -#include "ImmutableDictionary.h" -#include "NativeWebKeyboardEvent.h" -#include "NativeWebWheelEvent.h" -#include "NotificationPermissionRequest.h" -#include "PluginInformation.h" -#include "WKAPICast.h" -#include "WebColorPickerResultListenerProxy.h" -#include "WebNumber.h" -#include "WebOpenPanelResultListenerProxy.h" -#include "WebPageProxy.h" -#include <WebCore/FloatRect.h> -#include <WebCore/IntSize.h> -#include <WebCore/WindowFeatures.h> -#include <string.h> -#include <wtf/text/WTFString.h> - -using namespace WebCore; - -namespace WebKit { - -PassRefPtr<WebPageProxy> WebUIClient::createNewPage(WebPageProxy* page, const ResourceRequest& resourceRequest, const WindowFeatures& windowFeatures, WebEvent::Modifiers modifiers, WebMouseEvent::Button button) -{ - if (!m_client.version && !m_client.createNewPage_deprecatedForUseWithV0) - return 0; - - if (m_client.version == kWKPageUIClientCurrentVersion && !m_client.createNewPage) - return 0; - - ImmutableDictionary::MapType map; - if (windowFeatures.xSet) - map.set("x", WebDouble::create(windowFeatures.x)); - if (windowFeatures.ySet) - map.set("y", WebDouble::create(windowFeatures.y)); - if (windowFeatures.widthSet) - map.set("width", WebDouble::create(windowFeatures.width)); - if (windowFeatures.heightSet) - map.set("height", WebDouble::create(windowFeatures.height)); - map.set("menuBarVisible", WebBoolean::create(windowFeatures.menuBarVisible)); - map.set("statusBarVisible", WebBoolean::create(windowFeatures.statusBarVisible)); - map.set("toolBarVisible", WebBoolean::create(windowFeatures.toolBarVisible)); - map.set("locationBarVisible", WebBoolean::create(windowFeatures.locationBarVisible)); - map.set("scrollbarsVisible", WebBoolean::create(windowFeatures.scrollbarsVisible)); - map.set("resizable", WebBoolean::create(windowFeatures.resizable)); - map.set("fullscreen", WebBoolean::create(windowFeatures.fullscreen)); - map.set("dialog", WebBoolean::create(windowFeatures.dialog)); - RefPtr<ImmutableDictionary> featuresMap = ImmutableDictionary::adopt(map); - - if (!m_client.version) - return adoptRef(toImpl(m_client.createNewPage_deprecatedForUseWithV0(toAPI(page), toAPI(featuresMap.get()), toAPI(modifiers), toAPI(button), m_client.clientInfo))); - - RefPtr<WebURLRequest> request = WebURLRequest::create(resourceRequest); - return adoptRef(toImpl(m_client.createNewPage(toAPI(page), toAPI(request.get()), toAPI(featuresMap.get()), toAPI(modifiers), toAPI(button), m_client.clientInfo))); -} - -void WebUIClient::showPage(WebPageProxy* page) -{ - if (!m_client.showPage) - return; - - m_client.showPage(toAPI(page), m_client.clientInfo); -} - -void WebUIClient::close(WebPageProxy* page) -{ - if (!m_client.close) - return; - - m_client.close(toAPI(page), m_client.clientInfo); -} - -void WebUIClient::takeFocus(WebPageProxy* page, WKFocusDirection direction) -{ - if (!m_client.takeFocus) - return; - - m_client.takeFocus(toAPI(page), direction, m_client.clientInfo); -} - -void WebUIClient::focus(WebPageProxy* page) -{ - if (!m_client.focus) - return; - - m_client.focus(toAPI(page), m_client.clientInfo); -} - -void WebUIClient::unfocus(WebPageProxy* page) -{ - if (!m_client.unfocus) - return; - - m_client.unfocus(toAPI(page), m_client.clientInfo); -} - -void WebUIClient::runJavaScriptAlert(WebPageProxy* page, const String& message, WebFrameProxy* frame) -{ - if (!m_client.runJavaScriptAlert) - return; - - m_client.runJavaScriptAlert(toAPI(page), toAPI(message.impl()), toAPI(frame), m_client.clientInfo); -} - -bool WebUIClient::runJavaScriptConfirm(WebPageProxy* page, const String& message, WebFrameProxy* frame) -{ - if (!m_client.runJavaScriptConfirm) - return false; - - return m_client.runJavaScriptConfirm(toAPI(page), toAPI(message.impl()), toAPI(frame), m_client.clientInfo); -} - -String WebUIClient::runJavaScriptPrompt(WebPageProxy* page, const String& message, const String& defaultValue, WebFrameProxy* frame) -{ - if (!m_client.runJavaScriptPrompt) - return String(); - - WebString* string = toImpl(m_client.runJavaScriptPrompt(toAPI(page), toAPI(message.impl()), toAPI(defaultValue.impl()), toAPI(frame), m_client.clientInfo)); - if (!string) - return String(); - - String result = string->string(); - string->deref(); - - return result; -} - -void WebUIClient::setStatusText(WebPageProxy* page, const String& text) -{ - if (!m_client.setStatusText) - return; - - m_client.setStatusText(toAPI(page), toAPI(text.impl()), m_client.clientInfo); -} - -void WebUIClient::mouseDidMoveOverElement(WebPageProxy* page, const WebHitTestResult::Data& data, WebEvent::Modifiers modifiers, APIObject* userData) -{ - if (!m_client.mouseDidMoveOverElement && !m_client.mouseDidMoveOverElement_deprecatedForUseWithV0) - return; - - if (m_client.version == kWKPageUIClientCurrentVersion && !m_client.mouseDidMoveOverElement) - return; - - if (!m_client.version) { - m_client.mouseDidMoveOverElement_deprecatedForUseWithV0(toAPI(page), toAPI(modifiers), toAPI(userData), m_client.clientInfo); - return; - } - - RefPtr<WebHitTestResult> webHitTestResult = WebHitTestResult::create(data); - m_client.mouseDidMoveOverElement(toAPI(page), toAPI(webHitTestResult.get()), toAPI(modifiers), toAPI(userData), m_client.clientInfo); -} - -void WebUIClient::unavailablePluginButtonClicked(WebPageProxy* page, WKPluginUnavailabilityReason pluginUnavailabilityReason, ImmutableDictionary* pluginInformation) -{ - if (pluginUnavailabilityReason == kWKPluginUnavailabilityReasonPluginMissing) { - if (m_client.missingPluginButtonClicked_deprecatedForUseWithV0) - m_client.missingPluginButtonClicked_deprecatedForUseWithV0( - toAPI(page), - toAPI(pluginInformation->get<WebString>(pluginInformationMIMETypeKey())), - toAPI(pluginInformation->get<WebString>(pluginInformationPluginURLKey())), - toAPI(pluginInformation->get<WebString>(pluginInformationPluginspageAttributeURLKey())), - m_client.clientInfo); - } - - if (m_client.unavailablePluginButtonClicked_deprecatedForUseWithV1) - m_client.unavailablePluginButtonClicked_deprecatedForUseWithV1( - toAPI(page), - pluginUnavailabilityReason, - toAPI(pluginInformation->get<WebString>(pluginInformationMIMETypeKey())), - toAPI(pluginInformation->get<WebString>(pluginInformationPluginURLKey())), - toAPI(pluginInformation->get<WebString>(pluginInformationPluginspageAttributeURLKey())), - m_client.clientInfo); - - if (m_client.unavailablePluginButtonClicked) - m_client.unavailablePluginButtonClicked( - toAPI(page), - pluginUnavailabilityReason, - toAPI(pluginInformation), - m_client.clientInfo); -} - -bool WebUIClient::implementsDidNotHandleKeyEvent() const -{ - return m_client.didNotHandleKeyEvent; -} - -void WebUIClient::didNotHandleKeyEvent(WebPageProxy* page, const NativeWebKeyboardEvent& event) -{ - if (!m_client.didNotHandleKeyEvent) - return; - m_client.didNotHandleKeyEvent(toAPI(page), event.nativeEvent(), m_client.clientInfo); -} - -bool WebUIClient::implementsDidNotHandleWheelEvent() const -{ - return m_client.didNotHandleWheelEvent; -} - -void WebUIClient::didNotHandleWheelEvent(WebPageProxy* page, const NativeWebWheelEvent& event) -{ - if (!m_client.didNotHandleWheelEvent) - return; - m_client.didNotHandleWheelEvent(toAPI(page), event.nativeEvent(), m_client.clientInfo); -} - -bool WebUIClient::toolbarsAreVisible(WebPageProxy* page) -{ - if (!m_client.toolbarsAreVisible) - return true; - return m_client.toolbarsAreVisible(toAPI(page), m_client.clientInfo); - -} -void WebUIClient::setToolbarsAreVisible(WebPageProxy* page, bool visible) -{ - if (!m_client.setToolbarsAreVisible) - return; - m_client.setToolbarsAreVisible(toAPI(page), visible, m_client.clientInfo); -} - -bool WebUIClient::menuBarIsVisible(WebPageProxy* page) -{ - if (!m_client.menuBarIsVisible) - return true; - return m_client.menuBarIsVisible(toAPI(page), m_client.clientInfo); -} - -void WebUIClient::setMenuBarIsVisible(WebPageProxy* page, bool visible) -{ - if (!m_client.setMenuBarIsVisible) - return; - m_client.setMenuBarIsVisible(toAPI(page), visible, m_client.clientInfo); -} - -bool WebUIClient::statusBarIsVisible(WebPageProxy* page) -{ - if (!m_client.statusBarIsVisible) - return true; - return m_client.statusBarIsVisible(toAPI(page), m_client.clientInfo); -} - -void WebUIClient::setStatusBarIsVisible(WebPageProxy* page, bool visible) -{ - if (!m_client.setStatusBarIsVisible) - return; - m_client.setStatusBarIsVisible(toAPI(page), visible, m_client.clientInfo); -} - -bool WebUIClient::isResizable(WebPageProxy* page) -{ - if (!m_client.isResizable) - return true; - return m_client.isResizable(toAPI(page), m_client.clientInfo); -} - -void WebUIClient::setIsResizable(WebPageProxy* page, bool resizable) -{ - if (!m_client.setIsResizable) - return; - m_client.setIsResizable(toAPI(page), resizable, m_client.clientInfo); -} - -void WebUIClient::setWindowFrame(WebPageProxy* page, const FloatRect& frame) -{ - if (!m_client.setWindowFrame) - return; - - m_client.setWindowFrame(toAPI(page), toAPI(frame), m_client.clientInfo); -} - -FloatRect WebUIClient::windowFrame(WebPageProxy* page) -{ - if (!m_client.getWindowFrame) - return FloatRect(); - - return toFloatRect(m_client.getWindowFrame(toAPI(page), m_client.clientInfo)); -} - -bool WebUIClient::canRunBeforeUnloadConfirmPanel() const -{ - return m_client.runBeforeUnloadConfirmPanel; -} - -bool WebUIClient::runBeforeUnloadConfirmPanel(WebPageProxy* page, const String& message, WebFrameProxy* frame) -{ - if (!m_client.runBeforeUnloadConfirmPanel) - return true; - - return m_client.runBeforeUnloadConfirmPanel(toAPI(page), toAPI(message.impl()), toAPI(frame), m_client.clientInfo); -} - -void WebUIClient::didDraw(WebPageProxy* page) -{ - if (!m_client.didDraw) - return; - - m_client.didDraw(toAPI(page), m_client.clientInfo); -} - -void WebUIClient::pageDidScroll(WebPageProxy* page) -{ - if (!m_client.pageDidScroll) - return; - - m_client.pageDidScroll(toAPI(page), m_client.clientInfo); -} - -unsigned long long WebUIClient::exceededDatabaseQuota(WebPageProxy* page, WebFrameProxy* frame, WebSecurityOrigin* origin, const String& databaseName, const String& databaseDisplayName, unsigned long long currentQuota, unsigned long long currentOriginUsage, unsigned long long currentDatabaseUsage, unsigned long long expectedUsage) -{ - if (!m_client.exceededDatabaseQuota) - return currentQuota; - - return m_client.exceededDatabaseQuota(toAPI(page), toAPI(frame), toAPI(origin), toAPI(databaseName.impl()), toAPI(databaseDisplayName.impl()), currentQuota, currentOriginUsage, currentDatabaseUsage, expectedUsage, m_client.clientInfo); -} - -bool WebUIClient::runOpenPanel(WebPageProxy* page, WebFrameProxy* frame, WebOpenPanelParameters* parameters, WebOpenPanelResultListenerProxy* listener) -{ - if (!m_client.runOpenPanel) - return false; - - m_client.runOpenPanel(toAPI(page), toAPI(frame), toAPI(parameters), toAPI(listener), m_client.clientInfo); - return true; -} - -bool WebUIClient::decidePolicyForGeolocationPermissionRequest(WebPageProxy* page, WebFrameProxy* frame, WebSecurityOrigin* origin, GeolocationPermissionRequestProxy* permissionRequest) -{ - if (!m_client.decidePolicyForGeolocationPermissionRequest) - return false; - - m_client.decidePolicyForGeolocationPermissionRequest(toAPI(page), toAPI(frame), toAPI(origin), toAPI(permissionRequest), m_client.clientInfo); - return true; -} - -bool WebUIClient::decidePolicyForNotificationPermissionRequest(WebPageProxy* page, WebSecurityOrigin* origin, NotificationPermissionRequest* permissionRequest) -{ - if (!m_client.decidePolicyForNotificationPermissionRequest) - return false; - - m_client.decidePolicyForNotificationPermissionRequest(toAPI(page), toAPI(origin), toAPI(permissionRequest), m_client.clientInfo); - return true; -} - -float WebUIClient::headerHeight(WebPageProxy* page, WebFrameProxy* frame) -{ - if (!m_client.headerHeight) - return 0; - - return m_client.headerHeight(toAPI(page), toAPI(frame), m_client.clientInfo); -} - -float WebUIClient::footerHeight(WebPageProxy* page, WebFrameProxy* frame) -{ - if (!m_client.footerHeight) - return 0; - - return m_client.footerHeight(toAPI(page), toAPI(frame), m_client.clientInfo); -} - -void WebUIClient::drawHeader(WebPageProxy* page, WebFrameProxy* frame, const WebCore::FloatRect& rect) -{ - if (!m_client.drawHeader) - return; - - m_client.drawHeader(toAPI(page), toAPI(frame), toAPI(rect), m_client.clientInfo); -} - -void WebUIClient::drawFooter(WebPageProxy* page, WebFrameProxy* frame, const WebCore::FloatRect& rect) -{ - if (!m_client.drawFooter) - return; - - m_client.drawFooter(toAPI(page), toAPI(frame), toAPI(rect), m_client.clientInfo); -} - -void WebUIClient::printFrame(WebPageProxy* page, WebFrameProxy* frame) -{ - if (!m_client.printFrame) - return; - - m_client.printFrame(toAPI(page), toAPI(frame), m_client.clientInfo); -} - -bool WebUIClient::canRunModal() const -{ - return m_client.runModal; -} - -void WebUIClient::runModal(WebPageProxy* page) -{ - if (!m_client.runModal) - return; - - m_client.runModal(toAPI(page), m_client.clientInfo); -} - -void WebUIClient::saveDataToFileInDownloadsFolder(WebPageProxy* page, const String& suggestedFilename, const String& mimeType, const String& originatingURLString, WebData* data) -{ - if (!m_client.saveDataToFileInDownloadsFolder) - return; - - m_client.saveDataToFileInDownloadsFolder(toAPI(page), toAPI(suggestedFilename.impl()), toAPI(mimeType.impl()), toURLRef(originatingURLString.impl()), toAPI(data), m_client.clientInfo); -} - -bool WebUIClient::shouldInterruptJavaScript(WebPageProxy* page) -{ - if (!m_client.shouldInterruptJavaScript) - return false; - - return m_client.shouldInterruptJavaScript(toAPI(page), m_client.clientInfo); -} - -#if ENABLE(INPUT_TYPE_COLOR) -bool WebUIClient::showColorPicker(WebPageProxy* page, const String& initialColor, WebColorPickerResultListenerProxy* listener) -{ - if (!m_client.showColorPicker) - return false; - - m_client.showColorPicker(toAPI(page), toAPI(initialColor.impl()), toAPI(listener), m_client.clientInfo); - return true; -} - -bool WebUIClient::hideColorPicker(WebPageProxy* page) -{ - if (!m_client.hideColorPicker) - return false; - - m_client.hideColorPicker(toAPI(page), m_client.clientInfo); - return true; -} -#endif - -} // namespace WebKit |