File: Debug.h

package info (click to toggle)
qtop 2.3.4-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,976 kB
  • sloc: cpp: 40,477; makefile: 7
file content (113 lines) | stat: -rw-r--r-- 2,548 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#ifndef Debug_h
#define Debug_h

/******************************************************************************
*
* Copyright (C) 2002 Hugo PEREIRA <mailto: hugo.pereira@free.fr>
*
* This is free software; you can redistribute it and/or modify it under the
* terms of the GNU General Public License as published by the Free Software
* Foundation; either version 2 of the License, or (at your option) any later
* version.
*
* This software is distributed in the hope that it will be useful, but WITHOUT
* Any WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
* for more details.
*
* You should have received a copy of the GNU General Public License along with
* this program.  If not, see <http://www.gnu.org/licenses/>.
*
*******************************************************************************/

#include "TimeStamp.h"

#include <QFile>
#include <QString>
#include <QTextStream>

class Debug final
{
    public:

    //*@name static accessors
    //@{

    //* retrieves the debug level
    static int level();

    //@}

    //*@name static modifiers
    //@{

    //* sets the debug level. Everything thrown of bigger level is not discarded
    static void setLevel( int );

    //* set file name
    static void setFileName( const QString& );

    //* writes string to clog if level is lower than level_
    static void Throw( int, const QString& );

    //* writes string to clog if level_ is bigger than 0
    static void Throw( const QString& value )
    { Throw( 1, value ); }

    //* debug stream
    class Stream final
    {

        public:

        //* constructor
        Stream( bool enabled );

        //*@name modifiers
        //@{

        //* mutable accessor
        QTextStream& get()
        { return stream_; }

        //* file name
        void setFileName( const QString& );

        //@}

        private:

        //* debug level
        bool enabled_ = false;

        //* internal device
        QFile device_;

        //* internal stream
        QTextStream stream_;

        //* universal streamer
        template< class T >
        friend Stream& operator << ( Stream& stream, const T& t )
        {
            if( stream.enabled_ ) stream.stream_ << t;
            return stream;
        }

    };

    //* returns either clog or dummy stream depending of the level
    static Stream& Throw( int = 1 );

    //@}

    private:

    class Private;

    //* return singleton
    static Private& _get();

};

#endif