File: log.h

package info (click to toggle)
qtcurve 1.9-9
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 12,460 kB
  • sloc: cpp: 70,269; perl: 123; sh: 122; xml: 46; makefile: 15
file content (76 lines) | stat: -rw-r--r-- 3,208 bytes parent folder | download | duplicates (5)
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
/*****************************************************************************
 *   Copyright 2013 - 2015 Yichao Yu <yyc1992@gmail.com>                     *
 *                                                                           *
 *   This program is free software; you can redistribute it and/or modify    *
 *   it under the terms of the GNU Lesser General Public License as          *
 *   published by the Free Software Foundation; either version 2.1 of the    *
 *   License, or (at your option) version 3, or any later version accepted   *
 *   by the membership of KDE e.V. (or its successor approved by the         *
 *   membership of KDE e.V.), which shall act as a proxy defined in          *
 *   Section 6 of version 3 of the license.                                  *
 *                                                                           *
 *   This program 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       *
 *   Lesser General Public License for more details.                         *
 *                                                                           *
 *   You should have received a copy of the GNU Lesser General Public        *
 *   License along with this library. If not,                                *
 *   see <http://www.gnu.org/licenses/>.                                     *
 *****************************************************************************/

#ifndef _QTC_UTILS_LOG_H_
#define _QTC_UTILS_LOG_H_

#include "utils.h"
#include <stdarg.h>

namespace QtCurve {

void backtrace();
enum class LogLevel {
    Debug,
    Info,
    Warn,
    Error,
    Force
};

namespace Log {

LogLevel level();

__attribute__((format(printf, 5, 0)))
void logv(LogLevel level, const char *fname, int line,
          const char *func, const char *fmt, va_list ap);

__attribute__((format(printf, 5, 6)))
void log(LogLevel level, const char *fname, int line, const char *func,
         const char *fmt, ...);

static inline bool
checkLevel(LogLevel _level)
{
    return qtcUnlikely(_level <= LogLevel::Force && _level >= level());
}

}
}

#define qtcLog(__level, fmt, args...)                                   \
    do {                                                                \
        using namespace QtCurve;                                        \
        LogLevel level = (__level);                                     \
        if (!Log::checkLevel(level)) {                                  \
            break;                                                      \
        }                                                               \
        Log::log(level, __FILE__, __LINE__, __FUNCTION__, fmt, ##args); \
    } while (0)

#define qtcDebug(fmt, args...) qtcLog(LogLevel::Debug, fmt, ##args)
#define qtcInfo(fmt, args...) qtcLog(LogLevel::Info, fmt, ##args)
#define qtcWarn(fmt, args...) qtcLog(LogLevel::Warn, fmt, ##args)
#define qtcError(fmt, args...) qtcLog(LogLevel::Error, fmt, ##args)
#define qtcForceLog(fmt, args...) qtcLog(LogLevel::Force, fmt, ##args)

#endif