Implement configurable logging.
This commit is contained in:
parent
856fc63627
commit
a0f719b8df
2 changed files with 114 additions and 39 deletions
|
@ -13,7 +13,7 @@ namespace ConsoleInterface
|
|||
public static class Program
|
||||
{
|
||||
private static ILoggerFactory _loggerFactory;
|
||||
public static readonly ILogger Logger = NullLogger.Instance;
|
||||
public static ILogger Logger = NullLogger.Instance;
|
||||
|
||||
/// <summary>
|
||||
/// The console interface for the project and the main entrypoint.
|
||||
|
@ -22,28 +22,23 @@ namespace ConsoleInterface
|
|||
// ReSharper disable once UnusedMember.Local
|
||||
public static void Main(string[] args)
|
||||
{
|
||||
Parser.Default.ParseArguments<Options>(args).WithParsed(RunOptions);
|
||||
Parser.Default.ParseArguments<ProgramOptions>(args).WithParsed(RunOptions);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// RunOptions will be called after the command-line arguments were successfully parsed.
|
||||
/// </summary>
|
||||
private static void RunOptions(Options options)
|
||||
private static void RunOptions(ProgramOptions options)
|
||||
{
|
||||
_loggerFactory = LoggerFactory.Create(b => b.AddConsole());
|
||||
TaskExecutor.Logger = _loggerFactory.CreateLogger(nameof(TaskExecutor));
|
||||
LocalSystemFilesRetriever.Logger = _loggerFactory.CreateLogger(nameof(LocalSystemFilesRetriever));
|
||||
KeepFilenameFormatter.Logger =
|
||||
_loggerFactory.CreateLogger(nameof(KeepFilenameFormatter));
|
||||
|
||||
SetupLogging(options.LogLevel);
|
||||
CreateDestinationDirectory(options.DestinationDirectory);
|
||||
var outputFormatter = KeepFilenameFormatter.Create(options.DestinationDirectory);
|
||||
var outputFormatter = SimpleOutputSink.Create(options.DestinationDirectory);
|
||||
var executor = TaskExecutor.Create(new TaskExecutorOptions
|
||||
{
|
||||
EnableCompression = options.CompressFiles is true,
|
||||
FileOutputFormatter = outputFormatter
|
||||
OutputSink = outputFormatter
|
||||
});
|
||||
var filesRetriever = LocalSystemFilesRetriever.Create();
|
||||
var filesRetriever = LocalFileBrowser.Create();
|
||||
|
||||
|
||||
executor.ParallelCleanImages(filesRetriever.GetFilenamesFromPath(options.SourceDirectory));
|
||||
|
@ -55,36 +50,77 @@ namespace ConsoleInterface
|
|||
/// <param name="destinationDirectory">The destination directory.</param>
|
||||
private static void CreateDestinationDirectory(string destinationDirectory)
|
||||
{
|
||||
if (FileSystemHelpers.Logger == null)
|
||||
{
|
||||
FileSystemHelpers.Logger = _loggerFactory.CreateLogger(nameof(FileSystemHelpers));
|
||||
}
|
||||
FileSystemHelpers.CreateDestinationDirectory(destinationDirectory);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Options is a class defining command line options supported by this program.
|
||||
/// </summary>
|
||||
public class Options
|
||||
public static void SetupLogging(string logLevel)
|
||||
{
|
||||
/// <summary>
|
||||
/// CompressFiles indicates whether files should be compressed after being cleaned.
|
||||
/// </summary>
|
||||
[Option('c', "compress", Required = false, HelpText = "Compress images after cleaning.", Default = true)]
|
||||
public bool? CompressFiles { get; set; }
|
||||
_loggerFactory = LoggerFactory.Create(b =>
|
||||
{
|
||||
b.AddConsole();
|
||||
var logLevelToBeSet = LogLevel.Information;
|
||||
switch (logLevel.ToLower())
|
||||
{
|
||||
case "trace":
|
||||
case "t":
|
||||
{
|
||||
logLevelToBeSet = LogLevel.Trace;
|
||||
break;
|
||||
}
|
||||
case "debug":
|
||||
case "d":
|
||||
{
|
||||
logLevelToBeSet = LogLevel.Debug;
|
||||
break;
|
||||
}
|
||||
case "information":
|
||||
case "i":
|
||||
case "info":
|
||||
{
|
||||
logLevelToBeSet = LogLevel.Information;
|
||||
break;
|
||||
}
|
||||
case "warning":
|
||||
case "warn":
|
||||
case "w":
|
||||
{
|
||||
logLevelToBeSet = LogLevel.Warning;
|
||||
break;
|
||||
}
|
||||
case "error":
|
||||
case "err":
|
||||
case "e":
|
||||
{
|
||||
logLevelToBeSet = LogLevel.Error;
|
||||
break;
|
||||
}
|
||||
case "critical":
|
||||
case "crt":
|
||||
case "c":
|
||||
{
|
||||
logLevelToBeSet = LogLevel.Critical;
|
||||
break;
|
||||
}
|
||||
case "none":
|
||||
case "n":
|
||||
{
|
||||
logLevelToBeSet = LogLevel.None;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// DestinationDirectory represents the destination directory for the cleaned images.
|
||||
/// </summary>
|
||||
[Option('d', "dest", Required = false, HelpText = "The destination directory for the cleaned images.",
|
||||
Default = "./cleaned")]
|
||||
public string DestinationDirectory { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// SourceDirectory represents the source directory of images.
|
||||
/// </summary>
|
||||
[Value(0, MetaName = "source", HelpText = "The source directory of images.", Default = ".")]
|
||||
public string SourceDirectory { get; set; }
|
||||
b.SetMinimumLevel(logLevelToBeSet);
|
||||
});
|
||||
Logger = _loggerFactory.CreateLogger(nameof(Program));
|
||||
// Tasks
|
||||
TaskExecutor.Logger = _loggerFactory.CreateLogger(nameof(TaskExecutor));
|
||||
// File Retriever
|
||||
LocalFileBrowser.Logger = _loggerFactory.CreateLogger(nameof(LocalFileBrowser));
|
||||
// FileName formatter
|
||||
SimpleOutputSink.Logger =
|
||||
_loggerFactory.CreateLogger(nameof(SimpleOutputSink));
|
||||
FileSystemHelpers.Logger = _loggerFactory.CreateLogger(nameof(FileSystemHelpers));
|
||||
Logger.LogTrace("SetupLogging - exit");
|
||||
}
|
||||
}
|
||||
}
|
39
ConsoleInterface/ProgramOptions.cs
Normal file
39
ConsoleInterface/ProgramOptions.cs
Normal file
|
@ -0,0 +1,39 @@
|
|||
using CommandLine;
|
||||
|
||||
namespace ConsoleInterface
|
||||
{
|
||||
/// <summary>
|
||||
/// ProgramOptions is a class defining command line options supported by this program.
|
||||
/// </summary>
|
||||
public class ProgramOptions
|
||||
{
|
||||
/// <summary>
|
||||
/// CompressFiles indicates whether files should be compressed after being cleaned.
|
||||
/// </summary>
|
||||
[Option('c', "compress", Required = false, HelpText = "Compress images after cleaning.", Default = true)]
|
||||
public bool? CompressFiles { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// DestinationDirectory represents the destination directory for the cleaned images.
|
||||
/// </summary>
|
||||
[Option('d', "destination", Required = false,
|
||||
HelpText = "The destination directory for the cleaned images.",
|
||||
Default = "./cleaned")]
|
||||
public string DestinationDirectory { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// DestinationDirectory represents the destination directory for the cleaned images.
|
||||
/// </summary>
|
||||
[Option('l', "log-level", Required = false,
|
||||
HelpText =
|
||||
"The logging level of the program. Available log levels are: None,Trace,Debug,Information,Warning,Error,Critical.",
|
||||
Default = "Information")]
|
||||
public string LogLevel { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// SourceDirectory represents the source directory of images.
|
||||
/// </summary>
|
||||
[Value(0, MetaName = "source", HelpText = "The source directory of images.", Default = ".")]
|
||||
public string SourceDirectory { get; set; }
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue