4 This file is part of PulseAudio.
6 PulseAudio is free software; you can redistribute it and/or modify
7 it under the terms of the GNU Lesser General Public License as
8 published by the Free Software Foundation; either version 2 of the
9 License, or (at your option) any later version.
11 PulseAudio is distributed in the hope that it will be useful, but
12 WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with PulseAudio; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
36 #include <pulse/utf8.h>
37 #include <pulse/xmalloc.h>
39 #include <pulsecore/core-util.h>
43 #define ENV_LOGLEVEL "POLYP_LOG"
45 static char *log_ident
= NULL
, *log_ident_local
= NULL
;
46 static pa_log_target_t log_target
= PA_LOG_STDERR
;
47 static void (*user_log_func
)(pa_log_level_t l
, const char *s
) = NULL
;
48 static pa_log_level_t maximal_level
= PA_LOG_NOTICE
;
51 static const int level_to_syslog
[] = {
52 [PA_LOG_ERROR
] = LOG_ERR
,
53 [PA_LOG_WARN
] = LOG_WARNING
,
54 [PA_LOG_NOTICE
] = LOG_NOTICE
,
55 [PA_LOG_INFO
] = LOG_INFO
,
56 [PA_LOG_DEBUG
] = LOG_DEBUG
60 void pa_log_set_ident(const char *p
) {
64 pa_xfree(log_ident_local
);
66 log_ident
= pa_xstrdup(p
);
67 log_ident_local
= pa_utf8_to_locale(log_ident
);
69 log_ident_local
= pa_xstrdup(log_ident
);
72 void pa_log_set_maximal_level(pa_log_level_t l
) {
73 assert(l
< PA_LOG_LEVEL_MAX
);
77 void pa_log_set_target(pa_log_target_t t
, void (*func
)(pa_log_level_t l
, const char*s
)) {
78 assert(t
== PA_LOG_USER
|| !func
);
83 void pa_log_levelv(pa_log_level_t level
, const char *format
, va_list ap
) {
87 assert(level
< PA_LOG_LEVEL_MAX
);
89 if ((e
= getenv(ENV_LOGLEVEL
)))
90 maximal_level
= atoi(e
);
92 if (level
> maximal_level
)
95 text
= pa_vsprintf_malloc(format
, ap
);
97 if (!pa_utf8_valid(text
))
98 pa_log_level(level
, __FILE__
": invalid UTF-8 string following below:");
100 for (t
= text
; t
; t
= n
) {
101 if ((n
= strchr(t
, '\n'))) {
109 switch (log_target
) {
110 case PA_LOG_STDERR
: {
111 const char *prefix
= "", *suffix
= "";
115 /* Yes indeed. Useless, but fun! */
116 if (isatty(STDERR_FILENO
)) {
117 if (level
<= PA_LOG_ERROR
) {
118 prefix
= "\x1B[1;31m";
120 } else if (level
<= PA_LOG_WARN
) {
127 local_t
= pa_utf8_to_locale(t
);
129 fprintf(stderr
, "%s%s%s\n", prefix
, t
, suffix
);
131 fprintf(stderr
, "%s%s%s\n", prefix
, local_t
, suffix
);
139 case PA_LOG_SYSLOG
: {
142 openlog(log_ident_local
? log_ident_local
: "???", LOG_PID
, LOG_USER
);
144 local_t
= pa_utf8_to_locale(t
);
146 syslog(level_to_syslog
[level
], "%s", t
);
148 syslog(level_to_syslog
[level
], "%s", local_t
);
158 user_log_func(level
, t
);
171 void pa_log_level(pa_log_level_t level
, const char *format
, ...) {
173 va_start(ap
, format
);
174 pa_log_levelv(level
, format
, ap
);
178 void pa_log_debug(const char *format
, ...) {
180 va_start(ap
, format
);
181 pa_log_levelv(PA_LOG_DEBUG
, format
, ap
);
185 void pa_log_info(const char *format
, ...) {
187 va_start(ap
, format
);
188 pa_log_levelv(PA_LOG_INFO
, format
, ap
);
192 void pa_log_notice(const char *format
, ...) {
194 va_start(ap
, format
);
195 pa_log_levelv(PA_LOG_INFO
, format
, ap
);
199 void pa_log_warn(const char *format
, ...) {
201 va_start(ap
, format
);
202 pa_log_levelv(PA_LOG_WARN
, format
, ap
);
206 void pa_log_error(const char *format
, ...) {
208 va_start(ap
, format
);
209 pa_log_levelv(PA_LOG_ERROR
, format
, ap
);