diff options
Diffstat (limited to 'Source/WebKit2/UIProcess/qt')
8 files changed, 205 insertions, 142 deletions
diff --git a/Source/WebKit2/UIProcess/qt/QtDialogRunner.cpp b/Source/WebKit2/UIProcess/qt/QtDialogRunner.cpp index 6e41c8b39..3ff4f273a 100644 --- a/Source/WebKit2/UIProcess/qt/QtDialogRunner.cpp +++ b/Source/WebKit2/UIProcess/qt/QtDialogRunner.cpp @@ -23,6 +23,7 @@ #include "WKRetainPtr.h" #include "WKStringQt.h" +#include "qquickwebview_p_p.h" #include "qwebpermissionrequest_p.h" #include <QtQml/QQmlComponent> #include <QtQml/QQmlContext> @@ -32,8 +33,9 @@ namespace WebKit { -QtDialogRunner::QtDialogRunner() +QtDialogRunner::QtDialogRunner(QQuickWebView* webView) : QEventLoop() + , m_webView(webView) , m_wasAccepted(false) { } @@ -42,30 +44,62 @@ QtDialogRunner::~QtDialogRunner() { } -class DialogContextObject : public QObject { +// All dialogs need a way to support the state of the +// dialog being done/finished/dismissed. This is handled +// in the dialog base context. +class DialogContextBase : public QObject { + Q_OBJECT + +public: + DialogContextBase() + : QObject() + , m_dismissed(false) + { + } + +public slots: + // Allows clients to call dismiss() directly, while also + // being able to hook up signals to automatically also + // dismiss the dialog since it's a slot. + + void dismiss() + { + m_dismissed = true; + emit dismissed(); + } + +signals: + void dismissed(); + +private: + // We store the dismissed state so that run() can check to see if a + // dialog has already been dismissed before spinning an event loop. + bool m_dismissed; + friend void QtDialogRunner::run(); +}; + +class DialogContextObject : public DialogContextBase { Q_OBJECT Q_PROPERTY(QString message READ message CONSTANT) Q_PROPERTY(QString defaultValue READ defaultValue CONSTANT) public: DialogContextObject(const QString& message, const QString& defaultValue = QString()) - : QObject() + : DialogContextBase() , m_message(message) , m_defaultValue(defaultValue) { + connect(this, SIGNAL(accepted(QString)), SLOT(dismiss())); + connect(this, SIGNAL(rejected()), SLOT(dismiss())); } QString message() const { return m_message; } QString defaultValue() const { return m_defaultValue; } public slots: - void dismiss() { emit dismissed(); } - void accept() { emit accepted(); } - void accept(const QString& result) { emit accepted(result); } + void accept(const QString& result = QString()) { emit accepted(result); } void reject() { emit rejected(); } signals: - void dismissed(); - void accepted(); void accepted(const QString& result); void rejected(); @@ -74,17 +108,19 @@ private: QString m_defaultValue; }; -class BaseAuthenticationContextObject : public QObject { +class BaseAuthenticationContextObject : public DialogContextBase { Q_OBJECT Q_PROPERTY(QString hostname READ hostname CONSTANT) Q_PROPERTY(QString prefilledUsername READ prefilledUsername CONSTANT) public: BaseAuthenticationContextObject(const QString& hostname, const QString& prefilledUsername) - : QObject() + : DialogContextBase() , m_hostname(hostname) , m_prefilledUsername(prefilledUsername) { + connect(this, SIGNAL(accepted(QString, QString)), SLOT(dismiss())); + connect(this, SIGNAL(rejected()), SLOT(dismiss())); } QString hostname() const { return m_hostname; } @@ -137,15 +173,17 @@ private: quint16 m_port; }; -class CertificateVerificationDialogContextObject : public QObject { +class CertificateVerificationDialogContextObject : public DialogContextBase { Q_OBJECT Q_PROPERTY(QString hostname READ hostname CONSTANT) public: CertificateVerificationDialogContextObject(const QString& hostname) - : QObject() + : DialogContextBase() , m_hostname(hostname) { + connect(this, SIGNAL(accepted()), SLOT(dismiss())); + connect(this, SIGNAL(rejected()), SLOT(dismiss())); } QString hostname() const { return m_hostname; } @@ -162,17 +200,19 @@ private: QString m_hostname; }; -class FilePickerContextObject : public QObject { +class FilePickerContextObject : public DialogContextBase { Q_OBJECT Q_PROPERTY(QStringList fileList READ fileList CONSTANT) Q_PROPERTY(bool allowMultipleFiles READ allowMultipleFiles CONSTANT) public: FilePickerContextObject(const QStringList& selectedFiles, bool allowMultiple) - : QObject() + : DialogContextBase() , m_allowMultiple(allowMultiple) , m_fileList(selectedFiles) { + connect(this, SIGNAL(fileSelected(QStringList)), SLOT(dismiss())); + connect(this, SIGNAL(rejected()), SLOT(dismiss())); } QStringList fileList() const { return m_fileList; } @@ -198,7 +238,7 @@ private: QStringList m_fileList; }; -class DatabaseQuotaDialogContextObject : public QObject { +class DatabaseQuotaDialogContextObject : public DialogContextBase { Q_OBJECT Q_PROPERTY(QString databaseName READ databaseName CONSTANT) Q_PROPERTY(QString displayName READ displayName CONSTANT) @@ -210,7 +250,7 @@ class DatabaseQuotaDialogContextObject : public QObject { public: DatabaseQuotaDialogContextObject(const QString& databaseName, const QString& displayName, WKSecurityOriginRef securityOrigin, quint64 currentQuota, quint64 currentOriginUsage, quint64 currentDatabaseUsage, quint64 expectedUsage) - : QObject() + : DialogContextBase() , m_databaseName(databaseName) , m_displayName(displayName) , m_currentQuota(currentQuota) @@ -224,6 +264,9 @@ public: m_securityOrigin.setScheme(WKStringCopyQString(scheme.get())); m_securityOrigin.setHost(WKStringCopyQString(host.get())); m_securityOrigin.setPort(static_cast<int>(WKSecurityOriginGetPort(securityOrigin))); + + connect(this, SIGNAL(accepted(quint64)), SLOT(dismiss())); + connect(this, SIGNAL(rejected()), SLOT(dismiss())); } QString databaseName() const { return m_databaseName; } @@ -252,118 +295,136 @@ private: QtWebSecurityOrigin m_securityOrigin; }; -bool QtDialogRunner::initForAlert(QQmlComponent* component, QQuickItem* dialogParent, const QString& message) +void QtDialogRunner::run() { - DialogContextObject* contextObject = new DialogContextObject(message); - if (!createDialog(component, dialogParent, contextObject)) - return false; + DialogContextBase* context = static_cast<DialogContextBase*>(m_dialogContext->contextObject()); - connect(contextObject, SIGNAL(dismissed()), SLOT(quit())); - return true; + // We may have already been dismissed as part of Component.onCompleted() + if (context->m_dismissed) + return; + + connect(context, SIGNAL(dismissed()), SLOT(quit())); + + QQuickWebViewPrivate* webViewPrivate = QQuickWebViewPrivate::get(m_webView); + + // FIXME: Change the way we disable mouse and touch events to use the + // concept of suspending instead (in this case event processing). + webViewPrivate->disableMouseEvents(); + webViewPrivate->m_dialogActive = true; + exec(); // Spin the event loop + webViewPrivate->m_dialogActive = false; + webViewPrivate->enableMouseEvents(); } -bool QtDialogRunner::initForConfirm(QQmlComponent* component, QQuickItem* dialogParent, const QString& message) +bool QtDialogRunner::initForAlert(const QString& message) { + QQmlComponent* component = m_webView->experimental()->alertDialog(); + if (!component) + return false; + DialogContextObject* contextObject = new DialogContextObject(message); - if (!createDialog(component, dialogParent, contextObject)) + + return createDialog(component, contextObject); +} + +bool QtDialogRunner::initForConfirm(const QString& message) +{ + QQmlComponent* component = m_webView->experimental()->confirmDialog(); + if (!component) return false; - connect(contextObject, SIGNAL(accepted()), SLOT(onAccepted())); - connect(contextObject, SIGNAL(accepted()), SLOT(quit())); - connect(contextObject, SIGNAL(rejected()), SLOT(quit())); - return true; + DialogContextObject* contextObject = new DialogContextObject(message); + connect(contextObject, SIGNAL(accepted(QString)), SLOT(onAccepted())); + + return createDialog(component, contextObject); } -bool QtDialogRunner::initForPrompt(QQmlComponent* component, QQuickItem* dialogParent, const QString& message, const QString& defaultValue) +bool QtDialogRunner::initForPrompt(const QString& message, const QString& defaultValue) { - DialogContextObject* contextObject = new DialogContextObject(message, defaultValue); - if (!createDialog(component, dialogParent, contextObject)) + QQmlComponent* component = m_webView->experimental()->promptDialog(); + if (!component) return false; + DialogContextObject* contextObject = new DialogContextObject(message, defaultValue); connect(contextObject, SIGNAL(accepted(QString)), SLOT(onAccepted(QString))); - connect(contextObject, SIGNAL(accepted(QString)), SLOT(quit())); - connect(contextObject, SIGNAL(rejected()), SLOT(quit())); - return true; + + return createDialog(component, contextObject); } -bool QtDialogRunner::initForAuthentication(QQmlComponent* component, QQuickItem* dialogParent, const QString& hostname, const QString& realm, const QString& prefilledUsername) +bool QtDialogRunner::initForAuthentication(const QString& hostname, const QString& realm, const QString& prefilledUsername) { - HttpAuthenticationDialogContextObject* contextObject = new HttpAuthenticationDialogContextObject(hostname, realm, prefilledUsername); - if (!createDialog(component, dialogParent, contextObject)) + QQmlComponent* component = m_webView->experimental()->authenticationDialog(); + if (!component) return false; + HttpAuthenticationDialogContextObject* contextObject = new HttpAuthenticationDialogContextObject(hostname, realm, prefilledUsername); connect(contextObject, SIGNAL(accepted(QString, QString)), SLOT(onAuthenticationAccepted(QString, QString))); - connect(contextObject, SIGNAL(accepted(QString, QString)), SLOT(quit())); - connect(contextObject, SIGNAL(rejected()), SLOT(quit())); - return true; + return createDialog(component, contextObject); } -bool QtDialogRunner::initForProxyAuthentication(QQmlComponent* component, QQuickItem* dialogParent, const QString& hostname, uint16_t port, const QString& prefilledUsername) +bool QtDialogRunner::initForProxyAuthentication(const QString& hostname, uint16_t port, const QString& prefilledUsername) { - ProxyAuthenticationDialogContextObject* contextObject = new ProxyAuthenticationDialogContextObject(hostname, port, prefilledUsername); - if (!createDialog(component, dialogParent, contextObject)) + QQmlComponent* component = m_webView->experimental()->proxyAuthenticationDialog(); + if (!component) return false; + ProxyAuthenticationDialogContextObject* contextObject = new ProxyAuthenticationDialogContextObject(hostname, port, prefilledUsername); connect(contextObject, SIGNAL(accepted(QString, QString)), SLOT(onAuthenticationAccepted(QString, QString))); - connect(contextObject, SIGNAL(accepted(QString, QString)), SLOT(quit())); - connect(contextObject, SIGNAL(rejected()), SLOT(quit())); - return true; + return createDialog(component, contextObject); } -bool QtDialogRunner::initForCertificateVerification(QQmlComponent* component, QQuickItem* dialogParent, const QString& hostname) +bool QtDialogRunner::initForCertificateVerification(const QString& hostname) { - CertificateVerificationDialogContextObject* contextObject = new CertificateVerificationDialogContextObject(hostname); - if (!createDialog(component, dialogParent, contextObject)) + QQmlComponent* component = m_webView->experimental()->certificateVerificationDialog(); + if (!component) return false; + CertificateVerificationDialogContextObject* contextObject = new CertificateVerificationDialogContextObject(hostname); connect(contextObject, SIGNAL(accepted()), SLOT(onAccepted())); - connect(contextObject, SIGNAL(accepted()), SLOT(quit())); - connect(contextObject, SIGNAL(rejected()), SLOT(quit())); - return true; + return createDialog(component, contextObject); } -bool QtDialogRunner::initForFilePicker(QQmlComponent* component, QQuickItem* dialogParent, const QStringList& selectedFiles, bool allowMultiple) +bool QtDialogRunner::initForFilePicker(const QStringList& selectedFiles, bool allowMultiple) { - FilePickerContextObject* contextObject = new FilePickerContextObject(selectedFiles, allowMultiple); - if (!createDialog(component, dialogParent, contextObject)) + QQmlComponent* component = m_webView->experimental()->filePicker(); + if (!component) return false; + FilePickerContextObject* contextObject = new FilePickerContextObject(selectedFiles, allowMultiple); connect(contextObject, SIGNAL(fileSelected(QStringList)), SLOT(onFileSelected(QStringList))); - connect(contextObject, SIGNAL(fileSelected(QStringList)), SLOT(quit())); - connect(contextObject, SIGNAL(rejected()), SLOT(quit())); - return true; + return createDialog(component, contextObject); } -bool QtDialogRunner::initForDatabaseQuotaDialog(QQmlComponent* component, QQuickItem* dialogParent, const QString& databaseName, const QString& displayName, WKSecurityOriginRef securityOrigin, quint64 currentQuota, quint64 currentOriginUsage, quint64 currentDatabaseUsage, quint64 expectedUsage) +bool QtDialogRunner::initForDatabaseQuotaDialog(const QString& databaseName, const QString& displayName, WKSecurityOriginRef securityOrigin, quint64 currentQuota, quint64 currentOriginUsage, quint64 currentDatabaseUsage, quint64 expectedUsage) { - DatabaseQuotaDialogContextObject* contextObject = new DatabaseQuotaDialogContextObject(databaseName, displayName, securityOrigin, currentQuota, currentOriginUsage, currentDatabaseUsage, expectedUsage); - if (!createDialog(component, dialogParent, contextObject)) + QQmlComponent* component = m_webView->experimental()->databaseQuotaDialog(); + if (!component) return false; + DatabaseQuotaDialogContextObject* contextObject = new DatabaseQuotaDialogContextObject(databaseName, displayName, securityOrigin, currentQuota, currentOriginUsage, currentDatabaseUsage, expectedUsage); connect(contextObject, SIGNAL(accepted(quint64)), SLOT(onDatabaseQuotaAccepted(quint64))); - connect(contextObject, SIGNAL(accepted(quint64)), SLOT(quit())); - connect(contextObject, SIGNAL(rejected()), SLOT(quit())); - return true; + return createDialog(component, contextObject); } -bool QtDialogRunner::createDialog(QQmlComponent* component, QQuickItem* dialogParent, QObject* contextObject) +bool QtDialogRunner::createDialog(QQmlComponent* component, QObject* contextObject) { QQmlContext* baseContext = component->creationContext(); if (!baseContext) - baseContext = QQmlEngine::contextForObject(dialogParent); + baseContext = QQmlEngine::contextForObject(m_webView); m_dialogContext = adoptPtr(new QQmlContext(baseContext)); - // This makes both "message" and "model.message" work for the dialog, just like QtQuick's ListView delegates. + // This makes both "message" and "model.message" work for the dialog, + // just like QtQuick's ListView delegates. contextObject->setParent(m_dialogContext.get()); m_dialogContext->setContextProperty(QLatin1String("model"), contextObject); m_dialogContext->setContextObject(contextObject); - QObject* object = component->create(m_dialogContext.get()); + QObject* object = component->beginCreate(m_dialogContext.get()); if (!object) { m_dialogContext.clear(); return false; @@ -376,10 +437,48 @@ bool QtDialogRunner::createDialog(QQmlComponent* component, QQuickItem* dialogPa return false; } - m_dialog->setParentItem(dialogParent); + QQuickWebViewPrivate::get(m_webView)->addAttachedPropertyTo(m_dialog.get()); + m_dialog->setParentItem(m_webView); + + // Only fully create the component once we've set both a parent + // and the needed context and attached properties, so that dialogs + // can do useful stuff in their Component.onCompleted() method. + component->completeCreate(); + + // FIXME: As part of completeCreate, the bindings of the item will be + // evaluated, but for some reason doing mapToItem/mapFromItem in a + // binding will not work as expected, even if we at binding evaluation + // time have the parent and all the way up to the root QML item. + // As a workaround you can set whichever property you need in + // Component.onCompleted, even to a binding using Qt.bind(). + return true; } +void QtDialogRunner::onAccepted(const QString& result) +{ + m_wasAccepted = true; + m_result = result; +} + +void QtDialogRunner::onAuthenticationAccepted(const QString& username, const QString& password) +{ + m_username = username; + m_password = password; +} + +void QtDialogRunner::onFileSelected(const QStringList& filePaths) +{ + m_wasAccepted = true; + m_filepaths = filePaths; +} + +void QtDialogRunner::onDatabaseQuotaAccepted(quint64 quota) +{ + m_wasAccepted = true; + m_databaseQuota = quota; +} + } // namespace WebKit #include "QtDialogRunner.moc" diff --git a/Source/WebKit2/UIProcess/qt/QtDialogRunner.h b/Source/WebKit2/UIProcess/qt/QtDialogRunner.h index eb229ec84..c04043d34 100644 --- a/Source/WebKit2/UIProcess/qt/QtDialogRunner.h +++ b/Source/WebKit2/UIProcess/qt/QtDialogRunner.h @@ -22,6 +22,7 @@ #define QtDialogRunner_h #include "WKSecurityOrigin.h" +#include "qquickwebview_p.h" #include <QtCore/QEventLoop> #include <QtCore/QStringList> #include <wtf/OwnPtr.h> @@ -38,17 +39,19 @@ class QtDialogRunner : public QEventLoop { Q_OBJECT public: - QtDialogRunner(); + QtDialogRunner(QQuickWebView*); virtual ~QtDialogRunner(); - bool initForAlert(QQmlComponent*, QQuickItem* dialogParent, const QString& message); - bool initForConfirm(QQmlComponent*, QQuickItem* dialogParent, const QString& message); - bool initForPrompt(QQmlComponent*, QQuickItem* dialogParent, const QString& message, const QString& defaultValue); - bool initForAuthentication(QQmlComponent*, QQuickItem* dialogParent, const QString& hostname, const QString& realm, const QString& prefilledUsername); - bool initForCertificateVerification(QQmlComponent*, QQuickItem*, const QString& hostname); - bool initForProxyAuthentication(QQmlComponent*, QQuickItem*, const QString& hostname, uint16_t port, const QString& prefilledUsername); - bool initForFilePicker(QQmlComponent*, QQuickItem*, const QStringList& selectedFiles, bool allowMultiple); - bool initForDatabaseQuotaDialog(QQmlComponent*, QQuickItem*, const QString& databaseName, const QString& displayName, WKSecurityOriginRef, quint64 currentQuota, quint64 currentOriginUsage, quint64 currentDatabaseUsage, quint64 expectedUsage); + bool initForAlert(const QString& message); + bool initForConfirm(const QString& message); + bool initForPrompt(const QString& message, const QString& defaultValue); + bool initForAuthentication(const QString& hostname, const QString& realm, const QString& prefilledUsername); + bool initForCertificateVerification(const QString& hostname); + bool initForProxyAuthentication(const QString& hostname, uint16_t port, const QString& prefilledUsername); + bool initForFilePicker(const QStringList& selectedFiles, bool allowMultiple); + bool initForDatabaseQuotaDialog(const QString& databaseName, const QString& displayName, WKSecurityOriginRef, quint64 currentQuota, quint64 currentOriginUsage, quint64 currentDatabaseUsage, quint64 expectedUsage); + + void run(); QQuickItem* dialog() const { return m_dialog.get(); } @@ -63,33 +66,15 @@ public: QStringList filePaths() const { return m_filepaths; } public slots: - void onAccepted(const QString& result = QString()) - { - m_wasAccepted = true; - m_result = result; - } - - void onAuthenticationAccepted(const QString& username, const QString& password) - { - m_username = username; - m_password = password; - } - - void onFileSelected(const QStringList& filePaths) - { - m_wasAccepted = true; - m_filepaths = filePaths; - } - - void onDatabaseQuotaAccepted(quint64 quota) - { - m_wasAccepted = true; - m_databaseQuota = quota; - } + void onAccepted(const QString& result = QString()); + void onAuthenticationAccepted(const QString& username, const QString& password); + void onFileSelected(const QStringList& filePaths); + void onDatabaseQuotaAccepted(quint64 quota); private: - bool createDialog(QQmlComponent*, QQuickItem* dialogParent, QObject* contextObject); + bool createDialog(QQmlComponent*, QObject* contextObject); + QQuickWebView* m_webView; OwnPtr<QQmlContext> m_dialogContext; OwnPtr<QQuickItem> m_dialog; QString m_result; diff --git a/Source/WebKit2/UIProcess/qt/QtViewportInteractionEngine.cpp b/Source/WebKit2/UIProcess/qt/QtViewportInteractionEngine.cpp index 949a5918c..eb3c5a8d2 100644 --- a/Source/WebKit2/UIProcess/qt/QtViewportInteractionEngine.cpp +++ b/Source/WebKit2/UIProcess/qt/QtViewportInteractionEngine.cpp @@ -192,6 +192,13 @@ bool QtViewportInteractionEngine::animateItemRectVisible(const QRectF& itemRect) if (itemRect == currentItemRectVisible) return false; + // FIXME: Investigate why that animation doesn't run when we are unfocused. + if (!m_viewport->isVisible() || !m_viewport->hasFocus()) { + // Apply the end result immediately when we are non-visible. + setItemRectVisible(itemRect); + return true; + } + m_scaleAnimation->setDuration(kScaleAnimationDurationMillis); m_scaleAnimation->setEasingCurve(QEasingCurve::OutCubic); @@ -254,36 +261,6 @@ static inline QPointF boundPosition(const QPointF minPosition, const QPointF& po qBound(minPosition.y(), position.y(), maxPosition.y())); } -void QtViewportInteractionEngine::wheelEvent(QWheelEvent* ev) -{ - if (scrollAnimationActive() || scaleAnimationActive() || pinchGestureActive()) - return; // Ignore. - - - // A normal scroll-tick should have a delta of 120 (1/8) degrees. Convert this to - // local standard scroll step of 3 lines of 20 pixels. - static const int cDefaultQtScrollStep = 20; - static const int wheelScrollLines = 3; - const int wheelTick = wheelScrollLines * cDefaultQtScrollStep; - - int pixelDelta = ev->delta() * (wheelTick / 120.f); - - QPointF newPosition = m_viewport->contentPos(); - - if (ev->orientation() == Qt::Horizontal) - newPosition.rx() -= pixelDelta; - else - newPosition.ry() -= pixelDelta; - - QRectF endPosRange = computePosRangeForItemAtScale(m_content->contentsScale()); - - QPointF currentPosition = m_viewport->contentPos(); - newPosition = boundPosition(endPosRange.topLeft(), newPosition, endPosRange.bottomRight()); - m_viewport->setContentPos(newPosition); - - emit contentViewportChanged(currentPosition - newPosition); -} - void QtViewportInteractionEngine::pagePositionRequest(const QPoint& pagePosition) { // Ignore the request if suspended. Can only happen due to delay in event delivery. diff --git a/Source/WebKit2/UIProcess/qt/QtViewportInteractionEngine.h b/Source/WebKit2/UIProcess/qt/QtViewportInteractionEngine.h index 8a720f34b..accfc6ad7 100644 --- a/Source/WebKit2/UIProcess/qt/QtViewportInteractionEngine.h +++ b/Source/WebKit2/UIProcess/qt/QtViewportInteractionEngine.h @@ -35,7 +35,7 @@ class QQuickWebView; class QWheelEvent; QT_END_NAMESPACE -class QWebViewportInfo; +class QWebKitTest; namespace WebKit { @@ -65,7 +65,6 @@ public: void setItemRectVisible(const QRectF&); bool animateItemRectVisible(const QRectF&); - void wheelEvent(QWheelEvent*); void pagePositionRequest(const QPoint& pos); void touchBegin(); void touchEnd(); @@ -116,7 +115,7 @@ private Q_SLOTS: private: friend class ViewportUpdateDeferrer; - friend class ::QWebViewportInfo; + friend class ::QWebKitTest; QQuickWebView* const m_viewport; QQuickWebPage* const m_content; diff --git a/Source/WebKit2/UIProcess/qt/QtWebContext.cpp b/Source/WebKit2/UIProcess/qt/QtWebContext.cpp index 30d59c2a4..8239c5d21 100644 --- a/Source/WebKit2/UIProcess/qt/QtWebContext.cpp +++ b/Source/WebKit2/UIProcess/qt/QtWebContext.cpp @@ -47,6 +47,7 @@ QtWebContext* QtWebContext::s_defaultContext = 0; static void initInspectorServer() { +#if ENABLE(INSPECTOR_SERVER) QString inspectorEnv = QString::fromUtf8(qgetenv("QTWEBKIT_INSPECTOR_SERVER")); if (!inspectorEnv.isEmpty()) { QString bindAddress = QLatin1String("127.0.0.1"); @@ -73,6 +74,7 @@ static void initInspectorServer() } else qWarning("Couldn't start the inspector server on bind address \"%s\" and port \"%d\". In case of invalid input, try something like: \"12345\" or \"192.168.2.14:12345\" (with the address of one of this host's interface).", qPrintable(bindAddress), port); } +#endif } static void globalInitialization() diff --git a/Source/WebKit2/UIProcess/qt/QtWebIconDatabaseClient.cpp b/Source/WebKit2/UIProcess/qt/QtWebIconDatabaseClient.cpp index d94b634b3..c769c8b03 100644 --- a/Source/WebKit2/UIProcess/qt/QtWebIconDatabaseClient.cpp +++ b/Source/WebKit2/UIProcess/qt/QtWebIconDatabaseClient.cpp @@ -45,7 +45,8 @@ QtWebIconDatabaseClient::QtWebIconDatabaseClient(QtWebContext *qtWebContext) m_contextId = qtWebContext->contextID(); // The setter calls the getter here as it triggers the startup of the icon database. WebContext* context = qtWebContext->context(); - context->setIconDatabasePath(context->iconDatabasePath()); + if (!context->iconDatabase()->isOpen()) + context->setIconDatabasePath(context->iconDatabasePath()); m_iconDatabase = context->iconDatabase(); WKIconDatabaseClient iconDatabaseClient; diff --git a/Source/WebKit2/UIProcess/qt/QtWebPageEventHandler.cpp b/Source/WebKit2/UIProcess/qt/QtWebPageEventHandler.cpp index bbfab1a5a..c1ebaac14 100644 --- a/Source/WebKit2/UIProcess/qt/QtWebPageEventHandler.cpp +++ b/Source/WebKit2/UIProcess/qt/QtWebPageEventHandler.cpp @@ -154,9 +154,6 @@ void QtWebPageEventHandler::handleWheelEvent(QWheelEvent* ev) { QTransform fromItemTransform = m_webPage->transformFromItem(); m_webPageProxy->handleWheelEvent(NativeWebWheelEvent(ev, fromItemTransform)); - // FIXME: Handle whether the page used the wheel event or not. - if (m_interactionEngine) - m_interactionEngine->wheelEvent(ev); } void QtWebPageEventHandler::handleHoverLeaveEvent(QHoverEvent* ev) diff --git a/Source/WebKit2/UIProcess/qt/WebPopupMenuProxyQt.cpp b/Source/WebKit2/UIProcess/qt/WebPopupMenuProxyQt.cpp index 9f9100a54..648394b6f 100644 --- a/Source/WebKit2/UIProcess/qt/WebPopupMenuProxyQt.cpp +++ b/Source/WebKit2/UIProcess/qt/WebPopupMenuProxyQt.cpp @@ -283,10 +283,13 @@ void WebPopupMenuProxyQt::createItem(QObject* contextObject) connect(contextObject, SIGNAL(acceptedWithOriginalIndex(int)), SLOT(hidePopupMenu()), Qt::QueuedConnection); connect(contextObject, SIGNAL(rejected()), SLOT(hidePopupMenu()), Qt::QueuedConnection); - QQuickWebViewPrivate::get(m_webView)->setViewInAttachedProperties(m_itemSelector.get()); - component->completeCreate(); - + QQuickWebViewPrivate::get(m_webView)->addAttachedPropertyTo(m_itemSelector.get()); m_itemSelector->setParentItem(m_webView); + + // Only fully create the component once we've set both a parent + // and the needed context and attached properties, so that the + // dialog can do useful stuff in Component.onCompleted(). + component->completeCreate(); } void WebPopupMenuProxyQt::createContext(QQmlComponent* component, QObject* contextObject) |