LogBean.cs
1.8 KB
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
using log4net;
using System;
namespace AGVLib
{
internal class LogBean
{
public delegate void ShowMsg(string msg);
public event ShowMsg ShowDebug;
public event ShowMsg ShowInfo;
public event ShowMsg ShowWarn;
public event ShowMsg ShowError;
readonly ILog log;
string debug = "", info = "", warn = "", error = "";
public LogBean(string logName)
{
this.log = LogManager.GetLogger(logName);
LogUtil.AddLogMap(logName, this);
}
#region Main log
bool check(string old,string newstr)
{
if(old!=null && old.Equals(newstr))
return true;
return false;
}
public void Debug(string msg)
{
ShowDebug?.Invoke(msg);
if(check(debug,msg))
return;
debug = msg;
log.Debug(debug);
}
public void Info(string msg)
{
ShowInfo?.Invoke(msg);
if (check(info, msg))
return;
info = msg;
log.Info(info);
}
public void Warn(string msg)
{
ShowWarn?.Invoke(msg);
if (check(warn, msg))
return;
warn = msg;
log.Warn(warn);
}
public void Error(string msg, Exception exception = null)
{
ShowError?.Invoke(msg);
if (exception == null)
{
if (check(error, msg))
return;
error = msg;
log.Error(error);
}
else
{
if (check(error, msg))
return;
error = msg;
log.Error(error, exception);
}
}
#endregion
}
}