|
1 | 1 | using System; |
2 | | -using System.Diagnostics; |
| 2 | +using System.Threading.Tasks; |
3 | 3 | using GitVersion.Common; |
4 | 4 | using GitVersion.Configuration; |
5 | 5 | using GitVersion.Logging; |
| 6 | +using Microsoft.Extensions.Configuration; |
6 | 7 | using Microsoft.Extensions.DependencyInjection; |
7 | | -using Console = System.Console; |
| 8 | +using Microsoft.Extensions.Hosting; |
| 9 | +using Microsoft.Extensions.Options; |
8 | 10 | using Environment = GitVersion.Common.Environment; |
9 | 11 |
|
10 | 12 | namespace GitVersion |
11 | 13 | { |
12 | 14 | internal class Program |
13 | 15 | { |
14 | | - private static void Main(string[] args) |
| 16 | + private static async Task Main(string[] args) |
15 | 17 | { |
16 | | - var arguments = ParseArguments(args); |
17 | | - |
18 | | - var exitCode = 1; |
19 | | - if (arguments != null) |
20 | | - { |
21 | | - var services = ConfigureServices(arguments); |
| 18 | + await CreateHostBuilder(args).Build().RunAsync(); |
| 19 | + } |
22 | 20 |
|
23 | | - using (var serviceProvider = services.BuildServiceProvider()) |
| 21 | + private static IHostBuilder CreateHostBuilder(string[] args) => |
| 22 | + new HostBuilder() |
| 23 | + .ConfigureAppConfiguration((hostContext, configApp) => |
| 24 | + { |
| 25 | + configApp.AddCommandLine(args); |
| 26 | + }) |
| 27 | + .ConfigureServices((hostContext, services) => |
24 | 28 | { |
25 | | - try |
26 | | - { |
27 | | - var app = serviceProvider.GetService<IGitVersionRunner>(); |
28 | | - exitCode = app.Run(arguments); |
29 | | - } |
30 | | - catch (Exception exception) |
31 | | - { |
32 | | - Console.Error.WriteLine(exception.Message); |
33 | | - } |
34 | | - } |
35 | | - } |
| 29 | + services.AddSingleton<IArgumentParser, ArgumentParser>(); |
| 30 | + services.AddSingleton<IFileSystem, FileSystem>(); |
| 31 | + services.AddSingleton<IEnvironment, Environment>(); |
| 32 | + services.AddSingleton<IHelpWriter, HelpWriter>(); |
| 33 | + services.AddSingleton<IVersionWriter, VersionWriter>(); |
| 34 | + services.AddSingleton<IGitVersionRunner, GitVersionRunner>(); |
36 | 35 |
|
37 | | - if (Debugger.IsAttached) |
38 | | - { |
39 | | - Console.ReadKey(); |
40 | | - } |
| 36 | + services.AddSingleton(GetLog); |
| 37 | + services.AddSingleton(GetConfigFileLocator); |
| 38 | + services.AddSingleton(sp => GetArguments(sp, args)); |
41 | 39 |
|
42 | | - System.Environment.Exit(exitCode); |
43 | | - } |
| 40 | + services.AddHostedService<GitVersionApp>(); |
| 41 | + }) |
| 42 | + .UseConsoleLifetime(); |
44 | 43 |
|
45 | | - private static IServiceCollection ConfigureServices(Arguments arguments) |
| 44 | + private static ILog GetLog(IServiceProvider sp) |
46 | 45 | { |
47 | | - var services = new ServiceCollection(); |
48 | | - |
49 | | - services.AddSingleton<IFileSystem, FileSystem>(); |
50 | | - services.AddSingleton<IEnvironment, Environment>(); |
51 | | - services.AddSingleton<IHelpWriter, HelpWriter>(); |
52 | | - services.AddSingleton<IVersionWriter, VersionWriter>(); |
53 | | - services.AddSingleton<ILog>(new Log { Verbosity = arguments.Verbosity }); |
54 | | - services.AddSingleton(sp => ConfigFileLocator(sp, arguments)); |
55 | | - services.AddSingleton<IGitVersionRunner, GitVersionRunner>(); |
| 46 | + var arguments = sp.GetService<IOptions<Arguments>>(); |
| 47 | + return new Log { Verbosity = arguments.Value.Verbosity }; |
| 48 | + } |
56 | 49 |
|
57 | | - return services; |
| 50 | + private static IConfigureOptions<Arguments> GetArguments(IServiceProvider sp, string[] args) |
| 51 | + { |
| 52 | + return new ConfigureArguments(sp.GetService<IArgumentParser>(), args); |
58 | 53 | } |
59 | 54 |
|
60 | | - private static IConfigFileLocator ConfigFileLocator(IServiceProvider sp, Arguments arguments) |
| 55 | + private static IConfigFileLocator GetConfigFileLocator(IServiceProvider sp) |
61 | 56 | { |
62 | 57 | var fileSystem = sp.GetService<IFileSystem>(); |
63 | 58 | var log = sp.GetService<ILog>(); |
| 59 | + var arguments = sp.GetService<IOptions<Arguments>>(); |
64 | 60 |
|
65 | | - var configFileLocator = string.IsNullOrWhiteSpace(arguments.ConfigFile) |
| 61 | + var configFileLocator = string.IsNullOrWhiteSpace(arguments.Value.ConfigFile) |
66 | 62 | ? (IConfigFileLocator) new DefaultConfigFileLocator(fileSystem, log) |
67 | | - : new NamedConfigFileLocator(arguments.ConfigFile, fileSystem, log); |
| 63 | + : new NamedConfigFileLocator(arguments.Value.ConfigFile, fileSystem, log); |
68 | 64 |
|
69 | 65 | return configFileLocator; |
70 | 66 | } |
71 | | - |
72 | | - private static Arguments ParseArguments(string[] args) |
73 | | - { |
74 | | - var argumentParser = new ArgumentParser(); |
75 | | - Arguments arguments = null; |
76 | | - try |
77 | | - { |
78 | | - arguments = argumentParser.ParseArguments(args); |
79 | | - } |
80 | | - catch (Exception exception) |
81 | | - { |
82 | | - Console.Error.WriteLine(exception.Message); |
83 | | - } |
84 | | - return arguments; |
85 | | - } |
86 | 67 | } |
87 | 68 | } |
0 commit comments