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 @@
-
-
+
+