forked from erlang-lager/lager
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsync_error_logger.erl
89 lines (72 loc) · 2.75 KB
/
sync_error_logger.erl
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
77
78
79
80
81
82
83
84
85
86
87
88
89
%%
%% %CopyrightBegin%
%%
%% Copyright Ericsson AB 1996-2009. All Rights Reserved.
%%
%% The contents of this file are subject to the Erlang Public License,
%% Version 1.1, (the "License"); you may not use this file except in
%% compliance with the License. You should have received a copy of the
%% Erlang Public License along with this software. If not, it can be
%% retrieved online at http://www.erlang.org/.
%%
%% Software distributed under the License is distributed on an "AS IS"
%% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
%% the License for the specific language governing rights and limitations
%% under the License.
%%
%% %CopyrightEnd%
%%
-module(sync_error_logger).
%% The error_logger API, but synchronous!
%% This is helpful for tests, otherwise you need lots of nasty timer:sleep.
%% Additionally, the warning map can be set on a per-process level, for
%% convenience, via the process dictionary value `warning_map'.
-export([
info_msg/1, info_msg/2,
warning_msg/1, warning_msg/2,
error_msg/1,error_msg/2
]).
-export([
info_report/1, info_report/2,
warning_report/1, warning_report/2,
error_report/1, error_report/2
]).
info_msg(Format) ->
info_msg(Format, []).
info_msg(Format, Args) ->
gen_event:sync_notify(error_logger, {info_msg, group_leader(), {self(), Format, Args}}).
warning_msg(Format) ->
warning_msg(Format, []).
warning_msg(Format, Args) ->
gen_event:sync_notify(error_logger, {warning_msg_tag(), group_leader(), {self(), Format, Args}}).
error_msg(Format) ->
error_msg(Format, []).
error_msg(Format, Args) ->
gen_event:sync_notify(error_logger, {error, group_leader(), {self(), Format, Args}}).
info_report(Report) ->
info_report(std_info, Report).
info_report(Type, Report) ->
gen_event:sync_notify(error_logger, {info_report, group_leader(), {self(), Type, Report}}).
warning_report(Report) ->
warning_report(std_warning, Report).
warning_report(Type, Report) ->
{Tag, NType} = warning_report_tag(Type),
gen_event:sync_notify(error_logger, {Tag, group_leader(), {self(), NType, Report}}).
error_report(Report) ->
error_report(std_error, Report).
error_report(Type, Report) ->
gen_event:sync_notify(error_logger, {error_report, group_leader(), {self(), Type, Report}}).
warning_msg_tag() ->
case get(warning_map) of
warning -> warning_msg;
info -> info_msg;
_ -> error
end.
warning_report_tag(Type) ->
case {get(warning_map), Type == std_warning} of
{warning, _} -> {warning_report, Type};
{info, true} -> {info_report, std_info};
{info, false} -> {info_report, Type};
{_, true} -> {error_report, std_error};
{_, false} -> {error_report, Type}
end.