runonphone timestamps nanosecond formating set to 9 chars, 0 padded
[qt:qt.git] / tools / runonphone / texttracehandler.cpp
1 /****************************************************************************
2 **
3 ** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4 ** All rights reserved.
5 ** Contact: Nokia Corporation (qt-info@nokia.com)
6 **
7 ** This file is part of the tools applications of the Qt Toolkit.
8 **
9 ** $QT_BEGIN_LICENSE:LGPL$
10 ** GNU Lesser General Public License Usage
11 ** This file may be used under the terms of the GNU Lesser General Public
12 ** License version 2.1 as published by the Free Software Foundation and
13 ** appearing in the file LICENSE.LGPL included in the packaging of this
14 ** file. Please review the following information to ensure the GNU Lesser
15 ** General Public License version 2.1 requirements will be met:
16 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
17 **
18 ** In addition, as a special exception, Nokia gives you certain additional
19 ** rights. These rights are described in the Nokia Qt LGPL Exception
20 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
21 **
22 ** GNU General Public License Usage
23 ** Alternatively, this file may be used under the terms of the GNU General
24 ** Public License version 3.0 as published by the Free Software Foundation
25 ** and appearing in the file LICENSE.GPL included in the packaging of this
26 ** file. Please review the following information to ensure the GNU General
27 ** Public License version 3.0 requirements will be met:
28 ** http://www.gnu.org/copyleft/gpl.html.
29 **
30 ** Other Usage
31 ** Alternatively, this file may be used in accordance with the terms and
32 ** conditions contained in a signed written agreement between you and Nokia.
33 **
34 **
35 **
36 **
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41
42 #include <QTextStream>
43 #include "texttracehandler.h"
44 #include "trkutils.h"
45
46 class TextTraceHandlerPrivate
47 {
48 public:
49     TextTraceHandlerPrivate();
50     ~TextTraceHandlerPrivate();
51     QIODevice *device;
52     QTextStream out;
53 };
54
55 TextTraceHandlerPrivate::TextTraceHandlerPrivate()
56 : out(stdout)
57 {
58 }
59
60 TextTraceHandlerPrivate::~TextTraceHandlerPrivate()
61 {
62     delete device;
63 }
64
65 TextTraceHandler::TextTraceHandler(QIODevice *device, QObject *parent)
66 : QObject(parent)
67 {
68     d = new TextTraceHandlerPrivate;
69     d->device = device;
70     connect(device, SIGNAL(readyRead()), this, SLOT(dataAvailable()));
71 }
72
73 TextTraceHandler::~TextTraceHandler()
74 {
75     delete d;
76 }
77
78 void TextTraceHandler::dataAvailable()
79 {
80     QByteArray result = d->device->readAll();
81     quint64 secs = 0;
82     quint64 ns = 0;
83     if (result.length() >= 8) {
84         quint64 timestamp = trk::extractInt64(result.constData()) & 0x0FFFFFFFFFFFFFFFULL;
85         secs = timestamp / 1000000000;
86         ns = timestamp % 1000000000;
87     }
88     d->out << QString("[%1.%2] %3").arg(secs).arg(ns,9,10,QLatin1Char('0')).arg(QString(result.mid(8))) << endl;
89 }