1 /*****************************************************************************
2 * console.c: console logger
3 *****************************************************************************
4 * Copyright © 1998-2005 VLC authors and VideoLAN
5 * Copyright © 2006-2015 Rémi Denis-Courmont
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU Lesser General Public License as published by
9 * the Free Software Foundation; either version 2.1 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public License
18 * along with this program; if not, write to the Free Software Foundation,
19 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
20 *****************************************************************************/
29 #include <unistd.h> /* isatty(), STDERR_FILNO */
31 #include <vlc_common.h>
32 #include <vlc_plugin.h>
34 static const int ptr_width
= 2 * /* hex digits */ sizeof (uintptr_t);
35 static const char msg_type
[4][9] = { "", " error", " warning", " debug" };
38 # define COL(x,y) "\033[" #x ";" #y "m"
39 # define RED COL(31,1)
40 # define GREEN COL(32,1)
41 # define YELLOW COL(0,33)
42 # define WHITE COL(0,1)
43 # define GRAY "\033[0m"
44 static const char msg_color
[4][8] = { WHITE
, RED
, YELLOW
, GRAY
};
46 static void LogConsoleColor(void *opaque
, int type
, const vlc_log_t
*meta
,
47 const char *format
, va_list ap
)
49 FILE *stream
= stderr
;
50 int verbose
= (intptr_t)opaque
;
56 fprintf(stream
, "["GREEN
"%0*"PRIxPTR GRAY
"] ", ptr_width
,
58 if (meta
->psz_header
!= NULL
)
59 fprintf(stream
, "[%s] ", meta
->psz_header
);
60 fprintf(stream
, "%s %s%s: %s", meta
->psz_module
, meta
->psz_object_type
,
61 msg_type
[type
], msg_color
[type
]);
62 vfprintf(stream
, format
, ap
);
63 fputs(GRAY
"\n", stream
);
68 static void LogConsoleGray(void *opaque
, int type
, const vlc_log_t
*meta
,
69 const char *format
, va_list ap
)
71 FILE *stream
= stderr
;
72 int verbose
= (intptr_t)opaque
;
78 fprintf(stream
, "[%0*"PRIxPTR
"] ", ptr_width
, meta
->i_object_id
);
79 if (meta
->psz_header
!= NULL
)
80 fprintf(stream
, "[%s] ", meta
->psz_header
);
81 fprintf(stream
, "%s %s%s: ", meta
->psz_module
, meta
->psz_object_type
,
83 vfprintf(stream
, format
, ap
);
84 putc_unlocked('\n', stream
);
88 static vlc_log_cb
Open(vlc_object_t
*obj
, void **sysp
)
92 if (!var_InheritBool(obj
, "quiet"))
94 const char *str
= getenv("VLC_VERBOSE");
96 verbosity
= atoi(str
);
98 verbosity
= var_InheritInteger(obj
, "verbose");
104 verbosity
+= VLC_MSG_ERR
;
105 *sysp
= (void *)(uintptr_t)verbosity
;
107 #if defined (HAVE_ISATTY) && !defined (_WIN32)
108 if (isatty(STDERR_FILENO
) && var_InheritBool(obj
, "color"))
109 return LogConsoleColor
;
111 return LogConsoleGray
;
114 #define QUIET_TEXT N_("Be quiet")
115 #define QUIET_LONGTEXT N_("Turn off all messages on the console.")
118 set_shortname(N_("Console log"))
119 set_description(N_("Console logger"))
120 set_category(CAT_ADVANCED
)
121 set_subcategory(SUBCAT_ADVANCED_MISC
)
122 set_capability("logger", 10)
123 set_callbacks(Open
, NULL
)
125 add_bool("quiet", false, QUIET_TEXT
, QUIET_LONGTEXT
, false)