Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(481)

Unified Diff: webkit/api/src/ChromeClientImpl.cpp

Issue 385057: Deleted webkit/api which now lives in webkit.org (Closed)
Patch Set: Created 11 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « webkit/api/src/ChromeClientImpl.h ('k') | webkit/api/src/ChromiumBridge.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webkit/api/src/ChromeClientImpl.cpp
diff --git a/webkit/api/src/ChromeClientImpl.cpp b/webkit/api/src/ChromeClientImpl.cpp
deleted file mode 100644
index f8163150ff796f82a8990cb51cc6580b8b8008cd..0000000000000000000000000000000000000000
--- a/webkit/api/src/ChromeClientImpl.cpp
+++ /dev/null
@@ -1,674 +0,0 @@
-/*
- * Copyright (C) 2009 Google 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:
- *
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * 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.
- * * Neither the name of Google Inc. nor the names of its
- * contributors may be used to endorse or promote products derived from
- * this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND 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 THE COPYRIGHT
- * OWNER OR 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 "ChromeClientImpl.h"
-
-#include "AccessibilityObject.h"
-#include "AXObjectCache.h"
-#include "CharacterNames.h"
-#include "Console.h"
-#include "Cursor.h"
-#include "DatabaseTracker.h"
-#include "Document.h"
-#include "DocumentLoader.h"
-#include "FileChooser.h"
-#include "FloatRect.h"
-#include "FrameLoadRequest.h"
-#include "FrameView.h"
-#include "HitTestResult.h"
-#include "IntRect.h"
-#include "Node.h"
-#include "NotificationPresenterImpl.h"
-#include "Page.h"
-#include "PopupMenuChromium.h"
-#include "ScriptController.h"
-#if USE(V8)
-#include "V8Proxy.h"
-#endif
-#include "WebAccessibilityObject.h"
-#include "WebConsoleMessage.h"
-#include "WebCursorInfo.h"
-#include "WebFileChooserCompletionImpl.h"
-#include "WebFrameClient.h"
-#include "WebFrameImpl.h"
-#include "WebInputEvent.h"
-#include "WebKit.h"
-#include "WebPopupMenuImpl.h"
-#include "WebPopupMenuInfo.h"
-#include "WebRect.h"
-#include "WebTextDirection.h"
-#include "WebURLRequest.h"
-#include "WebViewClient.h"
-#include "WebViewImpl.h"
-#include "WindowFeatures.h"
-#include "WrappedResourceRequest.h"
-
-using namespace WebCore;
-
-namespace WebKit {
-
-ChromeClientImpl::ChromeClientImpl(WebViewImpl* webView)
- : m_webView(webView)
- , m_toolbarsVisible(true)
- , m_statusbarVisible(true)
- , m_scrollbarsVisible(true)
- , m_menubarVisible(true)
- , m_resizable(true)
- , m_ignoreNextSetCursor(false)
-{
-}
-
-ChromeClientImpl::~ChromeClientImpl()
-{
-}
-
-void ChromeClientImpl::chromeDestroyed()
-{
- // Our lifetime is bound to the WebViewImpl.
-}
-
-void ChromeClientImpl::setWindowRect(const FloatRect& r)
-{
- if (m_webView->client())
- m_webView->client()->setWindowRect(IntRect(r));
-}
-
-FloatRect ChromeClientImpl::windowRect()
-{
- WebRect rect;
- if (m_webView->client())
- rect = m_webView->client()->rootWindowRect();
- else {
- // These numbers will be fairly wrong. The window's x/y coordinates will
- // be the top left corner of the screen and the size will be the content
- // size instead of the window size.
- rect.width = m_webView->size().width;
- rect.height = m_webView->size().height;
- }
- return FloatRect(rect);
-}
-
-FloatRect ChromeClientImpl::pageRect()
-{
- // We hide the details of the window's border thickness from the web page by
- // simple re-using the window position here. So, from the point-of-view of
- // the web page, the window has no border.
- return windowRect();
-}
-
-float ChromeClientImpl::scaleFactor()
-{
- // This is supposed to return the scale factor of the web page. It looks like
- // the implementor of the graphics layer is responsible for doing most of the
- // operations associated with scaling. However, this value is used ins some
- // cases by WebCore. For example, this is used as a scaling factor in canvas
- // so that things drawn in it are scaled just like the web page is.
- //
- // We don't currently implement scaling, so just return 1.0 (no scaling).
- return 1.0;
-}
-
-void ChromeClientImpl::focus()
-{
- if (!m_webView->client())
- return;
-
- m_webView->client()->didFocus();
-
- // If accessibility is enabled, we should notify assistive technology that
- // the active AccessibilityObject changed.
- const Frame* frame = m_webView->focusedWebCoreFrame();
- if (!frame)
- return;
-
- Document* doc = frame->document();
-
- if (doc && doc->axObjectCache()->accessibilityEnabled()) {
- Node* focusedNode = m_webView->focusedWebCoreNode();
-
- if (!focusedNode) {
- // Could not retrieve focused Node.
- return;
- }
-
- // Retrieve the focused AccessibilityObject.
- AccessibilityObject* focusedAccObj =
- doc->axObjectCache()->getOrCreate(focusedNode->renderer());
-
- // Alert assistive technology that focus changed.
- if (focusedAccObj)
- m_webView->client()->focusAccessibilityObject(WebAccessibilityObject(focusedAccObj));
- }
-}
-
-void ChromeClientImpl::unfocus()
-{
- if (m_webView->client())
- m_webView->client()->didBlur();
-}
-
-bool ChromeClientImpl::canTakeFocus(FocusDirection)
-{
- // For now the browser can always take focus if we're not running layout
- // tests.
- return !layoutTestMode();
-}
-
-void ChromeClientImpl::takeFocus(FocusDirection direction)
-{
- if (!m_webView->client())
- return;
- if (direction == FocusDirectionBackward)
- m_webView->client()->focusPrevious();
- else
- m_webView->client()->focusNext();
-}
-
-void ChromeClientImpl::focusedNodeChanged(Node* node)
-{
- WebURL focus_url;
- if (node && node->isLink()) {
- // This HitTestResult hack is the easiest way to get a link URL out of a
- // WebCore::Node.
- HitTestResult hit_test(IntPoint(0, 0));
- // This cast must be valid because of the isLink() check.
- hit_test.setURLElement(reinterpret_cast<Element*>(node));
- if (hit_test.isLiveLink())
- focus_url = hit_test.absoluteLinkURL();
- }
- m_webView->client()->setKeyboardFocusURL(focus_url);
-}
-
-Page* ChromeClientImpl::createWindow(
- Frame* frame, const FrameLoadRequest& r, const WindowFeatures& features)
-{
- if (!m_webView->client())
- return 0;
-
- WebViewImpl* newView = static_cast<WebViewImpl*>(
- m_webView->client()->createView(WebFrameImpl::fromFrame(frame)));
- if (!newView)
- return 0;
-
- // The request is empty when we are just being asked to open a blank window.
- // This corresponds to window.open(""), for example.
- if (!r.resourceRequest().isEmpty()) {
- WrappedResourceRequest request(r.resourceRequest());
- newView->mainFrame()->loadRequest(request);
- }
-
- return newView->page();
-}
-
-static inline bool currentEventShouldCauseBackgroundTab(const WebInputEvent* inputEvent)
-{
- if (!inputEvent)
- return false;
-
- if (inputEvent->type != WebInputEvent::MouseUp)
- return false;
-
- const WebMouseEvent* mouseEvent = static_cast<const WebMouseEvent*>(inputEvent);
-
- WebNavigationPolicy policy;
- unsigned short buttonNumber;
- switch (mouseEvent->button) {
- case WebMouseEvent::ButtonLeft:
- buttonNumber = 0;
- break;
- case WebMouseEvent::ButtonMiddle:
- buttonNumber = 1;
- break;
- case WebMouseEvent::ButtonRight:
- buttonNumber = 2;
- break;
- default:
- return false;
- }
- bool ctrl = mouseEvent->modifiers & WebMouseEvent::ControlKey;
- bool shift = mouseEvent->modifiers & WebMouseEvent::ShiftKey;
- bool alt = mouseEvent->modifiers & WebMouseEvent::AltKey;
- bool meta = mouseEvent->modifiers & WebMouseEvent::MetaKey;
-
- if (!WebViewImpl::navigationPolicyFromMouseEvent(buttonNumber, ctrl, shift, alt, meta, &policy))
- return false;
-
- return policy == WebNavigationPolicyNewBackgroundTab;
-}
-
-void ChromeClientImpl::show()
-{
- if (!m_webView->client())
- return;
-
- // If our default configuration was modified by a script or wasn't
- // created by a user gesture, then show as a popup. Else, let this
- // new window be opened as a toplevel window.
- bool asPopup = !m_toolbarsVisible
- || !m_statusbarVisible
- || !m_scrollbarsVisible
- || !m_menubarVisible
- || !m_resizable;
-
- WebNavigationPolicy policy = WebNavigationPolicyNewForegroundTab;
- if (asPopup)
- policy = WebNavigationPolicyNewPopup;
- if (currentEventShouldCauseBackgroundTab(WebViewImpl::currentInputEvent()))
- policy = WebNavigationPolicyNewBackgroundTab;
-
- m_webView->client()->show(policy);
-}
-
-bool ChromeClientImpl::canRunModal()
-{
- return !!m_webView->client();
-}
-
-void ChromeClientImpl::runModal()
-{
- if (m_webView->client())
- m_webView->client()->runModal();
-}
-
-void ChromeClientImpl::setToolbarsVisible(bool value)
-{
- m_toolbarsVisible = value;
-}
-
-bool ChromeClientImpl::toolbarsVisible()
-{
- return m_toolbarsVisible;
-}
-
-void ChromeClientImpl::setStatusbarVisible(bool value)
-{
- m_statusbarVisible = value;
-}
-
-bool ChromeClientImpl::statusbarVisible()
-{
- return m_statusbarVisible;
-}
-
-void ChromeClientImpl::setScrollbarsVisible(bool value)
-{
- m_scrollbarsVisible = value;
- WebFrameImpl* web_frame = static_cast<WebFrameImpl*>(m_webView->mainFrame());
- if (web_frame)
- web_frame->setAllowsScrolling(value);
-}
-
-bool ChromeClientImpl::scrollbarsVisible()
-{
- return m_scrollbarsVisible;
-}
-
-void ChromeClientImpl::setMenubarVisible(bool value)
-{
- m_menubarVisible = value;
-}
-
-bool ChromeClientImpl::menubarVisible()
-{
- return m_menubarVisible;
-}
-
-void ChromeClientImpl::setResizable(bool value)
-{
- m_resizable = value;
-}
-
-void ChromeClientImpl::addMessageToConsole(MessageSource source,
- MessageType type,
- MessageLevel level,
- const String& message,
- unsigned lineNumber,
- const String& sourceID)
-{
- if (m_webView->client()) {
- m_webView->client()->didAddMessageToConsole(
- WebConsoleMessage(static_cast<WebConsoleMessage::Level>(level), message),
- sourceID,
- lineNumber);
- }
-}
-
-bool ChromeClientImpl::canRunBeforeUnloadConfirmPanel()
-{
- return !!m_webView->client();
-}
-
-bool ChromeClientImpl::runBeforeUnloadConfirmPanel(const String& message, Frame* frame)
-{
- if (m_webView->client()) {
- return m_webView->client()->runModalBeforeUnloadDialog(
- WebFrameImpl::fromFrame(frame), message);
- }
- return false;
-}
-
-void ChromeClientImpl::closeWindowSoon()
-{
- // Make sure this Page can no longer be found by JS.
- m_webView->page()->setGroupName(String());
-
- // Make sure that all loading is stopped. Ensures that JS stops executing!
- m_webView->mainFrame()->stopLoading();
-
- if (m_webView->client())
- m_webView->client()->closeWidgetSoon();
-}
-
-// Although a Frame is passed in, we don't actually use it, since we
-// already know our own m_webView.
-void ChromeClientImpl::runJavaScriptAlert(Frame* frame, const String& message)
-{
- if (m_webView->client()) {
-#if USE(V8)
- // Before showing the JavaScript dialog, we give the proxy implementation
- // a chance to process any pending console messages.
- V8Proxy::processConsoleMessages();
-#endif
- m_webView->client()->runModalAlertDialog(
- WebFrameImpl::fromFrame(frame), message);
- }
-}
-
-// See comments for runJavaScriptAlert().
-bool ChromeClientImpl::runJavaScriptConfirm(Frame* frame, const String& message)
-{
- if (m_webView->client()) {
- return m_webView->client()->runModalConfirmDialog(
- WebFrameImpl::fromFrame(frame), message);
- }
- return false;
-}
-
-// See comments for runJavaScriptAlert().
-bool ChromeClientImpl::runJavaScriptPrompt(Frame* frame,
- const String& message,
- const String& defaultValue,
- String& result)
-{
- if (m_webView->client()) {
- WebString actualValue;
- bool ok = m_webView->client()->runModalPromptDialog(
- WebFrameImpl::fromFrame(frame),
- message,
- defaultValue,
- &actualValue);
- if (ok)
- result = actualValue;
- return ok;
- }
- return false;
-}
-
-void ChromeClientImpl::setStatusbarText(const String& message)
-{
- if (m_webView->client())
- m_webView->client()->setStatusText(message);
-}
-
-bool ChromeClientImpl::shouldInterruptJavaScript()
-{
- // FIXME: implement me
- return false;
-}
-
-bool ChromeClientImpl::tabsToLinks() const
-{
- // Returns true if anchors should accept keyboard focus with the tab key.
- // This method is used in a convoluted fashion by EventHandler::tabsToLinks.
- // It's a twisted path (self-evident, but more complicated than seems
- // necessary), but the net result is that returning true from here, on a
- // platform other than MAC or QT, lets anchors get keyboard focus.
- return m_webView->tabsToLinks();
-}
-
-IntRect ChromeClientImpl::windowResizerRect() const
-{
- IntRect result;
- if (m_webView->client())
- result = m_webView->client()->windowResizerRect();
- return result;
-}
-
-void ChromeClientImpl::repaint(
- const IntRect& paintRect, bool contentChanged, bool immediate,
- bool repaintContentOnly)
-{
- // Ignore spurious calls.
- if (!contentChanged || paintRect.isEmpty())
- return;
- if (m_webView->client())
- m_webView->client()->didInvalidateRect(paintRect);
-}
-
-void ChromeClientImpl::scroll(
- const IntSize& scrollDelta, const IntRect& scrollRect,
- const IntRect& clipRect)
-{
- if (m_webView->client()) {
- int dx = scrollDelta.width();
- int dy = scrollDelta.height();
- m_webView->client()->didScrollRect(dx, dy, clipRect);
- }
-}
-
-IntPoint ChromeClientImpl::screenToWindow(const IntPoint&) const
-{
- notImplemented();
- return IntPoint();
-}
-
-IntRect ChromeClientImpl::windowToScreen(const IntRect& rect) const
-{
- IntRect screenRect(rect);
-
- if (m_webView->client()) {
- WebRect windowRect = m_webView->client()->windowRect();
- screenRect.move(windowRect.x, windowRect.y);
- }
-
- return screenRect;
-}
-
-void ChromeClientImpl::contentsSizeChanged(Frame* frame, const IntSize& size) const
-{
- WebFrameImpl* webframe = WebFrameImpl::fromFrame(frame);
- if (webframe->client())
- webframe->client()->didChangeContentsSize(webframe, size);
-}
-
-void ChromeClientImpl::scrollbarsModeDidChange() const
-{
-}
-
-void ChromeClientImpl::mouseDidMoveOverElement(
- const HitTestResult& result, unsigned modifierFlags)
-{
- if (!m_webView->client())
- return;
- // Find out if the mouse is over a link, and if so, let our UI know...
- if (result.isLiveLink() && !result.absoluteLinkURL().string().isEmpty())
- m_webView->client()->setMouseOverURL(result.absoluteLinkURL());
- else
- m_webView->client()->setMouseOverURL(WebURL());
-}
-
-void ChromeClientImpl::setToolTip(const String& tooltipText, TextDirection dir)
-{
- if (!m_webView->client())
- return;
- WebTextDirection textDirection = (dir == RTL) ?
- WebTextDirectionRightToLeft :
- WebTextDirectionLeftToRight;
- m_webView->client()->setToolTipText(
- tooltipText, textDirection);
-}
-
-void ChromeClientImpl::print(Frame* frame)
-{
- if (m_webView->client())
- m_webView->client()->printPage(WebFrameImpl::fromFrame(frame));
-}
-
-void ChromeClientImpl::exceededDatabaseQuota(Frame* frame, const String& databaseName)
-{
- // set a reasonable quota for now -- 5Mb should be enough for anybody
- // TODO(dglazkov): this should be configurable
- SecurityOrigin* origin = frame->document()->securityOrigin();
- DatabaseTracker::tracker().setQuota(origin, 1024 * 1024 * 5);
-}
-
-#if ENABLE(OFFLINE_WEB_APPLICATIONS)
-void ChromeClientImpl::reachedMaxAppCacheSize(int64_t spaceNeeded)
-{
- ASSERT_NOT_REACHED();
-}
-#endif
-
-void ChromeClientImpl::runOpenPanel(Frame* frame, PassRefPtr<FileChooser> fileChooser)
-{
- WebViewClient* client = m_webView->client();
- if (!client)
- return;
-
- bool multipleFiles = fileChooser->allowsMultipleFiles();
-
- WebString suggestion;
- if (fileChooser->filenames().size() > 0)
- suggestion = fileChooser->filenames()[0];
-
- WebFileChooserCompletionImpl* chooserCompletion =
- new WebFileChooserCompletionImpl(fileChooser);
- bool ok = client->runFileChooser(multipleFiles,
- WebString(),
- suggestion,
- chooserCompletion);
- if (!ok) {
- // Choosing failed, so do callback with an empty list.
- chooserCompletion->didChooseFile(WebVector<WebString>());
- }
-}
-
-void ChromeClientImpl::popupOpened(PopupContainer* popupContainer,
- const IntRect& bounds,
- bool activatable,
- bool handleExternally)
-{
- if (!m_webView->client())
- return;
-
- WebWidget* webwidget;
- if (handleExternally) {
- WebPopupMenuInfo popupInfo;
- getPopupMenuInfo(popupContainer, &popupInfo);
- webwidget = m_webView->client()->createPopupMenu(popupInfo);
- } else
- webwidget = m_webView->client()->createPopupMenu(activatable);
-
- static_cast<WebPopupMenuImpl*>(webwidget)->Init(popupContainer, bounds);
-}
-
-void ChromeClientImpl::setCursor(const WebCursorInfo& cursor)
-{
- if (m_ignoreNextSetCursor) {
- m_ignoreNextSetCursor = false;
- return;
- }
-
- if (m_webView->client())
- m_webView->client()->didChangeCursor(cursor);
-}
-
-void ChromeClientImpl::setCursorForPlugin(const WebCursorInfo& cursor)
-{
- setCursor(cursor);
-
- // Currently, Widget::setCursor is always called after this function in
- // EventHandler.cpp and since we don't want that we set a flag indicating
- // that the next SetCursor call is to be ignored.
- m_ignoreNextSetCursor = true;
-}
-
-void ChromeClientImpl::formStateDidChange(const Node* node)
-{
- // The current history item is not updated yet. That happens lazily when
- // WebFrame::currentHistoryItem is requested.
- WebFrameImpl* webframe = WebFrameImpl::fromFrame(node->document()->frame());
- if (webframe->client())
- webframe->client()->didUpdateCurrentHistoryItem(webframe);
-}
-
-void ChromeClientImpl::getPopupMenuInfo(PopupContainer* popupContainer,
- WebPopupMenuInfo* info)
-{
- const Vector<PopupItem*>& inputItems = popupContainer->popupData();
-
- WebVector<WebPopupMenuInfo::Item> outputItems(inputItems.size());
-
- for (size_t i = 0; i < inputItems.size(); ++i) {
- const PopupItem& inputItem = *inputItems[i];
- WebPopupMenuInfo::Item& outputItem = outputItems[i];
-
- outputItem.label = inputItem.label;
- outputItem.enabled = inputItem.enabled;
-
- switch (inputItem.type) {
- case PopupItem::TypeOption:
- outputItem.type = WebPopupMenuInfo::Item::Option;
- break;
- case PopupItem::TypeGroup:
- outputItem.type = WebPopupMenuInfo::Item::Group;
- break;
- case PopupItem::TypeSeparator:
- outputItem.type = WebPopupMenuInfo::Item::Separator;
- break;
- default:
- ASSERT_NOT_REACHED();
- }
- }
-
- info->itemHeight = popupContainer->menuItemHeight();
- info->selectedIndex = popupContainer->selectedIndex();
- info->items.swap(outputItems);
-}
-
-#if ENABLE(NOTIFICATIONS)
-NotificationPresenter* ChromeClientImpl::notificationPresenter() const
-{
- return m_webView->notificationPresenterImpl();
-}
-#endif
-
-} // namespace WebKit
« no previous file with comments | « webkit/api/src/ChromeClientImpl.h ('k') | webkit/api/src/ChromiumBridge.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698