123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- using System;
- using System.IO;
- using System.Text;
- namespace BepInEx.Logging
- {
-
-
-
- public abstract class BaseLogger : TextWriter
- {
- protected BaseLogger()
- {
- DisplayedLevels = GetDefaultLogLevel();
- }
-
-
-
- public override Encoding Encoding { get; } = new UTF8Encoding(true);
-
-
-
-
-
- public delegate void EntryLoggedEventHandler(LogLevel level, object entry);
-
-
-
- public event EntryLoggedEventHandler EntryLogged;
-
-
-
-
- protected virtual LogLevel GetDefaultLogLevel()
- {
- LogLevel lowest;
- try
- {
- lowest = (LogLevel)Enum.Parse(typeof(LogLevel), Config.GetEntry("logger-displayed-levels", nameof(LogLevel.Info), "BepInEx"));
- }
- catch
- {
- return LogLevel.All;
- }
- if (lowest == LogLevel.None)
- return LogLevel.None;
- LogLevel value = lowest;
- foreach (LogLevel e in Enum.GetValues(typeof(LogLevel)))
- {
- if (lowest > e)
- value |= e;
- }
- return value;
- }
-
-
-
- public LogLevel DisplayedLevels { get; set; }
- private readonly object logLockObj = new object();
-
-
-
-
-
- public virtual void Log(LogLevel level, object entry)
- {
- if ((DisplayedLevels & level) != LogLevel.None)
- {
- lock (logLockObj)
- {
- EntryLogged?.Invoke(level, entry);
- WriteLine($"[{level.GetHighestLevel()}] {entry}");
- }
- }
- }
-
-
-
-
- public virtual void Log(object entry)
- {
- Log(LogLevel.Message, entry);
- }
- }
- }
|