~oif-team/ubuntu/natty/qt4-x11/xi2.1

« back to all changes in this revision

Viewing changes to tools/porting/src/logger.h

  • Committer: Bazaar Package Importer
  • Author(s): Adam Conrad
  • Date: 2005-08-24 04:09:09 UTC
  • Revision ID: james.westby@ubuntu.com-20050824040909-xmxe9jfr4a0w5671
Tags: upstream-4.0.0
ImportĀ upstreamĀ versionĀ 4.0.0

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/****************************************************************************
 
2
**
 
3
** Copyright (C) 1992-2005 Trolltech AS. All rights reserved.
 
4
**
 
5
** This file is part of the porting application of the Qt Toolkit.
 
6
**
 
7
** This file may be distributed under the terms of the Q Public License
 
8
** as defined by Trolltech AS of Norway and appearing in the file
 
9
** LICENSE.QPL included in the packaging of this file.
 
10
**
 
11
** This file may be distributed and/or modified under the terms of the
 
12
** GNU General Public License version 2 as published by the Free Software
 
13
** Foundation and appearing in the file LICENSE.GPL included in the
 
14
** packaging of this file.
 
15
**
 
16
** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
 
17
**   information about Qt Commercial License Agreements.
 
18
** See http://www.trolltech.com/qpl/ for QPL licensing information.
 
19
** See http://www.trolltech.com/gpl/ for GPL licensing information.
 
20
**
 
21
** Contact info@trolltech.com if any conditions of this licensing are
 
22
** not clear to you.
 
23
**
 
24
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
 
25
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
 
26
**
 
27
****************************************************************************/
 
28
 
 
29
#ifndef LOGGER_H
 
30
#define LOGGER_H
 
31
 
 
32
#include <QString>
 
33
#include <QStringList>
 
34
#include <QList>
 
35
#include <QMap>
 
36
/*
 
37
    Base class for logger entries;
 
38
    description() should return a text for this entry,
 
39
*/
 
40
class LogEntry
 
41
{
 
42
public:
 
43
    LogEntry(QString type, QString location);
 
44
    virtual ~LogEntry(){};
 
45
    virtual QString description() const =0;
 
46
    virtual void updateLinePos(int threshold, int delta) {Q_UNUSED(threshold); Q_UNUSED(delta)};
 
47
protected:
 
48
    QString type; // Error, Warning, Info, etc
 
49
    QString location;// preprocessor, c++parser, porting, etc
 
50
};
 
51
 
 
52
class PlainLogEntry: public LogEntry
 
53
{
 
54
public:
 
55
     PlainLogEntry(QString type, QString lcation, QString text);
 
56
     QString description() const {return text;};
 
57
protected:
 
58
     QString text;
 
59
};
 
60
 
 
61
/*
 
62
    A log entry that stores a source point: file, line and column.
 
63
*/
 
64
class SourcePointLogEntry : public LogEntry
 
65
{
 
66
public:
 
67
    SourcePointLogEntry(QString type, QString location, QString file, int line, int column, QString text);
 
68
    QString description() const;
 
69
    void updateLinePos(int threshold, int delta);
 
70
protected:
 
71
    QString file;
 
72
    int line;
 
73
    int column;
 
74
    QString text;
 
75
};
 
76
 
 
77
 
 
78
class Logger
 
79
{
 
80
public:
 
81
    Logger(){};
 
82
    ~Logger();
 
83
    static Logger *instance();
 
84
    static void deleteInstance();
 
85
 
 
86
    void beginSection();
 
87
    void commitSection();
 
88
    void revertSection();
 
89
    void addEntry(LogEntry *entry);
 
90
 
 
91
    QStringList fullReport();
 
92
    int numEntries();
 
93
    void updateLineNumbers(int insertLine, int numLines);
 
94
    /*
 
95
        glabalState can be used for storage of application state
 
96
        together with the logger. This can be useful in some cases,
 
97
        for example the current filename is stored here when processing
 
98
        files.
 
99
    */
 
100
    QMap<QString, QString> globalState;
 
101
private:
 
102
    static Logger *theInstance;
 
103
    QList<LogEntry*> logEntries;
 
104
    QList<LogEntry*> pendingLogEntries;
 
105
};
 
106
 
 
107
 
 
108
#endif