diff --git a/src/shared/trk/launcher.cpp b/src/shared/trk/launcher.cpp index b9b5f04a1595422431992b1cbc5ebf440cebcc8c..8a78456477210e6c125342993667d30aa9d15556 100644 --- a/src/shared/trk/launcher.cpp +++ b/src/shared/trk/launcher.cpp @@ -467,7 +467,7 @@ void Launcher::closeRemoteFile(bool failed) { QByteArray ba; appendInt(&ba, d->m_copyState.copyFileHandle, TargetByteOrder); - appendInt(&ba, QDateTime::currentDateTime().toTime_t(), TargetByteOrder); + appendDateTime(&ba, QDateTime::currentDateTime(), TargetByteOrder); d->m_device->sendTrkMessage(TrkCloseFile, failed ? TrkCallback() : TrkCallback(this, &Launcher::handleFileCopied), ba); diff --git a/src/shared/trk/trkutils.cpp b/src/shared/trk/trkutils.cpp index 458390d88936ffb9baf1de800318d76cc40902fd..256d4ad1e193256867a3bc091defe1dd5f992558 100644 --- a/src/shared/trk/trkutils.cpp +++ b/src/shared/trk/trkutils.cpp @@ -32,6 +32,9 @@ #include <QtCore/QCoreApplication> #include <QtCore/QDebug> +#include <QtCore/QDate> +#include <QtCore/QDateTime> +#include <QtCore/QTime> #define logMessage(s) do { qDebug() << "TRKCLIENT: " << s; } while (0) @@ -400,6 +403,18 @@ void appendString(QByteArray *ba, const QByteArray &str, Endianness endian, bool ba->append('\0'); } +void appendDateTime(QByteArray *ba, QDateTime dateTime, Endianness endian) +{ + // convert the QDateTime to UTC and append its representation to QByteArray + // format is the same as in FAT file system + dateTime = dateTime.toUTC(); + const QTime utcTime = dateTime.time(); + const QDate utcDate = dateTime.date(); + uint fatDateTime = (utcTime.hour() << 11 | utcTime.minute() << 5 | utcTime.second()/2) << 16; + fatDateTime |= (utcDate.year()-1980) << 9 | utcDate.month() << 5 | utcDate.day(); + appendInt(ba, fatDateTime, endian); +} + QByteArray errorMessage(byte code) { switch (code) { diff --git a/src/shared/trk/trkutils.h b/src/shared/trk/trkutils.h index aec86a17309639303ad53e8b86fef0698fbb451a..3648619373053b1a600a12653f26cf2ce5a6b477 100644 --- a/src/shared/trk/trkutils.h +++ b/src/shared/trk/trkutils.h @@ -37,6 +37,8 @@ typedef unsigned char byte; +class QDateTime; + namespace trk { enum Command { @@ -92,6 +94,7 @@ void appendByte(QByteArray *ba, byte b); void appendShort(QByteArray *ba, ushort s, Endianness = TargetByteOrder); void appendInt(QByteArray *ba, uint i, Endianness = TargetByteOrder); void appendString(QByteArray *ba, const QByteArray &str, Endianness = TargetByteOrder, bool appendNullTerminator = true); +void appendDateTime(QByteArray *ba, QDateTime dateTime, Endianness = TargetByteOrder); struct Library {