Skip to content

Commit

Permalink
Optimization: used StartsWith(char) instead of StartsWith(string) whe…
Browse files Browse the repository at this point in the history
…re supported
  • Loading branch information
epeshk committed Jul 18, 2024
1 parent 1e9f655 commit 32f5e17
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -103,12 +103,12 @@ LogEvent PrepareWrite<TState>(LogEventLevel level, EventId eventId, TState state
{
messageTemplate = value;
}
else if (property.Key.StartsWith("@"))
else if (property.Key.StartsWith('@'))
{
if (_logger.BindProperty(GetKeyWithoutFirstSymbol(DestructureDictionary, property.Key), property.Value, true, out var destructured))
properties.Add(destructured);
}
else if (property.Key.StartsWith("$"))
else if (property.Key.StartsWith('$'))
{
if (_logger.BindProperty(GetKeyWithoutFirstSymbol(StringifyDictionary, property.Key), property.Value?.ToString(), true, out var stringified))
properties.Add(stringified);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -54,13 +54,12 @@ public static void EnrichWithStateAndCreateScopeItem(LogEvent logEvent, ILogEven
void AddProperty(string key, object? value)
{
var destructureObject = false;

if (key.StartsWith("@"))
if (key.StartsWith('@'))
{
key = SerilogLogger.GetKeyWithoutFirstSymbol(SerilogLogger.DestructureDictionary, key);
destructureObject = true;
}
else if (key.StartsWith("$"))
else if (key.StartsWith('$'))
{
key = SerilogLogger.GetKeyWithoutFirstSymbol(SerilogLogger.StringifyDictionary, key);
value = value?.ToString();
Expand Down
14 changes: 14 additions & 0 deletions src/Serilog.Extensions.Logging/Extensions/StringExtensions.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
using System.Runtime.CompilerServices;

namespace Serilog.Extensions;

#if !NET6_0_OR_GREATER && !NETSTANDARD2_1_OR_GREATER
static class StringExtensions
{
[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static bool StartsWith(this string str, char value)
{
return str.Length > 0 && str[0] == value;
}
}
#endif

0 comments on commit 32f5e17

Please sign in to comment.