Compare commits

...

2 Commits

Author SHA1 Message Date
jozsef.b@aycode.com d6356451ac Add ExceptionExtensions... 2024-05-19 07:48:43 +02:00
jozsef.b@aycode.com 56f1eb75f9 ConsoleLog lock 2024-05-19 06:02:28 +02:00
3 changed files with 45 additions and 25 deletions

View File

@ -10,10 +10,6 @@
<ProjectReference Include="..\AyCode.Utils\AyCode.Utils.csproj" />
</ItemGroup>
<ItemGroup>
<Folder Include="Extensions\" />
</ItemGroup>
<ItemGroup>
<PackageReference Include="Microsoft.Extensions.Configuration.EnvironmentVariables" Version="8.0.0" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="8.0.0" />

View File

@ -0,0 +1,26 @@
using AyCode.Utils.Extensions;
namespace AyCode.Core.Extensions;
public static class ExceptionExtensions
{
public static void GetCategoryAndMemberNameFromStackTraceString(this Exception? exception, out string? memberName, out string? categoryName)
{
categoryName = null;
memberName = null;
if (exception == null) return;
var stackTraceString = exception.StackTrace ?? exception.InnerException?.StackTrace;
if (stackTraceString.IsNullOrWhiteSpace()) return;
var stackSplit = stackTraceString.Split(" in ");
if (stackSplit.Length <= 0) return;
stackSplit = stackSplit[0].Split('.');
if (stackSplit.Length <= 1) return;
memberName = stackSplit[^1]; //new StackTrace(exception).GetFrame(0)?.GetMethod()?.Name;
categoryName = stackSplit[^2]; //exception.Source
}
}

View File

@ -9,6 +9,8 @@ public interface IAcConsoleLogWriter : IAcTextLogWriterBase
public class AcConsoleLogWriter : AcTextLogWriterBase, IAcConsoleLogWriter
{
private static readonly object ForWriterLock = new();
protected AcConsoleLogWriter() : this(null)
{
Initialize();
@ -33,29 +35,25 @@ public class AcConsoleLogWriter : AcTextLogWriterBase, IAcConsoleLogWriter
{
if (logText.IsNullOrWhiteSpace()) return;
//lock (ForWriterLock)
lock (ForWriterLock)
{
if (loglevel is > LogLevel.Trace and < LogLevel.Suggest)
switch (loglevel)
{
//Console.ForegroundColor = ConsoleColor.White;
Console.WriteLine(logText);
return;
}
if (loglevel <= LogLevel.Trace)
{
Console.ForegroundColor = ConsoleColor.Gray;
Console.WriteLine(logText);
}
else if (loglevel == LogLevel.Suggest)
{
Console.ForegroundColor = ConsoleColor.Cyan;
Console.WriteLine(logText);
}
else
{
Console.ForegroundColor = loglevel == LogLevel.Warning ? ConsoleColor.Yellow : ConsoleColor.Red;
Console.WriteLine($"{AcEnv.NL}{logText}{AcEnv.NL}");
case > LogLevel.Trace and < LogLevel.Suggest:
Console.WriteLine(logText);
return;
case <= LogLevel.Trace:
Console.ForegroundColor = ConsoleColor.Gray;
Console.WriteLine(logText);
break;
case LogLevel.Suggest:
Console.ForegroundColor = ConsoleColor.Cyan;
Console.WriteLine(logText);
break;
default:
Console.ForegroundColor = loglevel == LogLevel.Warning ? ConsoleColor.Yellow : ConsoleColor.Red;
Console.WriteLine($"{AcEnv.NL}{logText}{AcEnv.NL}");
break;
}
Console.ForegroundColor = ConsoleColor.White;