summaryrefslogtreecommitdiff
path: root/shared/nm-glib-aux/nm-logging-base.h
blob: 63e7ddddd513dca9f79f7438b682e1aec112a37e (plain)
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
// SPDX-License-Identifier: LGPL-2.1+

#ifndef __NM_LOGGING_BASE_H__
#define __NM_LOGGING_BASE_H__

#include "nm-logging-fwd.h"

typedef struct {
    const char *name;
    const char *level_str;

    /* nm-logging uses syslog internally. Note that the three most-verbose syslog levels
     * are LOG_DEBUG, LOG_INFO and LOG_NOTICE. Journal already highlights LOG_NOTICE
     * as special.
     *
     * On the other hand, we have three levels LOGL_TRACE, LOGL_DEBUG and LOGL_INFO,
     * which are regular messages not to be highlighted. For that reason, we must map
     * LOGL_TRACE and LOGL_DEBUG both to syslog level LOG_DEBUG. */
    int syslog_level;

    GLogLevelFlags g_log_level;
} LogLevelDesc;

extern const LogLevelDesc level_desc[_LOGL_N];

gboolean _nm_log_parse_level(const char *level, NMLogLevel *out_level);

#endif /* __NM_LOGGING_BASE_H__ */