source: trunk/tools/porting/src/logger.cpp@ 372

Last change on this file since 372 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 4.3 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information ([email protected])
5**
6** This file is part of the qt3to4 porting application of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at [email protected].
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42#include "logger.h"
43#include <QFile>
44#include <QDateTime>
45
46QT_BEGIN_NAMESPACE
47
48LogEntry::LogEntry(QString type, QString location)
49:type(type), location(location)
50{}
51
52PlainLogEntry::PlainLogEntry(QString type, QString location, QString text)
53:LogEntry(type, location), text(text)
54{}
55
56SourcePointLogEntry::SourcePointLogEntry(QString type, QString location, QString file, int line, int column, QString text)
57:LogEntry(type, location), file(file), line(line), column(column), text(text)
58{}
59
60QString SourcePointLogEntry::description() const
61{
62 return QLatin1String("In file ") + file +
63 QLatin1String(" at line ") + QString(QLatin1String("%1")).arg(line + 1) + //line count is zero based, adjust here.
64 QLatin1String(" column ") + QString(QLatin1String("%1")).arg(column) +
65 QLatin1String(": ") + text ;
66}
67
68void SourcePointLogEntry::updateLinePos(int threshold, int delta)
69{
70 if (line >= threshold)
71 line += delta;
72}
73
74/////////////////////////////////////////////////////
75
76
77Logger::~Logger()
78{
79 qDeleteAll(logEntries);
80}
81
82Logger *Logger::theInstance = 0;
83Logger *Logger::instance()
84{
85 if(!theInstance)
86 theInstance = new Logger();
87 return theInstance;
88}
89
90void Logger::deleteInstance()
91{
92 if(theInstance)
93 delete theInstance;
94}
95
96void Logger::addEntry(LogEntry *entry)
97{
98 Q_ASSERT(entry);
99 pendingLogEntries.append(entry);
100}
101
102void Logger::beginSection()
103{
104 commitSection();
105}
106
107void Logger::commitSection()
108{
109 logEntries += pendingLogEntries;
110 pendingLogEntries.clear();
111}
112
113void Logger::revertSection()
114{
115 qDeleteAll(pendingLogEntries);
116 pendingLogEntries.clear();
117}
118
119int Logger::numEntries()
120{
121 commitSection();
122 return logEntries.size();
123}
124
125QStringList Logger::fullReport()
126{
127 commitSection();
128 QStringList report;
129 report << QLatin1String("Log for qt3to4 on ") + QDateTime::currentDateTime().toString() +
130 QLatin1String(". Number of log entries: ") + QString(QLatin1String("%1")).arg(logEntries.size());
131 foreach(LogEntry *logEntry, logEntries) {
132 report << logEntry->description();
133 }
134 return report;
135}
136
137/*
138 Update the line for all SourcePointLogEntrys in the list of pending log
139 entries located on or after insertLine.
140*/
141void Logger::updateLineNumbers(int insertLine, int numLines)
142{
143 foreach(LogEntry *logEntry, pendingLogEntries) {
144 logEntry->updateLinePos(insertLine, numLines);
145 }
146}
147
148QT_END_NAMESPACE
Note: See TracBrowser for help on using the repository browser.