File: logger.hrl

package info (click to toggle)
ejabberd 26.02-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 15,396 kB
  • sloc: erlang: 122,646; sh: 4,258; sql: 3,633; perl: 869; makefile: 559; javascript: 216; python: 48
file content (73 lines) | stat: -rw-r--r-- 2,792 bytes parent folder | download
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
%%%----------------------------------------------------------------------
%%%
%%% ejabberd, Copyright (C) 2002-2026   ProcessOne
%%%
%%% This program 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 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
%%% General Public License for more details.
%%%
%%% You should have received a copy of the GNU General Public License along
%%% with this program; if not, write to the Free Software Foundation, Inc.,
%%% 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
%%%
%%%----------------------------------------------------------------------
-define(PRINT(Format, Args), io:format(Format, Args)).

-include_lib("kernel/include/logger.hrl").

-define(CLEAD,    "\e[1").    % bold
-define(CMID,     "\e[0").    % normal
-define(CCLEAN,   "\e[0m").   % clean

-define(CDEFAULT, ";49;95m"). % light magenta
-define(CDEBUG,   ";49;90m"). % dark gray
-define(CINFO,    ";49;92m"). % green
-define(CWARNING, ";49;93m"). % light yellow
-define(CERROR,   ";49;91m"). % light magenta
-define(CCRITICAL,";49;31m"). % light red

-define(DEBUG(Format, Args),
	begin ?LOG_DEBUG(Format, Args,
                        #{clevel => ?CLEAD ++ ?CDEBUG,
                          ctext => ?CMID ++ ?CDEBUG}),
              ok end).

-define(INFO_MSG(Format, Args),
	begin ?LOG_INFO(Format, Args,
                        #{clevel => ?CLEAD ++ ?CINFO,
                          ctext => ?CCLEAN}),
              ok end).

-define(WARNING_MSG(Format, Args),
	begin ?LOG_WARNING(Format, Args,
                        #{clevel => ?CLEAD ++ ?CWARNING,
                          ctext => ?CMID ++ ?CWARNING}),
              ok end).

-define(ERROR_MSG(Format, Args),
	begin ?LOG_ERROR(Format, Args,
                        #{clevel => ?CLEAD ++ ?CERROR,
                          ctext => ?CMID ++ ?CERROR}),
              ok end).

-define(CRITICAL_MSG(Format, Args),
	begin ?LOG_CRITICAL(Format, Args,
                        #{clevel => ?CLEAD++ ?CCRITICAL,
                          ctext => ?CMID ++ ?CCRITICAL}),
              ok end).

%% Use only when trying to troubleshoot test problem with ExUnit
-define(EXUNIT_LOG(Format, Args),
        case lists:keyfind(logger, 1, application:loaded_applications()) of
            false -> ok;
            _ -> 'Elixir.Logger':bare_log(error, io_lib:format(Format, Args), [?MODULE])
        end).

%% Uncomment if you want to debug p1_fsm/gen_fsm
%%-define(DBGFSM, true).