From fe0d6feff2eab978af7e8bc4dd632238d2a3b502 Mon Sep 17 00:00:00 2001 From: Julian Verdurmen <304NotModified@users.noreply.github.com> Date: Tue, 26 Sep 2017 23:44:12 +0200 Subject: [PATCH] .NET Core 2 support (ILoggerFactory) rename parameters --- .../ConfigureExtensions.cs | 81 ++++++++++++++----- .../NLog.Extensions.Logging.csproj | 19 +++-- src/NLog.Extensions.Logging/NLogLogger.cs | 2 +- test/NLog.Extensions.Logging.Tests.csproj | 4 +- 4 files changed, 74 insertions(+), 32 deletions(-) diff --git a/src/NLog.Extensions.Logging/ConfigureExtensions.cs b/src/NLog.Extensions.Logging/ConfigureExtensions.cs index 50b4659a..d2b99527 100644 --- a/src/NLog.Extensions.Logging/ConfigureExtensions.cs +++ b/src/NLog.Extensions.Logging/ConfigureExtensions.cs @@ -11,6 +11,7 @@ namespace NLog.Extensions.Logging /// public static class ConfigureExtensions { + /// /// Enable NLog as logging provider in .NET Core. /// @@ -28,6 +29,47 @@ public static ILoggerFactory AddNLog(this ILoggerFactory factory) /// NLog options /// ILoggerFactory for chaining public static ILoggerFactory AddNLog(this ILoggerFactory factory, NLogProviderOptions options) + { + ConfigureHiddenAssemblies(); + + using (var provider = new NLogLoggerProvider(options)) + { + factory.AddProvider(provider); + } + return factory; + } + +#if NETSTANDARD2_0 + + /// + /// Enable NLog as logging provider in .NET Core. + /// + /// + /// ILoggerFactory for chaining + public static ILoggingBuilder AddNLog(this ILoggingBuilder factory) + { + return AddNLog(factory, null); + } + + /// + /// Enable NLog as logging provider in .NET Core. + /// + /// + /// NLog options + /// ILoggerFactory for chaining + public static ILoggingBuilder AddNLog(this ILoggingBuilder factory, NLogProviderOptions options) + { + ConfigureHiddenAssemblies(); + + using (var provider = new NLogLoggerProvider(options)) + { + factory.AddProvider(provider); + } + return factory; + } +#endif + + private static void ConfigureHiddenAssemblies() { //ignore this LogManager.AddHiddenAssembly(Assembly.Load(new AssemblyName("Microsoft.Extensions.Logging"))); @@ -43,24 +85,19 @@ public static ILoggerFactory AddNLog(this ILoggerFactory factory, NLogProviderOp { //ignore } - - LogManager.AddHiddenAssembly(typeof(ConfigureExtensions).GetTypeInfo().Assembly); - using (var provider = new NLogLoggerProvider(options)) - { - factory.AddProvider(provider); - } - return factory; + LogManager.AddHiddenAssembly(typeof(ConfigureExtensions).GetTypeInfo().Assembly); } /// /// Apply NLog configuration from XML config. /// - /// + /// /// relative path to NLog configuration file. - /// Current configuration for chaining. - public static LoggingConfiguration ConfigureNLog(this ILoggerFactory env, string configFileRelativePath) + /// Current configuration for chaining. + public static LoggingConfiguration ConfigureNLog(this ILoggerFactory loggerFactory, string configFileRelativePath) { + #if NETCORE var rootPath = System.AppContext.BaseDirectory; #else @@ -71,24 +108,24 @@ public static LoggingConfiguration ConfigureNLog(this ILoggerFactory env, string return ConfigureNLog(fileName); } - /// - /// Apply NLog configuration from config object. - /// - /// - /// New NLog config. - /// Current configuration for chaining. - public static LoggingConfiguration ConfigureNLog(this ILoggerFactory env, LoggingConfiguration config) - { - LogManager.Configuration = config; + /// + /// Apply NLog configuration from config object. + /// + /// + /// New NLog config. + /// Current configuration for chaining. + public static LoggingConfiguration ConfigureNLog(this ILoggerFactory loggerFactory, LoggingConfiguration config) + { + LogManager.Configuration = config; - return config; - } + return config; + } /// /// Apply NLog configuration from XML config. /// /// absolute path NLog configuration file. - /// Current configuration for chaining. + /// Current configuration for chaining. private static LoggingConfiguration ConfigureNLog(string fileName) { var config = new XmlLoggingConfiguration(fileName, true); diff --git a/src/NLog.Extensions.Logging/NLog.Extensions.Logging.csproj b/src/NLog.Extensions.Logging/NLog.Extensions.Logging.csproj index 394eb5e4..f7f3f292 100644 --- a/src/NLog.Extensions.Logging/NLog.Extensions.Logging.csproj +++ b/src/NLog.Extensions.Logging/NLog.Extensions.Logging.csproj @@ -3,7 +3,7 @@ NLog provider for Microsoft.Extensions.Logging 1.0.0-rtm-beta5 Microsoft;Julian Verdurmen - net451;netstandard1.3 + net451;netstandard1.3;netstandard2.0 true NLog.Extensions.Logging NLog.snk @@ -18,22 +18,27 @@ git git://github.com/NLog/NLog.Extensions.Logging - - - + - + + - + $(DefineConstants);NETCORE - + + + + + + + \ No newline at end of file diff --git a/src/NLog.Extensions.Logging/NLogLogger.cs b/src/NLog.Extensions.Logging/NLogLogger.cs index aab455f0..1132a117 100644 --- a/src/NLog.Extensions.Logging/NLogLogger.cs +++ b/src/NLog.Extensions.Logging/NLogLogger.cs @@ -38,7 +38,7 @@ public void Log(Microsoft.Extensions.Logging.LogLevel logLevel, EventId eventInfo.Exception = exception; if (!_options.IgnoreEmptyEventId || eventId.Id != 0 || !string.IsNullOrEmpty(eventId.Name)) { - /// Attempt to reuse the same string-allocations based on the current + // Attempt to reuse the same string-allocations based on the current var eventIdPropertyNames = _eventIdPropertyNames ?? new Tuple(null, null, null); var eventIdSeparator = _options.EventIdSeparator ?? string.Empty; if (!ReferenceEquals(eventIdPropertyNames.Item1, eventIdSeparator)) diff --git a/test/NLog.Extensions.Logging.Tests.csproj b/test/NLog.Extensions.Logging.Tests.csproj index 45572c0a..8b287c22 100644 --- a/test/NLog.Extensions.Logging.Tests.csproj +++ b/test/NLog.Extensions.Logging.Tests.csproj @@ -5,8 +5,8 @@ - - + +