QNetworkAccessCache: convert QDateTime::currentDateTime() to currentDateTimeUtc()

The latter is much faster as it doesn't have to deal with
time zones.

This change is safe, because the timestamp member is only
ever handled inside, and the calculation of the time difference
does not depend on any particular time zone.

Credits to Milian Wolff, from whose QtWS15 talk this advice is
taken.

Change-Id: I6c9190a4253ce5972871ab1f12870f8ae9891966
Reviewed-by: Milian Wolff <milian.wolff@kdab.com>
Reviewed-by: Lars Knoll <lars.knoll@theqtcompany.com>
This commit is contained in:
Marc Mutz 2015-10-23 16:32:59 +02:00
parent 4f4da7462b
commit a681b90418

View File

@ -151,7 +151,7 @@ void QNetworkAccessCache::linkEntry(const QByteArray &key)
oldest = node; oldest = node;
} }
node->timestamp = QDateTime::currentDateTime().addSecs(ExpiryTime); node->timestamp = QDateTime::currentDateTimeUtc().addSecs(ExpiryTime);
newest = node; newest = node;
} }
@ -190,7 +190,7 @@ void QNetworkAccessCache::updateTimer()
if (!oldest) if (!oldest)
return; return;
int interval = QDateTime::currentDateTime().secsTo(oldest->timestamp); int interval = QDateTime::currentDateTimeUtc().secsTo(oldest->timestamp);
if (interval <= 0) { if (interval <= 0) {
interval = 0; interval = 0;
} else { } else {
@ -216,7 +216,7 @@ bool QNetworkAccessCache::emitEntryReady(Node *node, QObject *target, const char
void QNetworkAccessCache::timerEvent(QTimerEvent *) void QNetworkAccessCache::timerEvent(QTimerEvent *)
{ {
// expire old items // expire old items
QDateTime now = QDateTime::currentDateTime(); const QDateTime now = QDateTime::currentDateTimeUtc();
while (oldest && oldest->timestamp < now) { while (oldest && oldest->timestamp < now) {
Node *next = oldest->newer; Node *next = oldest->newer;