2010-09-21 09:07:39 +02:00
|
|
|
#include "logfile.h"
|
|
|
|
#include <QDebug>
|
2010-09-21 21:28:01 +02:00
|
|
|
#include <QtGlobal>
|
2010-09-21 09:07:39 +02:00
|
|
|
|
|
|
|
LogFile::LogFile(QObject *parent) :
|
|
|
|
QIODevice(parent)
|
|
|
|
{
|
2010-09-21 21:28:01 +02:00
|
|
|
connect(&timer, SIGNAL(timeout()), this, SLOT(timerFired()));
|
2010-09-21 09:07:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
bool LogFile::open(OpenMode mode) {
|
|
|
|
|
|
|
|
// start a timer for playback
|
|
|
|
myTime.restart();
|
|
|
|
|
|
|
|
if(file.open(mode) == FALSE)
|
|
|
|
{
|
|
|
|
qDebug() << "Unable to open " << file.fileName() << " for logging";
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: Write a header at the beginng describing objects so that in future
|
|
|
|
// they can be read back if ID's change
|
|
|
|
|
|
|
|
// Must call parent function for QIODevice to pass calls to writeData
|
|
|
|
QIODevice::open(mode);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void LogFile::close()
|
|
|
|
{
|
|
|
|
file.close();
|
|
|
|
QIODevice::close();
|
|
|
|
}
|
|
|
|
|
|
|
|
qint64 LogFile::writeData(const char * data, qint64 dataSize) {
|
|
|
|
quint32 timeStamp = myTime.elapsed();
|
|
|
|
|
|
|
|
file.write((char *) &timeStamp,sizeof(timeStamp));
|
|
|
|
file.write((char *) &dataSize, sizeof(dataSize));
|
|
|
|
|
|
|
|
qint64 written = file.write(data, dataSize);
|
|
|
|
if(written != -1)
|
|
|
|
emit bytesWritten(written);
|
|
|
|
|
|
|
|
return dataSize;
|
|
|
|
}
|
2010-09-21 21:28:01 +02:00
|
|
|
|
|
|
|
qint64 LogFile::readData(char * data, qint64 maxSize) {
|
|
|
|
qint64 toRead = qMin(maxSize,(qint64)dataBuffer.size());
|
|
|
|
memcpy(data,dataBuffer.data(),toRead);
|
|
|
|
dataBuffer.remove(0,toRead);
|
|
|
|
return toRead;
|
|
|
|
}
|
|
|
|
|
|
|
|
qint64 LogFile::bytesAvailable() const
|
|
|
|
{
|
|
|
|
return dataBuffer.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
void LogFile::timerFired()
|
|
|
|
{
|
|
|
|
qint64 dataSize;
|
|
|
|
|
2010-09-21 23:43:23 +02:00
|
|
|
// TODO: going back in time will be a problem
|
|
|
|
while ((myTime.elapsed() - timeOffset) * playbackSpeed > lastTimeStamp) {
|
2010-09-21 21:28:01 +02:00
|
|
|
file.read((char *) &dataSize, sizeof(dataSize));
|
|
|
|
dataBuffer.append(file.read(dataSize));
|
|
|
|
emit readyRead();
|
|
|
|
|
|
|
|
file.read((char *) &lastTimeStamp,sizeof(lastTimeStamp));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool LogFile::startReplay() {
|
|
|
|
dataBuffer.clear();
|
|
|
|
myTime.restart();
|
2010-09-21 23:43:23 +02:00
|
|
|
timeOffset = 0;
|
|
|
|
playbackSpeed = 1;
|
2010-09-21 21:28:01 +02:00
|
|
|
file.read((char *) &lastTimeStamp,sizeof(lastTimeStamp));
|
|
|
|
timer.setInterval(10);
|
|
|
|
timer.start();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool LogFile::stopReplay() {
|
|
|
|
timer.stop();
|
|
|
|
return true;
|
|
|
|
}
|
2010-09-21 23:43:23 +02:00
|
|
|
|
|
|
|
void LogFile::pauseReplay()
|
|
|
|
{
|
|
|
|
timer.stop();
|
|
|
|
pausedTime = myTime.elapsed();
|
|
|
|
}
|
|
|
|
|
|
|
|
void LogFile::resumeReplay()
|
|
|
|
{
|
|
|
|
timeOffset += myTime.elapsed() - pausedTime;
|
|
|
|
timer.start();
|
|
|
|
}
|
|
|
|
|