53 lines
1.7 KiB
C#
53 lines
1.7 KiB
C#
using Microsoft.Extensions.Configuration;
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
using Microsoft.Extensions.Hosting;
|
|
using Microsoft.Extensions.Logging;
|
|
using View_by_Distance.Rename.Models;
|
|
|
|
namespace View_by_Distance.Rename;
|
|
|
|
public class Program
|
|
{
|
|
|
|
public static void Secondary(ILogger<Program> logger, List<string> args)
|
|
{
|
|
IConfigurationBuilder configurationBuilder = new ConfigurationBuilder()
|
|
.AddEnvironmentVariables()
|
|
.AddUserSecrets<Program>();
|
|
IConfigurationRoot configurationRoot = configurationBuilder.Build();
|
|
AppSettings appSettings = AppSettings.Get(configurationRoot);
|
|
int silentIndex = args.IndexOf("s");
|
|
if (silentIndex > -1)
|
|
args.RemoveAt(silentIndex);
|
|
try
|
|
{
|
|
if (args is null)
|
|
throw new Exception("args is null!");
|
|
Shared.Models.Console console = new();
|
|
_ = new Rename(args, logger, appSettings, silentIndex > -1, console);
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
logger?.LogError(ex, "Error!");
|
|
}
|
|
if (silentIndex > -1)
|
|
logger?.LogInformation("Done. Bye");
|
|
else
|
|
{
|
|
logger?.LogInformation("Done. Press 'Enter' to end");
|
|
_ = Console.ReadLine();
|
|
}
|
|
}
|
|
|
|
public static void Main(string[] args)
|
|
{
|
|
#pragma warning disable IL3050
|
|
ILogger<Program>? logger = Host.CreateDefaultBuilder(args).Build().Services.GetRequiredService<ILogger<Program>>();
|
|
#pragma warning restore IL3050
|
|
if (args is not null)
|
|
Secondary(logger, args.ToList());
|
|
else
|
|
Secondary(logger, []);
|
|
}
|
|
|
|
} |