1
/***************************************************************************
2
* Copyright (C) 2004 by Roberto Virga *
3
* rvirga@users.sf.net *
5
* This program is free software; you can redistribute it and/or modify *
6
* it under the terms of the GNU General Public License as published by *
7
* the Free Software Foundation; either version 2 of the License, or *
8
* (at your option) any later version. *
10
* This program is distributed in the hope that it will be useful, *
11
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
12
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13
* GNU General Public License for more details. *
15
* You should have received a copy of the GNU General Public License *
16
* along with this program; if not, write to the *
17
* Free Software Foundation, Inc., *
18
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
19
***************************************************************************/
24
#include <kbslogmonitor.h>
26
class KBSSETIProjectMonitor;
28
class KBSSETILog : public KBSLogMonitor
32
KBSSETILog(const KURL &url, QObject *parent=0, const char *name=0);
34
virtual QStringList keys() const;
35
virtual bool hasResults() const;
38
virtual bool parseFile(KBSFileInfo *file, const QString &fileName);
40
virtual KBSLogDatum formatWorkunitDatum(KBSSETIProjectMonitor *projectMonitor, const QString &workunit) const;
41
virtual KBSLogData formatSpikeData(KBSSETIProjectMonitor *monitor, const QString &workunit) const;
42
virtual KBSLogData formatGaussianData(KBSSETIProjectMonitor *monitor, const QString &workunit) const;
43
virtual KBSLogData formatPulseData(KBSSETIProjectMonitor *monitor, const QString &workunit) const;
44
virtual KBSLogData formatTripletData(KBSSETIProjectMonitor *monitor, const QString &workunit) const;
45
virtual QMap<QString,KBSLogData> formatWorkunit(KBSProjectMonitor *monitor, const QString &workunit) const;
47
virtual void appendHeader(const KBSFileInfo *info, QIODevice *io);
48
virtual void appendWorkunit(const KBSFileInfo *info, QIODevice *io, const KBSLogDatum &datum);
50
virtual void appendResult(QIODevice *io, const KBSLogDatum &datum);
53
static KBSLogDatum parseKVPSequence(const QString &string);
58
bool parseWorkunitLogDocument(const QStringList &lines);
59
bool parseResultsLogDocument(const QStringList &lines);
62
void updateFile(const QString &fileName);
65
enum FileType {WorkunitFile, ResultsFile};
66
static const QString s_filename[ResultsFile+1];
70
enum ResultType {Spike, Gaussian, Pulse, Triplet};