You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
100 lines
3.0 KiB
100 lines
3.0 KiB
/*
|
|
* Copyright (C) 2019,2020 Dieter (coder2000) Lunn <coder2000-at-gmail.com>
|
|
*
|
|
* 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 3 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, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
using System;
|
|
using System.Linq;
|
|
|
|
namespace Ubiety.Logging.Core
|
|
{
|
|
/// <summary>
|
|
/// DNS logger class.
|
|
/// </summary>
|
|
public static class UbietyLogger
|
|
{
|
|
private static IUbietyLogManager _dnsLogManager = new DefaultLogManager();
|
|
|
|
/// <summary>
|
|
/// Gets logger for the provided type.
|
|
/// </summary>
|
|
/// <typeparam name="T">Type to name the logger.</typeparam>
|
|
/// <returns>Logger named for the type.</returns>
|
|
public static IUbietyLogger Get<T>()
|
|
{
|
|
return _dnsLogManager.GetLogger(NameFor<T>());
|
|
}
|
|
|
|
/// <summary>
|
|
/// Initializes logger.
|
|
/// </summary>
|
|
/// <param name="logManager">Log manager instance.</param>
|
|
public static void Initialize(IUbietyLogManager logManager)
|
|
{
|
|
_dnsLogManager = logManager;
|
|
}
|
|
|
|
private static string NameFor<T>()
|
|
{
|
|
return NameFor(typeof(T));
|
|
}
|
|
|
|
private static string NameFor(Type type)
|
|
{
|
|
if (!type.IsGenericType)
|
|
{
|
|
return type.FullName;
|
|
}
|
|
|
|
var name = type.GetGenericTypeDefinition().FullName;
|
|
|
|
return
|
|
$"{name?.Substring(0, name.IndexOf('`'))}<{string.Join(",", type.GetGenericArguments().Select(NameFor).ToArray())}>";
|
|
}
|
|
|
|
private class DefaultLogManager : IUbietyLogManager
|
|
{
|
|
public IUbietyLogger GetLogger(string name)
|
|
{
|
|
return new DefaultLogger(name);
|
|
}
|
|
|
|
private class DefaultLogger : IUbietyLogger
|
|
{
|
|
private readonly string _name;
|
|
|
|
public DefaultLogger(string name)
|
|
{
|
|
_name = name;
|
|
}
|
|
|
|
public void Log(LogLevel level, object message)
|
|
{
|
|
Log(level, $"{message}");
|
|
}
|
|
|
|
public void Log(LogLevel level, object message, Exception exception)
|
|
{
|
|
Log(level, $"{message}{Environment.NewLine}{exception}");
|
|
}
|
|
|
|
private void Log(LogLevel level, string message)
|
|
{
|
|
Console.WriteLine($"[{_name}::{level}] {message}");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|