aboutsummaryrefslogtreecommitdiff
path: root/libraries/qt4/patches
diff options
context:
space:
mode:
Diffstat (limited to 'libraries/qt4/patches')
-rw-r--r--libraries/qt4/patches/0180-window-role.diff101
-rw-r--r--libraries/qt4/patches/0195-compositing-properties.diff58
-rw-r--r--libraries/qt4/patches/0225-invalidate-tabbar-geometry-on-refresh.patch35
-rw-r--r--libraries/qt4/patches/0234-fix-mysql-threaded.diff32
-rw-r--r--libraries/qt4/patches/0255-qtreeview-selection-columns-hidden.diff44
-rw-r--r--libraries/qt4/patches/0274-shm-native-image-fix.diff97
-rw-r--r--libraries/qt4/patches/0279-svg-rendering-regression.diff26
-rw-r--r--libraries/qt4/patches/0280-deserialization-custom-dbus-properties.diff47
-rw-r--r--libraries/qt4/patches/qt.mysql.h.diff12
-rw-r--r--libraries/qt4/patches/qt.x86.cflags.diff11
10 files changed, 0 insertions, 463 deletions
diff --git a/libraries/qt4/patches/0180-window-role.diff b/libraries/qt4/patches/0180-window-role.diff
deleted file mode 100644
index 687e11cb11b6f..0000000000000
--- a/libraries/qt4/patches/0180-window-role.diff
+++ /dev/null
@@ -1,101 +0,0 @@
-qt-bugs@ issue : 167704
-Trolltech task ID : 168283 (status: "fixed" for Qt 4.4.0, but effectively refused)
-bugs.kde.org number : none
-applied: no
-author: Lubos Lunak <l.lunak@kde.org>
-
-NOTE: It is suggested to apply patch #0209 as well when this patch is used.
-
-This patch uses object name as a fallback for window role if no window role
-is set explicitly using setWindowRole(). Since Qt3 always used the object
-name as the window role and most Qt3/KDE3 code is ported to call setObjectName(),
-this makes the window role set in many cases (which KWin uses for window identifying).
-
-
---- src/corelib/kernel/qobject.cpp.sav 2008-02-22 09:03:40.000000000 +0100
-+++ src/corelib/kernel/qobject.cpp 2008-02-23 16:15:51.000000000 +0100
-@@ -1016,9 +1016,18 @@ void QObject::setObjectName(const QStrin
- {
- Q_D(QObject);
- d->objectName = name;
-+#if defined(Q_WS_X11)
-+ d->checkWindowRole();
-+#endif
- }
-
-
-+#if defined(Q_WS_X11)
-+void QObjectPrivate::checkWindowRole()
-+{
-+}
-+#endif
-+
- #ifdef QT3_SUPPORT
- /*! \internal
- QObject::child is compat but needs to call itself recursively,
---- src/corelib/kernel/qobject_p.h.sav 2008-02-22 09:23:44.000000000 +0100
-+++ src/corelib/kernel/qobject_p.h 2008-02-23 16:16:46.000000000 +0100
-@@ -148,6 +148,9 @@ public:
- mutable quint32 connectedSignals;
-
- QString objectName;
-+#if defined(Q_WS_X11)
-+ virtual void checkWindowRole();
-+#endif
-
- // Note: you must hold the signalSlotLock() before accessing the lists below or calling the functions
- struct Connection
---- src/gui/kernel/qwidget_p.h.sav 2008-02-22 09:04:04.000000000 +0100
-+++ src/gui/kernel/qwidget_p.h 2008-02-23 16:17:07.000000000 +0100
-@@ -324,6 +324,7 @@ public:
-
- #if defined(Q_WS_X11)
- void setWindowRole();
-+ virtual void checkWindowRole();
- void sendStartupMessage(const char *message) const;
- void setNetWmWindowTypes();
- #endif
---- src/gui/kernel/qwidget_x11.cpp.sav 2008-02-23 15:28:47.000000000 +0100
-+++ src/gui/kernel/qwidget_x11.cpp 2008-02-23 16:31:47.000000000 +0100
-@@ -710,13 +710,17 @@ void QWidgetPrivate::create_sys(WId wind
-
-
- // declare the widget's window role
-+ QByteArray windowRole;
- if (QTLWExtra *topData = maybeTopData()) {
-- if (!topData->role.isEmpty()) {
-- QByteArray windowRole = topData->role.toUtf8();
-- XChangeProperty(dpy, id,
-- ATOM(WM_WINDOW_ROLE), XA_STRING, 8, PropModeReplace,
-- (unsigned char *)windowRole.constData(), windowRole.length());
-- }
-+ if (!topData->role.isEmpty())
-+ windowRole = topData->role.toUtf8();
-+ }
-+ if (windowRole.isEmpty()) // use object name as a fallback
-+ windowRole = objectName.toUtf8();
-+ if (!windowRole.isEmpty()) {
-+ XChangeProperty(dpy, id,
-+ ATOM(WM_WINDOW_ROLE), XA_STRING, 8, PropModeReplace,
-+ (unsigned char *)windowRole.constData(), windowRole.length());
- }
-
- // set client leader property
-@@ -2852,6 +2856,17 @@ void QWidgetPrivate::setWindowRole()
- (unsigned char *)windowRole.constData(), windowRole.length());
- }
-
-+void QWidgetPrivate::checkWindowRole()
-+{
-+ Q_Q(QWidget);
-+ if( !q->windowRole().isEmpty() || !q->internalWinId())
-+ return;
-+ QByteArray windowRole = objectName.toUtf8(); // use as a fallback
-+ XChangeProperty(X11->display, q->internalWinId(),
-+ ATOM(WM_WINDOW_ROLE), XA_STRING, 8, PropModeReplace,
-+ (unsigned char *)windowRole.constData(), windowRole.length());
-+}
-+
- Q_GLOBAL_STATIC(QX11PaintEngine, qt_widget_paintengine)
- QPaintEngine *QWidget::paintEngine() const
- {
diff --git a/libraries/qt4/patches/0195-compositing-properties.diff b/libraries/qt4/patches/0195-compositing-properties.diff
deleted file mode 100644
index 979df943662e2..0000000000000
--- a/libraries/qt4/patches/0195-compositing-properties.diff
+++ /dev/null
@@ -1,58 +0,0 @@
-qt-bugs@ issue : none
-bugs.kde.org number : none
-applied: no
-author: Lubos Lunak <l.lunak@kde.org>
-
-This patch makes override-redirect windows (popup menu, dropdown menu,
-tooltip, combobox, etc.) also have more window properties like WM_CLASS,
-so they can be used when compositing.
-
---- src/gui/kernel/qwidget_x11.cpp
-+++ src/gui/kernel/qwidget_x11.cpp
-@@ -637,6 +637,11 @@ void QWidgetPrivate::create_sys(WId window, bool initializeWindow, bool destroyO
- Q_ASSERT(id);
- XChangeWindowAttributes(dpy, id, CWOverrideRedirect | CWSaveUnder,
- &wsa);
-+ XClassHint class_hint;
-+ QByteArray appName = qAppName().toLatin1();
-+ class_hint.res_name = appName.data(); // application name
-+ class_hint.res_class = const_cast<char *>(QX11Info::appClass()); // application class
-+ XSetWMProperties(dpy, id, 0, 0, 0, 0, 0, 0, &class_hint);
- } else if (topLevel && !desktop) { // top-level widget
- if (!X11->wm_client_leader)
- create_wm_client_leader();
-@@ -685,13 +690,21 @@ void QWidgetPrivate::create_sys(WId window, bool initializeWindow, bool destroyO
- // set EWMH window types
- setNetWmWindowTypes();
-
-+ // when we create a toplevel widget, the frame strut should be dirty
-+ data.fstrut_dirty = 1;
-+
-+ } else {
-+ // non-toplevel widgets don't have a frame, so no need to
-+ // update the strut
-+ data.fstrut_dirty = 0;
-+ }
-+
-+ if (initializeWindow && (popup || (topLevel && !desktop))) { // properties set on all toplevel windows
- // set _NET_WM_PID
- long curr_pid = getpid();
- XChangeProperty(dpy, id, ATOM(_NET_WM_PID), XA_CARDINAL, 32, PropModeReplace,
- (unsigned char *) &curr_pid, 1);
-
-- // when we create a toplevel widget, the frame strut should be dirty
-- data.fstrut_dirty = 1;
-
- // declare the widget's window role
- if (QTLWExtra *topData = maybeTopData()) {
-@@ -707,10 +720,6 @@ void QWidgetPrivate::create_sys(WId window, bool initializeWindow, bool destroyO
- XChangeProperty(dpy, id, ATOM(WM_CLIENT_LEADER),
- XA_WINDOW, 32, PropModeReplace,
- (unsigned char *)&X11->wm_client_leader, 1);
-- } else {
-- // non-toplevel widgets don't have a frame, so no need to
-- // update the strut
-- data.fstrut_dirty = 0;
- }
-
- if (initializeWindow && q->internalWinId()) {
diff --git a/libraries/qt4/patches/0225-invalidate-tabbar-geometry-on-refresh.patch b/libraries/qt4/patches/0225-invalidate-tabbar-geometry-on-refresh.patch
deleted file mode 100644
index 49daca322f3b1..0000000000000
--- a/libraries/qt4/patches/0225-invalidate-tabbar-geometry-on-refresh.patch
+++ /dev/null
@@ -1,35 +0,0 @@
-qt-bugs@ issue : 208185
-Trolltech task ID : 208349
-bugs.kde.org number : 159014
-applied: no
-author: Robert Knight <robertknight@gmail.com>
-
-When tabs are inserted or removed in a QTabBar, QTabBarPrivate::refresh()
-is called to update the layout. If the tabbar widget is hidden, this
-just sets a boolean variable (layoutDirty) and returns, so the parent widget's layout
-is not notified about the possible geometry change.
-
-Prior to Qt 4.4 this was not a problem because the geometry was recalculated
-in QTabBar::sizeHint() if the layoutDirty variable was set. In Qt 4.4 however the layout
-caches size hint information in QWidgetItemV2. Since the cache information is not invalidated,
-the layout may end up using out-of-date size hint information to compute the widget size.
-
-If the QTabBar is empty when QTabBar::sizeHint() is called, it will return a size with a height
-of 0, which will be kept in the cache and so the tab bar will never be shown.
-
-This patch fixes the problem by calling updateGeometry() whenever the tab bar's layout is refreshed.
-
-Index: src/gui/widgets/qtabbar.cpp
-===================================================================
---- src/gui/widgets/qtabbar.cpp (revision 796858)
-+++ src/gui/widgets/qtabbar.cpp (working copy)
-@@ -533,8 +533,8 @@
- layoutTabs();
- makeVisible(currentIndex);
- q->update();
-- q->updateGeometry();
- }
-+ q->updateGeometry();
- }
-
- /*!
diff --git a/libraries/qt4/patches/0234-fix-mysql-threaded.diff b/libraries/qt4/patches/0234-fix-mysql-threaded.diff
deleted file mode 100644
index 4c5b6136b8c18..0000000000000
--- a/libraries/qt4/patches/0234-fix-mysql-threaded.diff
+++ /dev/null
@@ -1,32 +0,0 @@
-qt-bugs@ issue : N217716
-Trolltech task ID : 217788
-bugs.kde.org number : no report
-applied: no
-author: Tobias Koenig <tokoe@kde.org>
-
-This patch will fix the handling of connections to
-mysql server in a multithreaded environment
-
---- src/sql/drivers/mysql/qsql_mysql.cpp (revision 804421)
-+++ src/sql/drivers/mysql/qsql_mysql.cpp (working copy)
-@@ -1215,6 +1215,10 @@
- d->preparedQuerysEnabled = false;
- #endif
-
-+#ifndef QT_NO_THREAD
-+ mysql_thread_init();
-+#endif
-+
- setOpen(true);
- setOpenError(false);
- return true;
-@@ -1223,6 +1227,9 @@
- void QMYSQLDriver::close()
- {
- if (isOpen()) {
-+#ifndef QT_NO_THREAD
-+ mysql_thread_end();
-+#endif
- mysql_close(d->mysql);
- setOpen(false);
- setOpenError(false);
diff --git a/libraries/qt4/patches/0255-qtreeview-selection-columns-hidden.diff b/libraries/qt4/patches/0255-qtreeview-selection-columns-hidden.diff
deleted file mode 100644
index 08677af633f12..0000000000000
--- a/libraries/qt4/patches/0255-qtreeview-selection-columns-hidden.diff
+++ /dev/null
@@ -1,44 +0,0 @@
-qt-bugs@ issue : N232819
-Trolltech task ID : 232831
-applied: no
-author: Rafael Fernández López <ereslibre@kde.org>
-
-In a treeview with columns like this:
-
-Column 1 | Column 2 | ... | Column k | ... | Column n
-
-When selecting with rubberband (by clicking on the blank part of the viewport) while Column k is
-hidden, you get double items on the selection model, when asking for selection(). This is becase
-ranges are incorrectly calculated when there are hidden columns. A way to reproduce:
-
-Column 1 | Column 2 | Column 4 (Column 3 is hidden)
- item
- item
- item
- x <- press button here and move it up to select items (on this same column)
-
-If you do like this:
-
-Column 1 | Column 2 | Column 4 (Column 3 is hidden)
- item
- item
- item
- x <- press button here and move it up
-
-you won't be able to reproduce, since you need the hidden column to be between the one you click and
-the last one. The reason is that columnRanges returns two ranges when there is supposed to return 1
-range (even when there are hidden columns).
-
-diff --git a/src/gui/itemviews/qtreeview.cpp b/src/gui/itemviews/qtreeview.cpp
-index d5ca633..b7975be 100644
---- src/gui/itemviews/qtreeview.cpp
-+++ src/gui/itemviews/qtreeview.cpp
-@@ -3494,7 +3494,7 @@
- current.first = -2; // -1 is not enough because -1+1 = 0
- current.second = -2;
- foreach (int logicalColumn, logicalIndexes) {
-- if (current.second + 1 != logicalColumn) {
-+ if (current.second + 1 != logicalColumn && !header->isSectionHidden(current.second + 1)) {
- if (current.first != -2) {
- //let's save the current one
- ret += current;
diff --git a/libraries/qt4/patches/0274-shm-native-image-fix.diff b/libraries/qt4/patches/0274-shm-native-image-fix.diff
deleted file mode 100644
index 0ea21467a4cbb..0000000000000
--- a/libraries/qt4/patches/0274-shm-native-image-fix.diff
+++ /dev/null
@@ -1,97 +0,0 @@
-qt-bugs@ issue : none
-Qt Software task ID : none
-bugs.kde.org number : none
-applied: no
-author: Fredrik Höglund <fredrik@kde.org>
-
-This patch makes the raster graphics system use shared images instead
-of shared pixmaps.
-
-Shared memory pixmaps are deprecated since they are slower than shared
-images with modern graphics hardware. They are also not supported by EXA
-drivers and can be disabled in the latest version of the NVidia driver.
-
-Index: src/gui/kernel/qapplication_x11.cpp
-===================================================================
---- src/gui/kernel/qapplication_x11.cpp (revision 934506)
-+++ src/gui/kernel/qapplication_x11.cpp (working copy)
-@@ -1943,7 +1943,7 @@ void qt_init(QApplicationPrivate *priv,
- // to determine whether the display is local or not (not 100 % accurate)
- bool local = displayName.isEmpty() || displayName.lastIndexOf(QLatin1Char(':')) == 0;
- if (local && (qgetenv("QT_X11_NO_MITSHM").toInt() == 0))
-- X11->use_mitshm = mitshm_pixmaps;
-+ X11->use_mitshm = true;
- }
- #endif // QT_NO_MITSHM
-
-Index: src/gui/image/qnativeimage_p.h
-===================================================================
---- src/gui/image/qnativeimage_p.h (revision 930645)
-+++ src/gui/image/qnativeimage_p.h (working copy)
-@@ -85,7 +85,6 @@
-
- #elif defined(Q_WS_X11) && !defined(QT_NO_MITSHM)
- XImage *xshmimg;
-- Pixmap xshmpm;
- XShmSegmentInfo xshminfo;
-
- #elif defined(Q_WS_MAC)
-Index: src/gui/image/qnativeimage.cpp
-===================================================================
---- src/gui/image/qnativeimage.cpp (revision 930645)
-+++ src/gui/image/qnativeimage.cpp (working copy)
-@@ -140,7 +140,6 @@
- {
- if (!X11->use_mitshm) {
- xshmimg = 0;
-- xshmpm = 0;
- image = QImage(width, height, format);
- return;
- }
-@@ -184,11 +183,6 @@
- shmctl(xshminfo.shmid, IPC_RMID, 0);
- return;
- }
-- xshmpm = XShmCreatePixmap(X11->display, DefaultRootWindow(X11->display), xshmimg->data,
-- &xshminfo, width, height, dd);
-- if (!xshmpm) {
-- qWarning() << "QNativeImage: Unable to create shared Pixmap.";
-- }
- }
-
-
-@@ -197,10 +191,6 @@
- if (!xshmimg)
- return;
-
-- if (xshmpm) {
-- XFreePixmap(X11->display, xshmpm);
-- xshmpm = 0;
-- }
- XShmDetach(X11->display, &xshminfo);
- xshmimg->data = 0;
- XDestroyImage(xshmimg);
-Index: src/gui/painting/qwindowsurface_raster.cpp
-===================================================================
---- src/gui/painting/qwindowsurface_raster.cpp (revision 930645)
-+++ src/gui/painting/qwindowsurface_raster.cpp (working copy)
-@@ -228,9 +228,16 @@
-
- QRect br = rgn.boundingRect().translated(offset);
- #ifndef QT_NO_MITSHM
-- if (d_ptr->image->xshmpm) {
-- XCopyArea(X11->display, d_ptr->image->xshmpm, widget->handle(), d_ptr->gc,
-- br.x(), br.y(), br.width(), br.height(), wbr.x(), wbr.y());
-+ if (d_ptr->image->xshmimg && (br.width() * br.height() > 65536)) {
-+ const QImage &src = d->image->image;
-+ br = br.intersected(src.rect());
-+ // Hack to make sure we satisify the PutImage() constraints in the X server,
-+ // since the doShmPutImage() route currently forces a migration to system ram.
-+ wbr.setX(wbr.x() - br.x());
-+ br.setX(0);
-+ br.setWidth(src.width());
-+ XShmPutImage(X11->display, widget->handle(), d_ptr->gc, d_ptr->image->xshmimg,
-+ br.x(), br.y(), wbr.x(), wbr.y(), br.width(), br.height(), False);
- XSync(X11->display, False);
- } else
- #endif
diff --git a/libraries/qt4/patches/0279-svg-rendering-regression.diff b/libraries/qt4/patches/0279-svg-rendering-regression.diff
deleted file mode 100644
index 0ce074eb32557..0000000000000
--- a/libraries/qt4/patches/0279-svg-rendering-regression.diff
+++ /dev/null
@@ -1,26 +0,0 @@
-qt-bugs@ issue : none (not yet)
-Qt Software task ID : none (not yet)
-bugs.kde.org number : 190485 (at least)
-applied: no
-author: Alexis Menard <alexis.menard@nokia.com>
-
-This patch fix the regression introduced in 4.5.1 with SVG rendering.
-The problem appear when a gradient reference an another gradient which is after
-in the svg.
-
-Please clear your plasma cache as well.
-
-This patch is already in 4.5 branch so it will be in 4.5.2.
-
-Index: src/svg/qsvgstyle.cpp
-===================================================================
---- src/svg/qsvgstyle.cpp (revision 958572)
-+++ src/svg/qsvgstyle.cpp (working copy)
-@@ -808,6 +808,7 @@
- static_cast<QSvgGradientStyle*>(prop);
- st->resolveStops();
- m_gradient->setStops(st->qgradient()->stops());
-+ m_gradientStopsSet = st->gradientStopsSet();
- }
- }
- m_link = QString();
diff --git a/libraries/qt4/patches/0280-deserialization-custom-dbus-properties.diff b/libraries/qt4/patches/0280-deserialization-custom-dbus-properties.diff
deleted file mode 100644
index 7de633d1e2bae..0000000000000
--- a/libraries/qt4/patches/0280-deserialization-custom-dbus-properties.diff
+++ /dev/null
@@ -1,47 +0,0 @@
-qt-bugs@ issue : N240326
-Qt Software task ID : 240608
-bugs.kde.org number : none
-applied: no
-author: George Goldberg <grundleborg@googlemail.com>
-
-This patch fixes deserialization of values with custom types when setting
-properties on dbus adaptors. It is needed, in particular by telepathy/Qt
-programs and libraries. The bug was reported to Nokia on 2009-01-07 along
-with the patch supplied here. The summary of the issue from the Qt
-Software task tracker follows:
-
-When calling the setter for a DBus property, if that property has a custom type
-(e.g. a struct with dbus type (uss)), QtDBus fails to demarshall the
-QDBusArgument before attempting to set the property on the adaptor. The result
-is that it attempts to call adaptor->setProperty() with a QDBusArgument of type
-"uss" instead of with the type of the custom struct.
-
-Index: src/dbus/qdbusinternalfilters.cpp
-===================================================================
---- src/dbus/qdbusinternalfilters.cpp (revision 960506)
-+++ src/dbus/qdbusinternalfilters.cpp (working copy)
-@@ -274,9 +274,23 @@
- QDBusAdaptorConnector::AdaptorMap::ConstIterator it;
- it = qLowerBound(connector->adaptors.constBegin(), connector->adaptors.constEnd(),
- interface_name);
-- if (it != connector->adaptors.end() && interface_name == QLatin1String(it->interface))
-+ if (it != connector->adaptors.end() && interface_name == QLatin1String(it->interface)) {
-+ if (value.userType() == qMetaTypeId<QDBusArgument>()) {
-+ QDBusArgument valueArg = qvariant_cast<QDBusArgument>(value);
-+ if (valueArg.currentType() != -1) {
-+ int mid = it->adaptor->metaObject()->property(it->adaptor->metaObject()->indexOfProperty(property_name)).userType();
-+ void *null = 0;
-+ QVariant valueStore(mid, null);
-+ QDBusMetaType::demarshall(valueArg, mid, valueStore.data());
-+
-+ if (it->adaptor->setProperty(property_name, valueStore))
-+ return msg.createReply();
-+ }
-+ }
-+
- if (it->adaptor->setProperty(property_name, value))
- return msg.createReply();
-+ }
- }
- }
-
diff --git a/libraries/qt4/patches/qt.mysql.h.diff b/libraries/qt4/patches/qt.mysql.h.diff
deleted file mode 100644
index 7a41be5911efc..0000000000000
--- a/libraries/qt4/patches/qt.mysql.h.diff
+++ /dev/null
@@ -1,12 +0,0 @@
-diff -Nur qt-x11-opensource-src-4.3.4.orig/src/sql/drivers/mysql/qsql_mysql.h qt-x11-opensource-src-4.3.4/src/sql/drivers/mysql/qsql_mysql.h
---- qt-x11-opensource-src-4.3.4.orig/src/sql/drivers/mysql/qsql_mysql.h 2008-04-02 20:52:11.739343004 -0500
-+++ qt-x11-opensource-src-4.3.4/src/sql/drivers/mysql/qsql_mysql.h 2008-04-02 20:52:05.970610574 -0500
-@@ -51,7 +51,7 @@
- #include <QtCore/qt_windows.h>
- #endif
-
--#include <mysql.h>
-+#include <mysql/mysql.h>
-
- #ifdef QT_PLUGIN
- #define Q_EXPORT_SQLDRIVER_MYSQL
diff --git a/libraries/qt4/patches/qt.x86.cflags.diff b/libraries/qt4/patches/qt.x86.cflags.diff
deleted file mode 100644
index a9e65fbb84e06..0000000000000
--- a/libraries/qt4/patches/qt.x86.cflags.diff
+++ /dev/null
@@ -1,11 +0,0 @@
---- qt.orig/mkspecs/common/g++.conf 2007-12-22 00:22:18.295453075 -0600
-+++ qt/mkspecs/common/g++.conf 2007-12-22 00:23:07.514257895 -0600
-@@ -7,7 +7,7 @@
- QMAKE_CFLAGS_DEPS += -M
- QMAKE_CFLAGS_WARN_ON += -Wall -W
- QMAKE_CFLAGS_WARN_OFF += -w
--QMAKE_CFLAGS_RELEASE += -O2
-+QMAKE_CFLAGS_RELEASE += -O2 -march=i486 -mtune=i686
- QMAKE_CFLAGS_DEBUG += -g
- QMAKE_CFLAGS_SHLIB += -fPIC
- QMAKE_CFLAGS_STATIC_LIB += -fPIC