Enable checking for whether the system palette was explicitly set

In order to obey a palette set globally on QApplication, an application
attribute for checking if it's set at all is added.

Task-number: QTBUG-39800
Change-Id: I26b965e6e18e0e1ca4df03cf343b3527df3636b2
Reviewed-by: J-P Nurmi <jpnurmi@theqtcompany.com>
Reviewed-by: Friedemann Kleint <Friedemann.Kleint@theqtcompany.com>
This commit is contained in:
Harald Hvaal 2015-03-28 21:03:29 +01:00
parent 6526a4e136
commit 8fb881900c
5 changed files with 23 additions and 0 deletions

View File

@ -492,6 +492,7 @@ public:
AA_UseOpenGLES = 16, AA_UseOpenGLES = 16,
AA_UseSoftwareOpenGL = 17, AA_UseSoftwareOpenGL = 17,
AA_ShareOpenGLContexts = 18, AA_ShareOpenGLContexts = 18,
AA_SetPalette = 19,
// Add new attributes before this line // Add new attributes before this line
AA_AttributeCount AA_AttributeCount

View File

@ -194,6 +194,9 @@
instances that belong to different top-level windows. This value has instances that belong to different top-level windows. This value has
been added in Qt 5.4. been added in Qt 5.4.
\value AA_SetPalette Indicates whether a palette was explicitly set on the
QApplication/QGuiApplication. This value has been added in Qt 5.5.
The following values are obsolete: The following values are obsolete:
\value AA_ImmediateWidgetCreation This attribute is no longer fully \value AA_ImmediateWidgetCreation This attribute is no longer fully

View File

@ -2757,6 +2757,7 @@ void QGuiApplication::setPalette(const QPalette &pal)
else else
*QGuiApplicationPrivate::app_pal = pal; *QGuiApplicationPrivate::app_pal = pal;
applicationResourceFlags |= ApplicationPaletteExplicitlySet; applicationResourceFlags |= ApplicationPaletteExplicitlySet;
QCoreApplication::setAttribute(Qt::AA_SetPalette);
emit qGuiApp->paletteChanged(*QGuiApplicationPrivate::app_pal); emit qGuiApp->paletteChanged(*QGuiApplicationPrivate::app_pal);
} }

View File

@ -1508,6 +1508,7 @@ void QApplicationPrivate::setPalette_helper(const QPalette &palette, const char*
QApplicationPrivate::set_pal = new QPalette(palette); QApplicationPrivate::set_pal = new QPalette(palette);
else else
*QApplicationPrivate::set_pal = palette; *QApplicationPrivate::set_pal = palette;
QCoreApplication::setAttribute(Qt::AA_SetPalette);
} }
} }

View File

@ -76,6 +76,7 @@ private slots:
void genericPluginsAndWindowSystemEvents(); void genericPluginsAndWindowSystemEvents();
void layoutDirection(); void layoutDirection();
void globalShareContext(); void globalShareContext();
void testSetPaletteAttribute();
void staticFunctions(); void staticFunctions();
@ -968,6 +969,22 @@ void tst_QGuiApplication::globalShareContext()
#endif #endif
} }
void tst_QGuiApplication::testSetPaletteAttribute()
{
QCoreApplication::setAttribute(Qt::AA_SetPalette, false);
int argc = 1;
char *argv[] = { const_cast<char*>("tst_qguiapplication") };
QGuiApplication app(argc, argv);
QVERIFY(!QCoreApplication::testAttribute(Qt::AA_SetPalette));
QPalette palette;
palette.setColor(QPalette::Foreground, Qt::red);
QGuiApplication::setPalette(palette);
QVERIFY(QCoreApplication::testAttribute(Qt::AA_SetPalette));
}
// Test that static functions do not crash if there is no application instance. // Test that static functions do not crash if there is no application instance.
void tst_QGuiApplication::staticFunctions() void tst_QGuiApplication::staticFunctions()
{ {